亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

MySQL線程處于Opening tables的問題解決方法

2024-07-25 19:09:33
字體:
來源:轉載
供稿:網友

問題描述

最近有一臺MySQL5.6.21的服務器,在應用發布后,并發線程Threads_running迅速升高,達到2000左右,大量線程處于等待Opening tables、closing tables狀態,應用端相關邏輯訪問超時。

【分析過程】

1、16:10應用發布結束后,Opened_tables不斷增加,如下圖所示:

MySQL,線程,Opening,tables

查看當時故障期間抓取的pt-stalk日志文件,時間點2019-01-18 16:29:37,Open_tables 的值為3430,而table_open_cache的配置值為2000。

當Open_tables值大于table_open_cache值時,每次新的session打開表,有一些無法命中table cache,而不得不重新打開表。這樣反應出來的現象就是有大量的線程處于opening tables狀態。

2、這個實例下的表,加上系統數據庫下總計851張,遠小于table_open_cache的2000,為什么會導致Open_tables達到3430呢

從官方文檔中可以得到解釋,

https://dev.mysql.com/doc/refman/5.6/en/table-cache.html

table_open_cache is related to max_connections. For example, for 200 concurrent running connections, specify a table cache size of at least 200 * N, where N is the maximum number of tables per join in any of the queries which you execute.

當時并發線程數達到1980,假設這些并發連接中有30%是訪問2張表,其他都是單表,那么cache size就會達到(1980*30%*2+1980*70%*1)=2574

3、QPS在發布前后都比較平穩,從外部請求來看并沒有突增的連接請求,但在發布后threads_running上升到接近2000的高位,一直持續。猜測是由于某個發布的SQL語句觸發了問題。

4、查看當時抓取的processlist信息,有一句SQL并發訪問很高,查詢了8張物理表,SQL樣本如下:

<code>select id,name,email from table1 left join table2<br>union all<br>select id,name,email from table3 left join table4<br>union all<br>select id,name,email from table5 left join table6<br>union all<br>select id,name,email from table7 left join table8<br>where id in ('aaa');</code>

5、在測試環境中創建相同的8張表,清空表緩存,單個session執行SQL前后對比,Open_tables的值會增加8,如果高并發的情況下,Open_tables的值就會大幅增加。

問題重現

在測試環境上模擬高并發訪問的場景,并發1000個線程同時執行上面的SQL語句,復現了生產環境類似的現象,Open_tables迅速達到3800,大量進程處于Opening tables、closing tables狀態。

優化方案

1、 定位到問題原因后,我們與開發同事溝通,建議優化該SQL,降低單句SQL查詢表的數量或大幅降低該SQL的并發訪問頻率。

不過開發同事還沒來的及優化,生產環境上故障又出現了。當時DBA排障時將table_open_cache從2000增加4000,CPU使用率上升,效果并不明顯,等待Opening tables的問題依然存在。

2、 分析故障期間抓取的pstack信息,用pt-pmp聚合后,看到大量線程在open_table時等待mutex資源:

#0 0x0000003f0900e334 in __lll_lock_wait () from /lib64/libpthread.so.0#1 0x0000003f0900960e in _L_lock_995 () from /lib64/libpthread.so.0#2 0x0000003f09009576 in pthread_mutex_lock () from /lib64/libpthread.so.0#3 0x000000000069ce98 in open_table(THD*, TABLE_LIST*, Open_table_context*) ()#4 0x000000000069f2ba in open_tables(THD*, TABLE_LIST**, unsigned int*, unsigned int, Prelocking_strategy*) ()#5 0x000000000069f3df in open_normal_and_derived_tables(THD*, TABLE_LIST*, unsigned int) ()#6 0x00000000006de821 in execute_sqlcom_select(THD*, TABLE_LIST*) ()#7 0x00000000006e13cf in mysql_execute_command(THD*) ()#8 0x00000000006e4d8f in mysql_parse(THD*, char*, unsigned int, Parser_state*) ()#9 0x00000000006e62cb in dispatch_command(enum_server_command, THD*, char*, unsigned int) ()#10 0x00000000006b304f in do_handle_one_connection(THD*) ()#11 0x00000000006b3177 in handle_one_connection ()#12 0x0000000000afe5ca in pfs_spawn_thread ()#13 0x0000003f09007aa1 in start_thread () from /lib64/libpthread.so.0#14 0x0000003f088e893d in clone () from /lib64/libc.so.6

這時table_cache_manager中的mutex沖突非常嚴重。

由于MySQL5.6.21下table_open_cache_instances參數的默認值為1,想到增大table_open_cache_instances參數,增加表緩存分區,應該可以緩解爭用。

