精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

BenchmarkSQL 對 MySQL 測試時請注意隔離級別!

數據庫 MySQL
在使用 BenchmarkSQL(版本為 5.0)壓測一段時間后,會出現卡住的現象,即 tpm TOTAL? 的值不再發生變化,但通過 top 命令觀測到 MySQL 當前的壓力還是很大。

1背景

最近在使用 BenchmarkSQL[1] 工具對 MySQL 進行性能測試的過程中,遇到一個比較有意思的問題,Share 給大家。

BenchmarkSQL 是一款經典的開源數據庫測試工具,內含了TPC-C測試腳本,可支持 Oracle、MySQL、PostgreSQL、SQL Server以及一些國產數據庫的基準測試。

2問題描述

如下圖,在使用 BenchmarkSQL(版本為 5.0)壓測一段時間后,會出現卡住的現象,即 tpm TOTAL 的值不再發生變化,但通過 top 命令觀測到 MySQL 當前的壓力還是很大。

登錄 MySQL,通過 information_schema.innodb_trx 表可以看到,MySQL 一直在重復執行這兩個 SQL:

mysql> select * from information_schema.innodb_trx\G
*************************** 1. row ***************************
                    trx_id: 685907
                 trx_state: RUNNING
               trx_started: 2024-05-28 11:14:21
     trx_requested_lock_id: NULL
          trx_wait_started: NULL
                trx_weight: 2
       trx_mysql_thread_id: 157
                 trx_query: SELECT no_o_id FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 ORDER BY no_o_id ASC
       trx_operation_state: NULL
         trx_tables_in_use: 0
         trx_tables_locked: 1
          trx_lock_structs: 2
     trx_lock_memory_bytes: 1128
           trx_rows_locked: 1
         trx_rows_modified: 0
   trx_concurrency_tickets: 0
       trx_isolation_level: REPEATABLE READ
         trx_unique_checks: 1
    trx_foreign_key_checks: 1
trx_last_foreign_key_error: NULL
 trx_adaptive_hash_latched: 0
 trx_adaptive_hash_timeout: 0
          trx_is_read_only: 0
trx_autocommit_non_locking: 0
       trx_schedule_weight: NULL
1 row in set (0.00 sec)
mysql> select * from information_schema.innodb_trx\G
*************************** 1. row ***************************
                    trx_id: 685907
                 trx_state: RUNNING
               trx_started: 2024-05-28 11:14:21
     trx_requested_lock_id: NULL
          trx_wait_started: NULL
                trx_weight: 2
       trx_mysql_thread_id: 157
                 trx_query: DELETE FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 AND no_o_id = 2102
       trx_operation_state: NULL
         trx_tables_in_use: 1
         trx_tables_locked: 1
          trx_lock_structs: 2
     trx_lock_memory_bytes: 1128
           trx_rows_locked: 1
         trx_rows_modified: 0
   trx_concurrency_tickets: 0
       trx_isolation_level: REPEATABLE READ
         trx_unique_checks: 1
    trx_foreign_key_checks: 1
trx_last_foreign_key_error: NULL
 trx_adaptive_hash_latched: 0
 trx_adaptive_hash_timeout: 0
          trx_is_read_only: 0
trx_autocommit_non_locking: 0
       trx_schedule_weight: NULL
1 row in set (0.00 sec)

多次執行 show master status\G 也可以看到 GTID 不再發生變化。為了更好的分析,打開 MySQL 的 general log 后重新壓測抓取 SQL:

可以看到確實出現了重復 DELETE FROM 和 SELECT 的情況,再往前多看幾個事務,你會發現前幾個事務均對 2102 這條記錄進行了 DELETE 的操作。

3源碼探索

為什么會有這種類似死循環的情況出現呢?懷著探索精神,我們一起去看看 BenchmarkSQL 的源代碼。

  • 首先下載對應的源碼包,通過 for 循環找出 SQL 文件對應的代碼文件。
[root@lucky src]$ pwd
/root/packages/BenchmarkSQL-5.0/src

[root@lucky src]$ for dic in client  jdbc  LoadData  OSCollector
do
 echo $dic
 for file in `ls $dic`
 do
     echo $file && cat $dic/$file | grep -Ein 'bmsql_customer|grep bmsql_customer|bmsql_customer|bmsql_oorder|bmsql_new_order|bmsql_order_line|bmsql_stock|bmsql_item|bmsql_history'
 done
