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

首頁(yè) > 數(shù)據(jù)庫(kù) > MySQL > 正文

MySQL線程處于Opening tables的問(wèn)題解決方法

2024-07-25 19:09:33
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

問(wèn)題描述

最近有一臺(tái)MySQL5.6.21的服務(wù)器,在應(yīng)用發(fā)布后,并發(fā)線程Threads_running迅速升高,達(dá)到2000左右,大量線程處于等待Opening tables、closing tables狀態(tài),應(yīng)用端相關(guān)邏輯訪問(wèn)超時(shí)。

【分析過(guò)程】

1、16:10應(yīng)用發(fā)布結(jié)束后,Opened_tables不斷增加,如下圖所示:

MySQL,線程,Opening,tables

查看當(dāng)時(shí)故障期間抓取的pt-stalk日志文件,時(shí)間點(diǎn)2019-01-18 16:29:37,Open_tables 的值為3430,而table_open_cache的配置值為2000。

當(dāng)Open_tables值大于table_open_cache值時(shí),每次新的session打開(kāi)表,有一些無(wú)法命中table cache,而不得不重新打開(kāi)表。這樣反應(yīng)出來(lái)的現(xiàn)象就是有大量的線程處于opening tables狀態(tài)。

2、這個(gè)實(shí)例下的表,加上系統(tǒng)數(shù)據(jù)庫(kù)下總計(jì)851張,遠(yuǎn)小于table_open_cache的2000,為什么會(huì)導(dǎo)致Open_tables達(dá)到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.

當(dāng)時(shí)并發(fā)線程數(shù)達(dá)到1980,假設(shè)這些并發(fā)連接中有30%是訪問(wèn)2張表,其他都是單表,那么cache size就會(huì)達(dá)到(1980*30%*2+1980*70%*1)=2574

3、QPS在發(fā)布前后都比較平穩(wěn),從外部請(qǐng)求來(lái)看并沒(méi)有突增的連接請(qǐng)求,但在發(fā)布后threads_running上升到接近2000的高位,一直持續(xù)。猜測(cè)是由于某個(gè)發(fā)布的SQL語(yǔ)句觸發(fā)了問(wèn)題。

4、查看當(dāng)時(shí)抓取的processlist信息,有一句SQL并發(fā)訪問(wèn)很高,查詢了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、在測(cè)試環(huán)境中創(chuàng)建相同的8張表,清空表緩存,單個(gè)session執(zhí)行SQL前后對(duì)比,Open_tables的值會(huì)增加8,如果高并發(fā)的情況下,Open_tables的值就會(huì)大幅增加。

問(wèn)題重現(xiàn)

在測(cè)試環(huán)境上模擬高并發(fā)訪問(wèn)的場(chǎng)景,并發(fā)1000個(gè)線程同時(shí)執(zhí)行上面的SQL語(yǔ)句,復(fù)現(xiàn)了生產(chǎn)環(huán)境類似的現(xiàn)象,Open_tables迅速達(dá)到3800,大量進(jìn)程處于Opening tables、closing tables狀態(tài)。

優(yōu)化方案

1、 定位到問(wèn)題原因后,我們與開(kāi)發(fā)同事溝通,建議優(yōu)化該SQL,降低單句SQL查詢表的數(shù)量或大幅降低該SQL的并發(fā)訪問(wèn)頻率。

不過(guò)開(kāi)發(fā)同事還沒(méi)來(lái)的及優(yōu)化,生產(chǎn)環(huán)境上故障又出現(xiàn)了。當(dāng)時(shí)DBA排障時(shí)將table_open_cache從2000增加4000,CPU使用率上升,效果并不明顯,等待Opening tables的問(wèn)題依然存在。

2、 分析故障期間抓取的pstack信息,用pt-pmp聚合后,看到大量線程在open_table時(shí)等待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

這時(shí)table_cache_manager中的mutex沖突非常嚴(yán)重。

由于MySQL5.6.21下table_open_cache_instances參數(shù)的默認(rèn)值為1,想到增大table_open_cache_instances參數(shù),增加表緩存分區(qū),應(yīng)該可以緩解爭(zhēng)用。