3、 在測試環境上,我們調整兩個參數table_open_cache_instances=32,table_open_cache=6000,同樣并發1000個線程執行問題SQL,這次等待Opening tables、closing tables的線程消失了,MySQL的QPS也從12000上升到55000。
對比相同情況下,只調整table_open_cache=6000,等待Opening tables的進程數從861下降到203,問題有所緩解,有600多個進程已經從等待Opening tables變為運行狀態,QPS上升到40000左右,但不能根治。

源碼分析

查了下代碼有關table_open_cache的相關邏輯:

1、Table_cache::add_used_table函數如下,當新的連接打開的表在table cache中不存在時,打開表加入到used tables list:

bool Table_cache::add_used_table(THD *thd, TABLE *table){ Table_cache_element *el;  assert_owner();  DBUG_ASSERT(table->in_use == thd);  /* Try to get Table_cache_element representing this table in the cache from array in the TABLE_SHARE. */ el= table->s->cache_element[table_cache_manager.cache_index(this)];  if (!el) { /*  If TABLE_SHARE doesn't have pointer to the element representing table  in this cache, the element for the table must be absent from table the  cache.   Allocate new Table_cache_element object and add it to the cache  and array in TABLE_SHARE. */ DBUG_ASSERT(! my_hash_search(&m_cache,         (uchar*)table->s->table_cache_key.str,         table->s->table_cache_key.length));  if (!(el= new Table_cache_element(table->s)))  return true;  if (my_hash_insert(&m_cache, (uchar*)el)) {  delete el;  return true; }  table->s->cache_element[table_cache_manager.cache_index(this)]= el; }  /* Add table to the used tables list */  el->used_tables.push_front(table);  m_table_count++; free_unused_tables_if_necessary(thd);  return false;}

2、每次add_used_table會調用Table_cache::free_unused_tables_if_necessary函數,當滿足m_table_count > table_cache_size_per_instance &&m_unused_tables時,執行remove_table,清除m_unused_tables列表中多余的cache。其中table_cache_size_per_instance= table_cache_size / table_cache_instances,MySQL5.6的默認配置是2000/1=2000,當m_table_count值大于2000并且m_unused_tables非空時就執行remove_table,將m_unused_tables中的table cache清空。這樣m_table_count就是Open_tables的值正常會維持在2000上下。

void Table_cache::free_unused_tables_if_necessary(THD *thd){ /* We have too many TABLE instances around let us try to get rid of them.  Note that we might need to free more than one TABLE object, and thus need the below loop, in case when table_cache_size is changed dynamically, at server run time. */ if (m_table_count > table_cache_size_per_instance && m_unused_tables) { mysql_mutex_lock(&LOCK_open); while (m_table_count > table_cache_size_per_instance &&   m_unused_tables) {  TABLE *table_to_free= m_unused_tables;    remove_table(table_to_free);  intern_close_table(table_to_free);  thd->status_var.table_open_cache_overflows++; } mysql_mutex_unlock(&LOCK_open); }}

3、增大table_cache_instances為32,當Open_tables超過(2000/32=62)時,就會滿足條件,加速上述邏輯中m_unused_tables的清理,使得table cache中數量進一步減少,會導致Table_open_cache_overflows升高。

4、當table_open_cache_instances從1增大到32時,1個LOCK_open鎖分散到32個m_lock的mutex上,大大降低了鎖的爭用。

/** Acquire lock on table cache instance. */ void lock() { mysql_mutex_lock(&m_lock); } /** Release lock on table cache instance. */ void unlock() { mysql_mutex_unlock(&m_lock); }

解決問題

我們生產環境同時采取下面優化措施,問題得以解決:
1、 讀寫分離,增加read節點,分散master庫的壓力;
2、 調整table_open_cache_instances=16;
3、 調整table_open_cache=6000;

總結

當出現Opening tables等待問題時,
1、建議找出打開表頻繁的SQL語句,優化該SQL,降低單句SQL查詢表的數量或大幅降低該SQL的并發訪問頻率。