done
  • 執行以上命令,可以定位到事務 SQL 的代碼在 ./client/jTPCCConnection.java 文件中,通過搜索 DELETE FROM bmsql_new_order 和 SELECT no_o_id FROM bmsql_new_order,找到對應的 stmtDeliveryBGSelectOldestNewOrder 和 stmtDeliveryBGDeleteOldestNewOrder 關鍵字。

圖片圖片

  • 再次通過關鍵字 stmtDeliveryBGDeleteOldestNewOrder 搜索,最終可以定位到 ./BenchmarkSQL-5.0/src/client/jTPCCTData.java 的這部分代碼:

圖片圖片

看到這部分注釋,也許你已經知道了問題所在,下面我們結合代碼、注釋和實驗,來探究卡住的原因。

  • 事務A:DELETE FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 AND no_o_id = 2102;
  • 事務B:DELETE FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 AND no_o_id = 2102;執行時被阻塞。
  • 事務A:提交。
  • 事務B:繼續執行 DELETE 語句,但因為事務A已經刪除了這行數據,故刪除的記錄數為 0。BenchmarkSQL 中使用了 JDBC 的 executeUpdate() 方法,該方法會返回一個 INT 類型的值,即本次操作在數據庫中改變的行數。
  • 結合代碼分析,在執行 stmt2.executeUpdate() 后,rc=0,o_id=-1。又因為 o_id<0,故執行了 continue,繼續下一個 while 循環。
// 重點簡要代碼
while (o_id < 0)
{
   rs = stmt1.executeQuery();
   rc = stmt2.executeUpdate();
   if (rc == 0)
   {
       o_id = -1;
   }
}

if (o_id < 0)
{
   continue;
}
  1. 因為當前隔離級別配置為 REPEATABLE-READ 級別,故在同一事務中執行 SELECT no_o_id FROM bmsql_new_order ...ASC 進行排序后,查詢結果依舊為 no_o_id=2102 的數據,由此 rc 再次被賦值為 0,進入到無限的 while 死循環中。

4場景實驗

下面我們基于 REPEATABLE-READ 級別和 READ-COMMITTED 級別,進行類似場景的實驗。

1) REPEATABLE-READ 場景

sessionA

sessionB

set autocommit=0;

set autocommit=0;

SELECT no_o_id FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 ORDER BY no_o_id ASC limit 1; # 結果=2542

SELECT no_o_id FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 ORDER BY no_o_id ASC limit 1; # 結果=2542

DELETE FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 AND no_o_id = 2542;

DELETE FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 AND no_o_id = 2542; # 鎖等待

commit;

# 上一條 DELETE 語句執行成功,返回 0 rows affected


SELECT no_o_id FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 ORDER BY no_o_id ASC limit 1; # 結果=2542


DELETE FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 AND no_o_id = 2542; # 執行成功,返回0 rows affected


SELECT no_o_id FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 ORDER BY no_o_id ASC limit 1; # 結果=2542


...

2)READ-COMMITTED 場景

sessionA

sessionB

set autocommit=0;

set autocommit=0;

SELECT no_o_id FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 ORDER BY no_o_id ASC limit 1; # 結果=2543

SELECT no_o_id FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 ORDER BY no_o_id ASC limit 1; # 結果=2543

DELETE FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 AND no_o_id = 2543;

DELETE FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 AND no_o_id = 2543; # 鎖等待

commit;

# 上一條 DELETE 語句執行成功,返回 0 rows affected


SELECT no_o_id FROM bmsql_new_order WHERE no_w_id = 1 AND no_d_id = 1 ORDER BY no_o_id ASC limit 1; # 結果=2544


...

5總結

由此我們可以得出結論,因為 MySQL 配置的隔離級別是 REPEATABLE-READ,導致 BenchmarkSQL 出現了死循環的問題,將其修改為 READ-COMMITTED 級別后,問題得以解決。

參考資料

[1]benchmarksql: https://benchmarksql.readthedocs.io/en/latest/

責任編輯:武曉燕 來源: 愛可生開源社區
相關推薦

2022-06-10 11:51:49

MySQL事務隔離

2018-12-19 16:46:38

MySQL事務隔離數據庫

2021-08-04 13:19:42

MySQL 事務隔離

2021-07-26 10:28:13

MySQL事務隔離

2024-04-26 09:17:20

MySQL事務隔離

2024-12-02 08:37:04

2022-05-23 13:36:31

惡意軟件網絡攻擊

2024-04-23 08:17:14

MySQL數據庫隔離

