mysql - 如何模擬并發(fā)減庫(kù)存導(dǎo)致的慢sql
問(wèn)題描述
DBA給了我如下一些慢sql的截圖 希望我能優(yōu)化一下完整的截圖中有10個(gè)同樣的update sql,最長(zhǎng)的有56秒
這條update sql對(duì)應(yīng)的業(yè)務(wù)邏輯是這樣的
用戶中獎(jiǎng)后對(duì)應(yīng)獎(jiǎng)品庫(kù)存減一
而我在本地想模擬出這種情況 確定原因是什么以及該如何優(yōu)化。首先想到的原因就是高并發(fā)導(dǎo)致的鎖競(jìng)爭(zhēng), 于是基于此思路,我將最大連接數(shù)改成了10
show variables like ’max_connections’;+-----------------+-------+| Variable_name | Value |+-----------------+-------+| max_connections | 10 |+-----------------+-------+
然后啟動(dòng)了100個(gè)線程并發(fā)執(zhí)行減庫(kù)存sql 很快就全部執(zhí)行完了 500個(gè)線程并發(fā)執(zhí)行也不足一秒啊
100 threads concurrent update stock took time: 168(ms)500 threads concurrent update stock took time: 504(ms)
那么該如何能模擬出線上的這種情況呢?
問(wèn)題解答
回答1:流量復(fù)制,類似于這種 HTTP 流量復(fù)制工具:Gor Go,比較高大上;
自己模擬,使用工具如 Locust 來(lái)自定義請(qǐng)求,以實(shí)現(xiàn)模擬實(shí)際場(chǎng)景。案例有基于Locust、Tsung的百萬(wàn)并發(fā)秒殺壓測(cè)案例
相關(guān)文章:
1. 一個(gè)mysql聯(lián)表查詢的問(wèn)題2. mysql - 一個(gè)表和多個(gè)表是多對(duì)多的關(guān)系,該怎么設(shè)計(jì)3. 運(yùn)行python程序時(shí)出現(xiàn)“應(yīng)用程序發(fā)生異常”的內(nèi)存錯(cuò)誤?4. html5 - iOS的webview加載出來(lái)的H5網(wǎng)頁(yè),怎么修改html標(biāo)簽select的樣式字體?5. python如何不改動(dòng)文件的情況下修改文件的 修改日期6. javascript - git clone 下來(lái)的項(xiàng)目 想在本地運(yùn)行 npm run install 報(bào)錯(cuò)7. java - 我現(xiàn)在一個(gè)servlet中有調(diào)用socket訪問(wèn),作為socket的客戶端,8. 主從備份 - 跪求mysql 高可用主從方案9. mysql主從 - 請(qǐng)教下mysql 主動(dòng)-被動(dòng)模式的雙主配置 和 主從配置在應(yīng)用上有什么區(qū)別?10. python 如何實(shí)現(xiàn)PHP替換圖片 鏈接