3、 在測(cè)試環(huán)境上,我們調(diào)整兩個(gè)參數(shù)table_open_cache_instances=32,table_open_cache=6000,同樣并發(fā)1000個(gè)線程執(zhí)行問(wèn)題SQL,這次等待Opening tables、closing tables的線程消失了,MySQL的QPS也從12000上升到55000。
對(duì)比相同情況下,只調(diào)整table_open_cache=6000,等待Opening tables的進(jìn)程數(shù)從861下降到203,問(wèn)題有所緩解,有600多個(gè)進(jìn)程已經(jīng)從等待Opening tables變?yōu)檫\(yùn)行狀態(tài),QPS上升到40000左右,但不能根治。

源碼分析

查了下代碼有關(guān)table_open_cache的相關(guān)邏輯:

1、Table_cache::add_used_table函數(shù)如下,當(dāng)新的連接打開(kāi)的表在table cache中不存在時(shí),打開(kāi)表加入到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會(huì)調(diào)用Table_cache::free_unused_tables_if_necessary函數(shù),當(dāng)滿足m_table_count > table_cache_size_per_instance &&m_unused_tables時(shí),執(zhí)行remove_table,清除m_unused_tables列表中多余的cache。其中table_cache_size_per_instance= table_cache_size / table_cache_instances,MySQL5.6的默認(rèn)配置是2000/1=2000,當(dāng)m_table_count值大于2000并且m_unused_tables非空時(shí)就執(zhí)行remove_table,將m_unused_tables中的table cache清空。這樣m_table_count就是Open_tables的值正常會(huì)維持在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,當(dāng)Open_tables超過(guò)(2000/32=62)時(shí),就會(huì)滿足條件,加速上述邏輯中m_unused_tables的清理,使得table cache中數(shù)量進(jìn)一步減少,會(huì)導(dǎo)致Table_open_cache_overflows升高。

4、當(dāng)table_open_cache_instances從1增大到32時(shí),1個(gè)LOCK_open鎖分散到32個(gè)m_lock的mutex上,大大降低了鎖的爭(zhēng)用。