2021-10-19 10:10:51

MySQL事務隔離級別數據庫

2010-11-19 16:13:06

oracle事務隔離級

2009-06-29 17:54:47

Spring事務隔離

2011-05-07 10:47:29

Oracle大小寫

2025-01-13 13:12:54

2022-09-08 08:02:26

MySQL隔離

2020-10-13 10:32:24

MySQL事務MVCC

2025-03-03 08:20:00

MySQL事務隔離數據庫

2016-01-29 15:59:03

系統中毒防毒軟件

2022-06-29 11:01:05

MySQL事務隔離級別

2018-01-03 08:52:27

MySQL數據庫級別

2023-10-24 08:37:00

git工具開源
點贊
收藏

51CTO技術棧公眾號

在线中文字幕第一页| 国产有码在线观看| 免费欧美激情| 欧美日韩精品免费| 日韩xxxx视频| 国产高清免费av在线| 黑人巨大精品欧美一区| 亚州欧美日韩中文视频| 亚洲无人区码一码二码三码的含义| 伊人久久大香伊蕉在人线观看热v| 一区二区三区在线免费视频| 欧美日韩在线播放一区二区| 99国产精品久久久久久久成人| 在线一区视频| 久久人人爽亚洲精品天堂| 亚洲高清无码久久| 亚洲精品66| 欧美日韩美女在线| 成人在线观看毛片| jizz亚洲| 久久免费视频一区| www日韩av| 亚洲天天综合网| 国产精品人人爽人人做我的可爱| 精品国内亚洲在观看18黄| 精品夜夜澡人妻无码av| 伊人久久大香线蕉av超碰| 欧美色大人视频| 日本免费黄视频| 丰乳肥臀在线| 一区二区三区中文字幕精品精品| 亚洲欧美99| 免费a在线观看| 99亚偷拍自图区亚洲| av一区二区三区四区电影| 国产露脸91国语对白| 日韩高清在线不卡| 青草成人免费视频| 日韩不卡在线播放| 国产视频一区免费看| 久久久久中文字幕2018| 欧美成人精品欧美一级| 日韩在线精品| 在线视频国产日韩| 三年中国中文观看免费播放| 亚洲永久精品唐人导航网址| 日韩乱码在线视频| 真人bbbbbbbbb毛片| 久久人人爽人人爽人人片av不| 日韩一区二区高清| 久久久精品人妻一区二区三区| 麻豆一二三区精品蜜桃| 3d成人h动漫网站入口| 手机在线成人免费视频| 亚洲第一会所| 欧美三片在线视频观看| 激情视频免费网站| 色猫猫成人app| 在线免费不卡视频| www.99在线| 懂色aⅴ精品一区二区三区| 欧美日韩免费一区二区三区视频 | 日韩电影在线观看电影| 国产精品国产三级国产aⅴ浪潮| 中文字幕在线观看视频免费| 日韩影院精彩在线| 国产美女久久精品香蕉69| 国产又粗又猛又色又| 国产精品一区二区在线看| 成人女人免费毛片| 性感美女视频一二三| 久久先锋影音av| 四虎影视永久免费在线观看一区二区三区| 成人免费在线观看| 亚洲色图丝袜美腿| 国产曰肥老太婆无遮挡| 成人美女大片| 欧美人狂配大交3d怪物一区| 丰满饥渴老女人hd| 亚洲精品456| 日韩在线观看免费| 国产一级片久久| 午夜在线精品偷拍| 国产久一一精品| 亚洲乱色熟女一区二区三区| 成人黄色小视频在线观看| 久久天天狠狠| 麻豆网站视频在线观看| 亚洲成人免费视频| 婷婷丁香激情网| 亚洲网一区二区三区| 亚洲免费影视第一页| 国产精品18在线| 狠狠爱综合网| 国产精品久久久久久中文字| www.97超碰| 国产亚洲欧美日韩日本| 300部国产真实乱| 亚洲承认视频| 精品久久一区二区三区| 毛片久久久久久| 亚洲国内欧美| 国产免费一区二区三区在线观看| 六月婷婷综合网| 欧美激情综合五月色丁香| 日本一区午夜艳熟免费| 久久福利在线| 亚洲码在线观看| 久久精品人妻一区二区三区| 日本欧美久久久久免费播放网| 岛国视频一区| 日本在线看片免费人成视1000| 精品久久中文字幕久久av| 日韩成人av免费| 精品久久久久久久久久久下田| 欧美激情日韩图片| 91成品人影院| 久久精品视频免费观看| 男女日批视频在线观看| 美国十次综合久久| 日韩在线中文字幕| 一级黄色av片| 久久日一线二线三线suv| 韩日视频在线观看| 日韩精品一区二区三区中文 | 久久精品国产精品国产精品污| 成人在线播放免费观看| 欧美日本一区二区三区| 日韩毛片无码永久免费看| 一本综合精品| 国产一区二区三区奇米久涩 | 国产aⅴ夜夜欢一区二区三区| 亚洲精品久久久久久动漫器材一区| 国产精品国模大尺度视频| 男人的天堂日韩| 免费不卡中文字幕在线| 欧美一级片在线播放| 日本wwwxxxx| 亚洲成年人影院| 91精品又粗又猛又爽| 欧美阿v一级看视频| 亚洲最大成人免费视频| 国产精品剧情一区二区在线观看| 欧美人与禽zozo性伦| 影音先锋男人资源在线观看| 久久精品国产精品亚洲精品| 日日骚一区二区网站| 岛国一区二区| 久久视频在线看| 国产福利资源在线| 亚洲精品一二三四区| 乳色吐息在线观看| 黄色成人91| 国产日韩欧美亚洲一区| 美女搞黄视频在线观看| 国产丝袜精品第一页| 国产精品熟女视频| 中文无字幕一区二区三区| 欧美精品久久久久久久久25p| 久久要要av| 91丝袜美腿美女视频网站| v片在线观看| 精品国一区二区三区| 久草国产精品视频| 久久久久88色偷偷免费| 久久综合伊人77777麻豆最新章节| 日韩久久精品网| 147欧美人体大胆444| av电影在线地址| 日韩精品免费看| 日韩xxx视频| 亚洲色图欧美激情| 四虎精品一区二区| 老牛嫩草一区二区三区日本 | 尤物在线精品| 老牛影视免费一区二区| 国产精品成人国产| 久久99久久99精品中文字幕| 午夜视频在线免费播放| 精品视频在线看| 久久久.www| 国产无人区一区二区三区| 制服丝袜中文字幕第一页| 韩国在线一区| 日韩欧美一区二区三区四区| 成人噜噜噜噜| 欧亚精品中文字幕| 成人短视频在线| 亚洲精品视频网上网址在线观看| 一区二区久久精品66国产精品| 亚洲一区二区三区影院| 国精产品一区二区三区| 国产精品69久久久久水密桃| 成年人免费在线播放| 伊人色**天天综合婷婷| 欧美黑人3p| 亚洲精品福利| 国产精品视频最多的网站| caoprom在线| 久久精品99国产精品酒店日本| 蜜桃在线一区二区| 欧美日韩国产三级| 国内自拍视频在线播放| 亚洲主播在线观看| 国产美女网站视频| 26uuu亚洲| 制服丝袜第一页在线观看| 蜜乳av一区二区| 一本大道熟女人妻中文字幕在线 | 国产精品97在线| 正在播放日韩欧美一页| 日韩欧美亚洲日产国产| 欧美a级网站| av免费观看久久| 九九九九九九精品任你躁| 国产精品久久久久久久久久久久久久| 182在线视频观看| 操日韩av在线电影| 四虎久久免费| 国产一区二区三区在线| 日本一区高清| 亚洲精品福利在线观看| 欧美一区二区三区黄片 | 午夜视频1000| 亚洲国产高清自拍| 国精品人妻无码一区二区三区喝尿 | 中文字幕av一区二区三区| 亚洲成人日韩在线| 99久久99久久久精品齐齐| 国产精品久久久久久亚洲色| 国产福利不卡视频| ass极品水嫩小美女ass| 国产一区999| 国产三级生活片| 久久er精品视频| 色婷婷成人在线| 青青草国产成人av片免费| 三级4级全黄60分钟| 亚洲永久免费精品| 妺妺窝人体色www在线小说| 亚洲综合欧美| 日本一本二本在线观看| 美女尤物久久精品| 黑鬼大战白妞高潮喷白浆| 日韩中文字幕一区二区三区| 欧美xxxxx在线视频| 久久一区二区三区四区五区 | 丰满女人性猛交| 天堂网在线观看国产精品| 中文字幕在线亚洲精品| 亚洲成人国产| 久久www视频| 亚洲午夜黄色| 91成人在线观看喷潮教学| 国产日韩欧美高清免费| 国产精彩免费视频| 麻豆成人免费电影| 欧美成人乱码一二三四区免费| 另类专区欧美蜜桃臀第一页| 91视频福利网| aaa欧美日韩| 麻豆精品免费视频| 国产精品免费av| av成人免费网站| 亚洲一二三区不卡| 色av性av丰满av| 欧美午夜片在线看| 国产肥老妇视频| 日韩精品视频免费在线观看| 国产福利小视频在线| 日韩在线高清视频| 182在线播放| 国产精品高潮粉嫩av| 欧美高清hd| 鲁片一区二区三区| 久久视频精品| 黄页网站大全在线观看| 男人操女人的视频在线观看欧美| 亚洲天堂av一区二区| 大陆成人av片| 欧美亚洲色综久久精品国产| 一区二区三区四区av| 在线永久看片免费的视频| 欧美一区二区在线免费观看| 亚洲欧洲综合在线| 久久最新资源网| 在线能看的av网址| 91香蕉电影院| 美女精品一区最新中文字幕一区二区三区 | 香蕉视频黄色片| 另类视频在线观看| 另类专区亚洲| caoporn国产精品免费公开| 神马久久一区二区三区| 中文字幕日韩精品无码内射| 视频一区二区三区在线| 女人扒开双腿让男人捅| 欧美国产欧美综合| 六月丁香婷婷综合| 日韩一区二区三区免费看| 超碰国产在线| 97视频人免费观看| 国产成年精品| 婷婷久久五月天| 亚洲欧美清纯在线制服| 超级砰砰砰97免费观看最新一期 | 久久久天堂国产精品| 久久综合伊人| 北京富婆泄欲对白| 亚洲免费av观看| 中文字幕人妻一区二区在线视频 | 日韩理伦片在线| 日韩av免费在线| 牛牛精品成人免费视频| 欧美一区二区三区综合| 精品综合免费视频观看| 公肉吊粗大爽色翁浪妇视频| 黑丝美女久久久| 空姐吹箫视频大全| 欧美激情精品久久久久久大尺度| 欧美天堂一区| 亚洲精品高清国产一线久久| 久久av一区| 久久精品一区二区免费播放| 亚州成人在线电影| 亚洲第一黄色片| 欧美成人免费全部观看天天性色| 日韩免费在线电影| 日韩精品福利视频| 老牛嫩草一区二区三区日本| 欧美狂猛xxxxx乱大交3| 精品久久久久久中文字幕| 欧美一区二不卡视频| 国内免费精品永久在线视频| 亚洲国产中文在线| 欧美国产视频一区| 国产成人av在线影院| 久久久久久久久久久久久女过产乱| 欧美日韩一区久久| 香蕉视频在线免费看| 91精品国产综合久久久久久蜜臀 | 久久精品视频免费| 久久精品五月天| 中文字幕精品一区二区精品| 成人午夜亚洲| 中文字幕欧美日韩一区二区| 精品无人码麻豆乱码1区2区| 91香蕉一区二区三区在线观看| 在线播放视频一区| 午夜影院免费在线| 国产免费一区二区| 国产欧美在线| 久久久久亚洲AV成人无在| 欧美日韩国产片| av在线免费播放| 国产精品v欧美精品v日韩精品| 亚洲国产二区| 亚洲第一香蕉网| 欧美日韩色综合| av免费在线免费| 国产美女在线精品免费观看| 嫩草成人www欧美| 成人信息集中地| 欧美r级电影在线观看| www.51av欧美视频| 丝袜足脚交91精品| 国产精品亚洲一区二区三区妖精| 国产午夜精品无码一区二区| 亚洲免费视频网站| 亚洲伦理网站| 国产www免费| 久久久久久免费| 国产男男gay体育生白袜| 97精品国产91久久久久久| 欧美人与拘性视交免费看| 五月天视频在线观看| 亚洲国产综合色| 国产三级视频在线看| 91精品视频网站| 亚洲一卡久久| 国产黄色录像片| 亚洲高清一二三区| 欧美天堂一区二区| 91成人在线观看喷潮教学| 国产精品午夜久久| 色哟哟中文字幕| 国产日本欧美视频| 国产欧美午夜| 国产一区二区播放| 亚洲免费一级电影| 一区三区自拍| 日本 片 成人 在线| 欧美日韩精品二区| www国产在线观看| 手机在线观看国产精品| 不卡的电视剧免费网站有什么| 亚洲一区二区人妻| 欧美亚洲激情视频| 欧美国内亚洲| av在线免费播放网址|