午夜视频免费看_日韩三级电影网站_国产精品久久一级_亚洲一级在线播放_人妻体内射精一区二区三区_91夜夜揉人人捏人人添红杏_91福利在线导航_国产又粗又猛又黄又爽无遮挡_欧美日韩一区在线播放_中文字幕一区二区三区四区不卡 _日日夜夜精品视频免费观看_欧美韩日一区二区三区

<nobr id="lczrk"></nobr>
<nobr id="lczrk"></nobr>
  • <ins id="lczrk"><sup id="lczrk"></sup></ins>
    <table id="lczrk"><video id="lczrk"><samp id="lczrk"></samp></video></table>
  • <tfoot id="lczrk"><div id="lczrk"></div></tfoot>
    主頁 > 知識庫 > MySQL線程處于Opening tables的問題解決方法

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

    熱門標簽:電話機器人市場趨勢 百度地圖標注后不顯示 俄國地圖標注app 昆明電信400電話辦理 淄博400電話申請 電銷機器人 行業 南昌高頻外呼系統哪家公司做的好 溫州瑞安400電話怎么申請 電銷機器人各個細節介紹

    問題描述

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

    【分析過程】

    1、16:10應用發布結束后,Opened_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 table2br>union allbr>select id,name,email from table3 left join table4br>union allbr>select id,name,email from table5 left join table6br>union allbr>select id,name,email from table7 left join table8br>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參數的值。

    您可能感興趣的文章:
    • mybatis學習之路mysql批量新增數據的方法
    • MySQL和Redis實現二級緩存的方法詳解
    • MySQL普通索引和唯一索引的深入講解
    • 使用MySQL的geometry類型處理經緯度距離問題的方法
    • mysql binlog(二進制日志)查看方法
    • Docker創建MySQL的講解
    • PHP date()格式MySQL中插入datetime方法
    • pymysql如何解決sql注入問題深入講解
    • mysql導出表的字段和相關屬性的步驟方法
    • MySQL limit性能分析與優化

    標簽:海口 洛陽 甘南 安徽 吐魯番 拉薩 嘉峪關 葫蘆島

    巨人網絡通訊聲明:本文標題《MySQL線程處于Opening tables的問題解決方法》,本文關鍵詞  MySQL,線程,處于,Opening,tables,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL線程處于Opening tables的問題解決方法》相關的同類信息!
  • 本頁收集關于MySQL線程處于Opening tables的問題解決方法的相關信息資訊供網民參考!
  • 推薦文章
    久久综合加勒比| 777午夜精品免费视频| 久久av二区| 日韩中文字幕影院| 日本一区二区在线播放| 东京热一区二区三区四区| 亚洲人成亚洲人成在线观看| 国产精品815.cc红桃| 日韩欧美成人区| 一级黄色高清视频| 午夜伊人狠狠久久| av在线网址导航| 一本久久综合亚洲鲁鲁五月天| 国产又大又黄又粗又爽| 亚洲成人免费看| 午夜激情av在线| 欧美日韩国产高清一区| 国产人成视频在线观看| 欧美精品日韩一本| 在线观看天堂av| 欧美tk—视频vk| 日本中文字幕免费在线观看| 亚洲一区二区久久| 麻豆成人免费视频| 国产精品视频自在线| 日韩专区在线视频| 国产成人免费电影| 成人精品高清在线| 黄页免费在线观看视频| 欧美视频精品一区| 亚洲最大成人网站| 欧美成人午夜免费视在线看片| 97精品人妻一区二区三区香蕉| 国产精品网红直播| 国产精品原创巨作av| 久久精品国产综合精品| 日本一区二区成人| 久久综合久久色| 精品视频一区三区九区| 色哟哟一一国产精品| 欧美激情18p| 媚黑女一区二区| 欧美亚洲精品日韩| 亚洲国产视频网站| 青青草自拍偷拍| 高清视频欧美一级| 老色鬼精品视频在线观看播放| 蜜桃欧美视频| 亚洲精品免费看| 好男人香蕉影院| 久久久久久久久久久免费| 三级在线观看一区二区| 日韩伦理一区二区三区av在线| 日本一区二区免费在线| 水蜜桃色314在线观看| 88在线观看91蜜桃国自产| 日本少妇在线观看| 国产精品区一区二区三在线播放 | 亚洲激情图片网| 久久99热精品| 国产福利一区二区| 天天摸天天舔天天操| 日韩有码视频在线| 天天操天天射天天舔| 一区二区三区|亚洲午夜| 欧美一卡在线观看| 曰批又黄又爽免费视频| 337p粉嫩大胆噜噜噜鲁| 欧美一级免费视频| www..com久久爱| 国产精品亚洲a| 久久频这里精品99香蕉| 不卡一区二区三区四区| 免费99视频| 777午夜精品视频在线播放| 国内精品国产成人国产三级| 成人在线免费播放视频| 欧美成人精品三级在线观看 | www.五月婷婷| 久久精品无码一区二区三区毛片| 欧美高清视频一区二区三区在线观看 | 日韩精品一区二| 国产一区不卡精品| 欧美性猛交xxxxx少妇| 久久99久久久久久| 97精品国产97久久久久久春色| 日韩视频在线观看一区二区| 久久精品国产精品亚洲红杏| wwwxxx黄色片| 88国产精品欧美一区二区三区| 农村少妇久久久久久久| 久久精品免费网站| 久久久久久久激情视频| 国产片一区二区三区| 久久精品成人av| 色悠悠国产精品| 国产.欧美.日韩| 中文字幕五月天| www..com日韩| 国产精品一区二区久久精品| 色狠狠综合天天综合综合| 蜜臀精品久久久久久蜜臀 | 国产在线不卡视频| 日韩av在线播| 成年人性生活视频| 欧美一区少妇| 98视频在线噜噜噜国产| 3atv一区二区三区| 中文字幕 久热精品 视频在线| 亚洲特级黄色片| 美女久久久久久久久久| 国产传媒久久久| 亚洲在线视频观看| 久久伊人精品天天| 日韩一级精品视频在线观看| 中文字幕久久午夜不卡| 成人毛片视频免费看| 五月婷婷一区二区| 国产又黄又嫩又滑又白| 18视频在线观看娇喘| 国产精品永久在线| 日韩在线视频国产| 日韩三级精品电影久久久| 亚洲欧美激情视频在线观看一区二区三区| 狠狠躁日日躁夜夜躁av| 国产精久久久久久| 国产精品扒开腿做爽爽| 久久久精品麻豆| 亚洲一区二区三区精品在线观看| 国产精品久久国产精品99gif| 色午夜这里只有精品| 7777精品久久久大香线蕉| 亚洲精品国产成人久久av盗摄| 国产精品亚洲第一| 亚欧在线观看视频| 国产伦精品一区二区三区视频网站| 中文字幕在线免费看线人| 日本成人在线免费视频| 日韩精品久久久毛片一区二区| 国产精品中文字幕在线观看| 欧美日韩国产成人在线| 亚洲国产精品久久精品怡红院| 在线亚洲欧美专区二区| 亚洲日本在线观看| 国产婷婷色一区二区三区四区| 久久国产精品露脸对白| 成人午夜免费福利| 91欧美日韩麻豆精品| 亚洲自拍一区在线观看| 国产精品9191| 日本三级视频在线| 日本青青草视频| 久久久精品成人| 正在播放国产对白害羞| 美女脱光内衣内裤| 女同毛片一区二区三区| 人妻丰满熟妇av无码久久洗澡| 国产精品久久久久久亚洲av| 在线免费观看av网| 香蕉视频xxx| av天堂一区二区| 亚洲国产精品自拍视频| 日本黄色网址大全| 四虎国产精品成人免费入口| 手机看片福利视频| 国产精品视频看看| 精品一区免费观看| 最近中文字幕在线免费观看| 综合久久中文字幕| 99热这里只有精品1| 91好色先生tv| 美女尤物久久精品| 国产精品亚洲视频| 中国av一区二区三区| 一区二区三区在线观看欧美| 欧美日韩激情小视频| 欧洲av一区二区嗯嗯嗯啊| 欧美成人精品二区三区99精品| 亚洲精品电影网| 欧美成人免费一级人片100| 午夜精品理论片| 亚洲va欧美va在线观看| 亚洲区一区二区三区| 欧美韩国日本在线| 一本色道综合久久欧美日韩精品| 日本精品人妻无码77777| 亚洲天堂男人网| 蜜桃视频第一区免费观看| 91在线一区二区三区| 亚洲一二三四久久| 欧美精品一区二区三区在线 | 在线视频 91| 国产乱码精品一区二区三区五月婷| 亚洲国产精品av| 91麻豆精品国产91久久久久久久久| 亚洲日韩中文字幕| 国产欧美久久久久久| 亚洲一区二区三区欧美| 1314成人网| 日韩精品一卡二卡| 轻轻草成人在线| 亚洲午夜电影在线| 正在播放亚洲1区| 国产精品乱子乱xxxx| 虎白女粉嫩尤物福利视频| 国产又色又爽又高潮免费| www.成人精品| 亚洲欧洲韩国日本视频| 日韩av综合网站| 亚洲a级在线播放观看| 精品一卡二卡三卡| 久久精品视频8| 精品一区二区三区免费播放| 欧美性猛交丰臀xxxxx网站| 欧美成人激情图片网| 一级特黄录像免费播放全99| 免费看黄色aaaaaa 片| 丰满人妻妇伦又伦精品国产| 亚洲精品日产精品乱码不卡| www.99久久热国产日韩欧美.com| 欧美日韩精品免费在线观看视频| 极品白嫩的小少妇| 欧美自拍第一页| 欧美性生交xxxxx久久久| 88国产精品欧美一区二区三区| 精品无码国模私拍视频| 日韩免费视频一区二区视频在线观看| 波多野结衣在线aⅴ中文字幕不卡| 欧美mv日韩mv国产网站app| 亚洲综合小说区| 中文字幕在线观看的网站| 日日噜噜夜夜狠狠视频欧美人| 色综合久久久久综合体桃花网| 国产精品91免费在线| 国产乱叫456| 后入内射欧美99二区视频| 日本精品一区二区三区四区的功能| 日韩av免费网站| 在线播放国产视频| 国产一区二区三区黄视频 | 视频在线一区二区三区| 久久久久国产精品夜夜夜夜夜| 91性感美女视频| 久久福利视频网| 97超碰成人在线| 免费日本视频一区| 亚洲人a成www在线影院| 美女扒开大腿让男人桶| www.精品视频| 精品国产自在久精品国产| 日韩中文一区| 国产又粗又长视频| 91精品午夜视频| 2021狠狠干| 国产免费黄色片| 欧美一区二区三区色| 久久视频免费在线| 亚洲黄色一级大片| 精品视频在线播放| 国产九九热视频| 国产成人综合在线播放| 欧美精品video| 无码少妇精品一区二区免费动态| 国产欧美日韩另类一区| 亚洲www视频| 欧美a视频在线观看| 欧美一区中文字幕| 成人在线观看a| 国产激情精品久久久第一区二区| 久久久久久久久久国产精品| 年下总裁被打光屁股sp| 国产精品视频第一区| 国产福利久久| av网站在线免费看| 亚洲视频999| 中文成人无字幕乱码精品区| 久久精品在这里| 久久99精品国产99久久| 国产丰满果冻videossex| 亚洲天堂av在线免费观看| 影音先锋人妻啪啪av资源网站| 国产精品久久久久影院亚瑟 | 欧美高清在线播放| www欧美com| 亚洲成人久久久久| 中文字幕免费在线播放| 精品对白一区国产伦| 日本黄色的视频| 伊人色综合久久天天人手人婷| 一区二区三区四区国产| 韩国v欧美v日本v亚洲v| 国产欧美日韩高清| av在线免费在线观看| 久久久亚洲欧洲日产国码aⅴ| 看片网站在线观看| 亚洲男人的天堂在线播放| 天天操天天舔天天射| 91精品视频网| jizz日本免费| 日韩欧美专区在线| www.自拍偷拍| 精品少妇一区二区三区日产乱码| 亚洲午夜久久久久久久久| 一本久久综合亚洲鲁鲁五月天| 天堂网在线免费观看| 欧美日韩精品国产| 奇米影音第四色| 欧美日韩在线一区| 97免费公开视频| 欧美精品九九99久久| 在线免费观看黄色小视频| 亚洲色图15p| 波多野结衣电影免费观看| 国产亚洲短视频| www.xxx麻豆| 一区二区三区欧美日| 天天干天天av| 欧美日韩国产综合一区二区三区| 国产精品无码久久久久久| 日韩精品视频中文在线观看| 国产无遮挡又黄又爽又色| 欧美一区三区三区高中清蜜桃| 国产成人麻豆精品午夜在线| 91精品国产综合久久男男| 激情欧美日韩一区二区| 成人激情视频网| 蜜臀久久99精品久久久| 精品国产_亚洲人成在线| 91小视频免费观看| 日日摸天天爽天天爽视频| 欧美视频一区二区三区在线观看 | 99在线观看视频免费| 精品动漫一区二区三区| 2014亚洲天堂| 色99之美女主播在线视频| 在线播放第一页| 91精品国产综合久久蜜臀| www插插插无码免费视频网站| 欧美视频在线观看 亚洲欧| 久久久免费看片| 欧美一区二区三区四区在线| 韩国精品免费视频| 国产高清精品在线观看| 欧美成人a∨高清免费观看| 在线视频一区二区三区四区| 国产精品久久久久久久久婷婷| 亚洲天堂2014| 91精品人妻一区二区| 97视频在线观看亚洲| 久久综合狠狠综合久久综合88 | 爱豆国产剧免费观看大全剧苏畅 | 亚洲精品国偷自产在线99热| 最近中文字幕免费在线观看| 欧洲亚洲一区| 欧美三级电影一区| 中文字幕乱码视频| 91久久精品美女高潮| 亚洲男人天堂av| 欧美日韩在线观看成人| 亚洲一区二区三区xxx视频| 亚洲免费在线看| 日韩字幕在线观看| 亚洲ai欧洲av| 亚洲成人激情在线| 天堂午夜影视日韩欧美一区二区| 欧美三级一级片| 伊人伊成久久人综合网小说| 久久国内精品视频| 无码人妻精品一区二区三| 国产91精品在线播放| 亚洲视频 欧洲视频| 中文字幕精品三级久久久| 国产奶头好大揉着好爽视频| 日韩精品在线观看视频| 成人免费福利片| 校园春色 亚洲| 亚洲成人动漫在线| 自拍亚洲一区欧美另类| 久久久久久久久99精品| 日本少妇激情视频| 尤物一区二区三区| 亚洲另类图片色| 久久夜色精品国产欧美乱极品| 久久网中文字幕| 欧美视频在线观看视频| 国自产精品手机在线观看视频| 国产亚洲va综合人人澡精品 | 久久国产一级片| 日本欧美黄色片| 国产精品成熟老女人| 欧美一区二区久久久| 成人午夜av影视| 激情视频网站在线观看| 成年人黄色片视频| 国产欧美日韩丝袜精品一区| 欧美午夜一区二区| 国产成人aaa| 亚洲精品一区二三区| 中文字幕在线观看日| 国产精品jizz视频| 日韩电影大片中文字幕| 国产精品国产三级国产专播品爱网 | 男人天堂av在线播放| 日本少妇一级片| 一区视频二区视频| 久久人人爽国产| 这里只有精品电影| 亚洲色图都市小说| 精品一区二区免费视频| 丰满熟女人妻一区二区三|