/** 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); }

解決問(wèn)題

我們生產(chǎn)環(huán)境同時(shí)采取下面優(yōu)化措施,問(wèn)題得以解決:
1、 讀寫分離,增加read節(jié)點(diǎn),分散master庫(kù)的壓力;
2、 調(diào)整table_open_cache_instances=16;
3、 調(diào)整table_open_cache=6000;

總結(jié)

當(dāng)出現(xiàn)Opening tables等待問(wèn)題時(shí),
1、建議找出打開(kāi)表頻繁的SQL語(yǔ)句,優(yōu)化該SQL,降低單句SQL查詢表的數(shù)量或大幅降低該SQL的并發(fā)訪問(wèn)頻率。

2、設(shè)置合適的table cache,同時(shí)增大table_open_cache_instances和 table_open_cache參數(shù)的值。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到MYSQL教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
中文字字幕一区二区三区四区五区| 日韩视频在线免费播放| 久久综合亚洲色hezyo国产| 欧美freesex黑人又粗又大| 在线看无码的免费网站| 国产91网红主播在线观看| 欧美人妻一区二区三区| 在线视频播放大全| 欧美性猛交xxxx乱大交91| 国产精品第72页| 香蕉视频在线观看黄| 91视频 - 88av| 精品51国产黑色丝袜高跟鞋| bl在线肉h视频大尺度| 中文字幕久久亚洲| 国产粉嫩在线观看| 欧洲精品一区二区三区久久| 青青热久免费精品视频在线18| 亚洲精品久久久久久久久久久久久久| 无码人妻一区二区三区线| 日产精品久久久久久久性色| 欧美色图一区二区三区| 亚洲一级片免费| av免费网站在线观看| 日韩成人在线看| 在线视频亚洲色图| 国产精品一区二区三区久久久| 亚洲人成绝费网站色www| 少妇av片在线观看| 天天做夜夜操| 蜜桃av噜噜一区二区三区小说| 特级毛片在线免费观看| 国产在线播精品第三| 无人区乱码一区二区三区| 成人免费黄色| 久久久天天操| 精品嫩草影院| 香蕉视频网站在线| 天天爽人人爽夜夜爽| 精品一区二区三区日本| 欧美孕妇性xxxⅹ精品hd| 日本丰满少妇xxxx| 91精品国模一区二区三区| 精品久久蜜桃| 精品久久久久久久| 在线免费激情视频| www.久久久久久| 精品久久精品久久| 精品无码人妻一区二区三区品| 国产色在线 com| 久久久国产视频91| 亚洲欧洲制服丝袜| 香蕉污视频在线观看| 日韩电影中文字幕在线| 亚洲成a人片77777老司机| 中文字幕精品国产| 五月激情在线| 精品美女www爽爽爽视频| 精品成人国产在线观看男人呻吟| 一本色道久久综合亚洲| 91日韩视频在线观看| 粉嫩粉嫩芽的虎白女18在线视频| 精品国产髙清在线看国产毛片| 国产一区二区三区站长工具| 精品免费久久久| 777午夜精品福利在线观看| 激情五月激情综合| 亚洲免费看av| 欧美裸身视频免费观看| 免费羞羞视频| 国产日韩一区二区| 亚洲风情亚aⅴ在线发布| 国产精品日韩久久久久| 黄污视频在线观看| 免费日韩一区二区| 国产偷国产偷亚洲清高网站| 免费一级肉体全黄毛片| 国产亚洲一区二区三区在线观看| 欧美日韩在线不卡视频| 国产69精品久久久久9999人| 欧美第一淫aaasss性| 性欧美lx╳lx╳| 97欧美精品一区二区三区| 欧美禁忌电影网| 在线免费观看成人网| 欧美日韩精品一区二区三区视频播放| 经典三级久久| 日本爱爱网站| 久久影院一区二区三区| 青青草国产精品| 亚洲日本一区二区三区| 免费a级毛片在线播放| 亚洲18私人小影院| 91日韩精品一区| 免费在线视频一级不卡| 少妇愉情理伦片bd| 午夜影院黄色片| 两根大肉大捧一进一出好爽视频| 日韩视频不卡中文| 欧美精品国产精品久久久| 中文在线最新版天堂| 欧美亚洲一区二区三区四区| 天天爽夜夜爽夜夜爽精品| 一区二区三区欧洲区| 六月婷婷综合网| 国产黄大片在线观看画质优化| 欧美高清视频一区| 国产一区二区三区朝在线观看| 午夜精品一区二区三区在线视频| 女人成午夜大片7777在线| 一区二区三区在线视频免费| 国产欧美在线观看免费| 国产人妻精品一区二区三| 久久99国产精品成人| 天堂va蜜桃一区二区三区漫画版| 日韩加勒比系列| 日本一区二区三区视频免费看| 亚洲成人天堂| www红色一片_亚洲成a人片在线观看_| av鲁丝一区鲁丝二区鲁丝三区| 日韩一中文字幕| 亚洲精品www| 亚洲精品电影网站| 亚洲免费精彩视频| 围产精品久久久久久久| 日本不卡一区二区三区在线观看| 无码人妻丰满熟妇奶水区码| 91视频免费在线观看| 中文字幕欧美日韩va免费视频| 国产视频二区在线观看| 欧美影院午夜播放| 精品国产乱码久久久久久蜜坠欲下| 欧美日韩另类丝袜其他| 日本黄色免费视频| 国产1区在线观看| 亚洲国产精品va在线看黑人| 欧美日韩蜜桃| 免费看男男www网站入口在线| 综合欧美国产视频二区| 欧美另类极品videosbestfree| 激情综合网最新| 亚洲av无一区二区三区| 国产午夜亚洲精品羞羞网站| 国产福利一区二区三区在线视频| 91高清在线免费观看| 天堂在线视频播放| 在线精品免费视| а√在线中文在线新版| 国产福利91精品一区二区| 欧美精品一区二区久久久| 国产免费久久精品| 精品一区二区三区四区| 一夜七次郎国产精品亚洲| 精品国产乱码91久久久久久网站| 中文字幕在线观看视频网站| 男人操女人免费| 国产a级一级片| 亚洲美女一区二区三区| www.久久av.com| 亚洲资源中文字幕| 在线不卡欧美| 日韩美女一级视频| 亚洲国产欧美一区二区三区丁香婷| 久久久亚洲天堂| 校园春色影音先锋| 亚洲黄色在线网站| 国产欧美啪啪| 免费成人av网站| 波多野结衣 作品| 天天操天天艹| 97久草视频| 欧美三级韩国三级日本三斤| 国产精品你懂的在线观看| 亚洲性夜色噜噜噜7777| 亚洲成人综合网站| 好吊妞视频一区二区三区| 久久亚洲av午夜福利精品一区| 91精品久久久久久久久青青| 日韩av免费看| 色综合电影网| 性xx无遮挡| 国内久久精品视频| 天天夜碰日日摸日日澡性色av| 九色porny自拍视频在线观看| 精品久久久久久亚洲| 成人av高清在线| 一本一道久久久a久久久精品91| 欧美日韩一区二区在线观看| 欧美视频专区一二在线观看| 91精品国产91久久久| 91在线视频在线| 美国一级片在线观看| 日日夜夜免费精品视频| 欧美日韩一区二区三区不卡| 99国产精品99久久久久久粉嫩| 亚洲av无码精品一区二区| 福利片在线一区二区| 激情一区二区| 欧美日韩国产综合久久| 亚洲精品一区二区三区在线观看| 国产精品一站二站| 蜜臀一区二区三区| 国产自产高清不卡| 91超薄肉色丝袜交足高跟凉鞋| 国产在成人精品线拍偷自揄拍| 一级片在线免费播放| 亚洲男人的天堂在线视频| 亚洲色图网友自拍| 亚洲欧美日韩久久精品| 欧美成人精品二区三区99精品| 高清不卡在线观看av| aaa日本高清在线播放免费观看| 免费黄色在线网址| 国产伦精品一区二区三区免.费| 黄色片网站免费| 色婷婷**av毛片一区| 国产99久久久国产精品| 免费国产羞羞网站视频| 亚洲色图38p| 国产欧美中文字幕| 狠狠综合久久| 欧美另类在线播放| 最新av在线| 蜜桃999成人看片在线观看| 上原亚衣加勒比在线播放| 国产精品高潮呻吟久久| 精品伊人久久久久7777人| 超薄肉色丝袜一二三| caopor在线视频| 日韩高清av| 亚洲高清网站| 国产精品久久久久久久久免费高清| 春意影院普通入口| 变态另类ts人妖一区二区| 欧美在线 | 亚洲| 国产v日产∨综合v精品视频| 搡女人真爽免费午夜网站| 成人免费视频caoporn| 日本一区二区成人| 欧美色图一区| 午夜精品久久久久久久无码| 7777精品伊人久久久大香线蕉的| 亚洲高清精品视频| 91精品久久香蕉国产线看观看| 在线影院自拍| t66y最新发布地址| 亚洲成人一二三| 日本精品在线视频| 99久久精品国产亚洲| 免费在线观看麻豆视频| 麻豆tv在线观看| 熟女少妇在线视频播放| 97人人澡人人爽91综合色| 91精品在线影院| 亚洲成人生活片| 国产精品一级片在线观看| 国产人成在线观看| 欧美日韩一区二区三区在线播放| 欧洲在线一区| 在线观看h网| 欧美日韩在线播放一区| 国产精品7777777| 337p亚洲精品色噜噜狠狠| 亚洲桃色在线一区| 亚洲一卡二卡| 色婷婷久久综合中文久久蜜桃av| 免费观看日批视频| 精品国产一区二区三区四区阿崩| 日韩精品综合一本久道在线视频| 1区1区3区4区产品乱码芒果精品| 成人豆花视频| 玛丽玛丽电影原版免费观看1977| 免费污视频在线| 日本不卡一区二区三区高清视频| 日本高清久久天堂| 日本福利片免费看| jvid福利在线一区二区| 黄漫在线观看| 97色在线视频| 四虎国产精品免费久久| 亚洲三级免费观看| 成人高清视频在线| 国产精品灌醉下药二区| 成人性生交大片免费看96| 久久久久中文| 日本a级片电影一区二区| 免费看91视频| 欧美性欧美巨大黑白大战| 久久都是精品| 日本亚洲三级在线| 日本中文字幕电影在线观看| 在线观看中文| 美女与牲口做爰视频在线观看| 国产在线麻豆精品| 国产精品热久久久久夜色精品三区| 伊人av在线播放| 在线观看91| 黄色av电影网站| 欧美另类女人| 精品无码m3u8在线观看| 91视频久色| 久在线观看福利视频| hbad中文字幕| 九色精品免费永久在线| 青青操综合网| 日韩精品欧美激情| 国产午夜电影| 国产精选在线观看| 久久精品国产在热久久| 九一九一国产精品| 天天天天天天天干| 国产免费成人在线| 2017天天干夜夜操| 多野结衣av一区| 国产老女人av| 捆绑变态av一区二区三区| 欧洲av无码放荡人妇网站| 国产精品a久久久久久| 日韩女优中文字幕| 日本不卡中文字幕| 欧美久久高跟鞋激| 国产成人免费在线观看视频| 伊人无码高清| 亚洲综合中文字幕68页| 玖玖爱视频在线| 国产午夜亚洲精品理论片色戒| 亚洲先锋成人| 禁果av一区二区三区|