2、設置合適的table cache,同時增大table_open_cache_instances和 table_open_cache參數的值。


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲成色777777在线观看影院| 亚洲激情久久久| 欧美国产视频一区二区| 91国产美女视频| 欧美性猛交xxxx乱大交3| 人妖精品videosex性欧美| 国产狼人综合免费视频| 国产不卡视频在线| 一级做a爰片久久毛片美女图片| 韩国日本不卡在线| 欧美尺度大的性做爰视频| 69久久夜色精品国产7777| 久久综合国产精品台湾中文娱乐网| 久久久视频免费观看| 欧美成人全部免费| 亚洲性生活视频在线观看| 高清欧美性猛交xxxx黑人猛交| 日本a级片电影一区二区| 亚洲精品美女久久久| 精品中文字幕在线2019| 国产精品美女久久| 91免费在线视频网站| 国产成人精品视频| 欧美丰满少妇xxxxx做受| 欧美日韩一区二区在线播放| 亚洲一区二区三区乱码aⅴ| 欧美美女操人视频| 久久国产精品免费视频| 久久亚洲精品国产亚洲老地址| 中文字幕日韩av综合精品| 国产精品极品美女在线观看免费| 日韩中文字幕不卡视频| 欧美成人中文字幕在线| 欧美视频裸体精品| 成年无码av片在线| 亚洲a在线播放| 国产精品 欧美在线| 日韩欧美成人精品| 精品久久在线播放| 亚洲一区二区久久久久久| 成人亚洲欧美一区二区三区| 亚洲3p在线观看| 成人黄色免费网站在线观看| 日韩欧美一区二区在线| 麻豆一区二区在线观看| 91免费综合在线| 国产亚洲欧洲黄色| 色樱桃影院亚洲精品影院| 91在线免费观看网站| 国产一区二区美女视频| 久久久av网站| 欧美极品少妇全裸体| 国产精品久久电影观看| 日韩精品在线免费播放| 亚洲国产一区自拍| 久久亚洲精品视频| 97在线看免费观看视频在线观看| 成人免费观看a| 亚洲一区中文字幕在线观看| 午夜美女久久久久爽久久| 538国产精品一区二区在线| 久久99热精品这里久久精品| 亚洲偷欧美偷国内偷| www.欧美三级电影.com| 国产自产女人91一区在线观看| 5566成人精品视频免费| 久久久久久久一区二区三区| 亚洲字幕一区二区| 亚洲人成电影网站色xx| 国产精品老女人精品视频| 国产精品丝袜视频| 日韩av在线最新| 欧美性猛交xxxx免费看| 欧美日韩国产精品一区二区不卡中文| 欧美日韩国产麻豆| xxxx性欧美| 国产99久久久欧美黑人| 欧亚精品在线观看| 亚洲一区中文字幕在线观看| 国产精品一区二区三区毛片淫片| 日韩av观看网址| 久久成人人人人精品欧| 91精品国产精品| 欧美国产欧美亚洲国产日韩mv天天看完整| 久久6精品影院| 日韩中文娱乐网| 国产精品自拍偷拍| 欧美性极品少妇精品网站| 日产日韩在线亚洲欧美| 成人黄色在线播放| 精品久久久久久久久久| 亚洲大胆美女视频| 国产精品高精视频免费| 国产成人高潮免费观看精品| 久久噜噜噜精品国产亚洲综合| 精品福利一区二区| 精品久久久久国产| 久久亚洲成人精品| 国产精品日本精品| 色综合久久悠悠| 亚洲国产成人av在线| 久久久精品一区二区三区| 色诱女教师一区二区三区| 精品久久久久久久久中文字幕| 蜜臀久久99精品久久久久久宅男| 国产视频观看一区| 成人免费网站在线看| 欧美日韩国产丝袜美女| 国产精品视频成人| 欧美亚洲午夜视频在线观看| 日日骚久久av| 日韩电影在线观看永久视频免费网站| 国产精品91在线| 亚洲人成电影网站色www| 91天堂在线视频| 国产精品视频久久久| 国产欧美精品久久久| 久久成年人免费电影| 色老头一区二区三区在线观看| 亚洲欧美中文字幕在线一区| 日本午夜人人精品| 久久久久久久999| 91在线直播亚洲| 国产欧美精品va在线观看| 国产精品91视频| 亚洲福利小视频| 午夜精品福利视频| 久久久人成影片一区二区三区| 久久精品久久久久电影| 成人a视频在线观看| 国产成人久久久精品一区| 亚洲偷熟乱区亚洲香蕉av| 日韩成人av在线| 17婷婷久久www| 欧美激情欧美狂野欧美精品| 富二代精品短视频| 欧美在线视频免费播放| 亚洲色图激情小说| 国产99久久精品一区二区 夜夜躁日日躁| 永久免费毛片在线播放不卡| 成人福利网站在线观看11| 美女黄色丝袜一区| 亚洲视频视频在线| 精品欧美一区二区三区| 久久视频免费在线播放| 国产成人精品一区二区三区| 国产亚洲精品久久| 日韩精品在线电影| 欧美多人乱p欧美4p久久| 日韩在线免费观看视频| 欧美日韩综合视频网址| 日韩综合视频在线观看| 亚洲深夜福利在线| 亚洲色图第三页| 97色在线观看免费视频| 久久精品国产久精国产一老狼| 成人精品一区二区三区电影免费| 欧美大尺度电影在线观看| 亚洲高清不卡av| 6080yy精品一区二区三区| 深夜福利日韩在线看| 日本亚洲欧美三级| 国内精久久久久久久久久人| 亚洲精品国产精品自产a区红杏吧|