婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > MySQL 5.6下table_open_cache參數優化合理配置詳解

MySQL 5.6下table_open_cache參數優化合理配置詳解

熱門標簽:凱立德科技館地圖標注 中科嘉智人工智能電銷機器人 上海智能外呼系統需要多少錢 電銷機器人好品牌門薩維l 西安400電話在哪里辦理 甘孜電話機器人廠家 銀川電銷外呼系統定制 做地圖標注都需要什么工具 哈爾濱crm外呼系統價格

1、簡介

table_cache是一個非常重要的MySQL性能參數,它在5.1.3之后的版本中叫做table_open_cache。table_cache主要用于設置table高速緩存的數量。由于每個客戶端連接都會至少訪問一個表,因此此參數的值與max_connections有關。
例如,對于 1000 個并行運行的連接,應該讓表的緩存至少有 1000 × N ,這里 N 是應用可以執行的查詢的一個聯接中表的最大數量。此外,還需要為臨時表和文件保留一些額外的文件描述符。

2、緩存機制

當某一連接訪問一個表時,MySQL會檢查當前已緩存表的數量。如果該表已經在緩存中打開,則會直接訪問緩存中的表已加快查詢速度;如果該表未被緩存,則會將當前的表添加進緩存并進行查詢。

在執行緩存操作之前,table_open_cache用于限制緩存表的最大數目:如果當前已經緩存的表未達到table_open_cache,則會將新表添加進來;若已經達到此值,MySQL將根據緩存表的最后查詢時間、查詢率等規則釋放之前的緩存。每當MySQL訪問一個表時,如果在表緩沖區中還有空間,該表就被打開并放入其中,這樣可以更快地訪問表內容。

3、如何判斷

通過檢查峰值時間的狀態值Open_tables和Opened_tables,可以決定是否需要增加table_open_cache的值。

如果你發現open_tables等于table_open_cache,并且opened_tables在不斷增長,那么你就需要增加 table_open_cache的值了(上述狀態值可以使用SHOW GLOBAL STATUS LIKE ‘Open%tables'獲得)。

注意,不能盲目地把table_open_cache設置成很大的值。如果設置得太高,可能會造成文件描述符不足,從而造成性能不穩定或者連接失敗。

Open_tables / Opened_tables >= 0.85

Open_tables / table_cache = 0.95

4、建議

如果開始沒有把握的話,把MySQL數據庫放在生產環境中試運行一段時間,然后把參數的值調整得比Opened_tables的數值大一些,并且保證在比較高負載的極端條件下依然比Opened_tables略大。
在mysql默認安裝情況下,table_cache的值在2G內存以下的機器中的值默認時256到 512,如果機器有4G內存,則默認這個值是2048,但這決意味著機器內存越大,這個值應該越大,因為table_cache加大后,使得mysql對 SQL響應的速度更快了,不可避免的會產生更多的死鎖(dead lock),這樣反而使得數據庫整個一套操作慢了下來,嚴重影響性能。所以平時維護中還是要根據庫的實際情況去作出判斷,找到最適合你維護的庫的 table_cache值。

mysql >flush tables; 可以將open_tables 清零

# service mysqld restart 可以講opened_tables 清零

以下是針對mysql 5.6的說明

table_open_cache指定表高速緩存的大小。每當MySQL訪問一個表時,如果在表緩沖區中還有空間,該表就被打開并放入其中,這樣可以更快地訪問表內容。
通過檢查峰值時間的狀態值Open_tables和Opened_tables,可以決定是否需要增加table_open_cache的值。
如果你發現open_tables等于table_open_cache,并且opened_tables在不斷增長,那么你就需要增加table_open_cache的值了(上述狀態值可通過SHOW GLOBAL STATUS LIKE ‘Open%tables'獲得)。
注意,不能盲目地把table_open_cache設置成很大的值,設置太大超過了shell的文件描述符(通過ulimit -n查看),造成文件描述符不足,從而造成性能不穩定或者連接失敗。

測試環境:騰訊云CDB,內存4000M,在控制臺查看到table_open_cache=512,監測table_open_cache設置是否合理,是否需要優化。

show variables like '%table_open_cache%';

show global status like 'Open%tables';

發現open_tables等于table_open_cache,都是512,說明mysql正在將緩存的表釋放以容納新的表,此時可能需要加大table_open_cache的值,4G內存的機器,建議設置為2048

比較適合的值:

Open_tables / Opened_tables >= 0.85
Open_tables / table_open_cache = 0.95

如果對此參數的把握不是很準,有個很保守的設置建議:把MySQL數據庫放在生產環境中試運行一段時間,然后把參數的值調整得比Opened_tables的數值大一些,并且保證在比較高負載的極端條件下依然比Opened_tables略大。

您可能感興趣的文章:
  • MySQL 參數相關概念及查詢更改方法
  • Python連接mysql方法及常用參數
  • pyMySQL SQL語句傳參問題,單個參數或多個參數說明
  • python mysql中in參數化說明
  • Python MySQLdb 執行sql語句時的參數傳遞方式
  • Python MySQL 日期時間格式化作為參數的操作
  • 詳解MySql存儲過程參數的入門使用
  • MySQL修改innodb_data_file_path參數的一些注意事項
  • MYSQL配置參數優化詳解
  • MySQL性能全面優化方法參考,從CPU,文件系統選擇到mysql.cnf參數優化
  • 聊聊MySQL中的參數

標簽:平頂山 安康 那曲 山南 四川 濮陽 安徽 浙江

巨人網絡通訊聲明:本文標題《MySQL 5.6下table_open_cache參數優化合理配置詳解》,本文關鍵詞  MySQL,5.6下,table,open,cache,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《MySQL 5.6下table_open_cache參數優化合理配置詳解》相關的同類信息!
  • 本頁收集關于MySQL 5.6下table_open_cache參數優化合理配置詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 革吉县| 益阳市| 寻乌县| 宁城县| 崇州市| 布拖县| 昔阳县| 佛学| 股票| 弋阳县| 济阳县| 罗定市| 山东| 牟定县| 雷山县| 河西区| 缙云县| 伊金霍洛旗| 乌兰察布市| 明水县| 清流县| 烟台市| 安吉县| 宽城| 岳普湖县| 芜湖市| 麦盖提县| 无极县| 射阳县| 保康县| 红河县| 松江区| 望城县| 奉节县| 城固县| 德昌县| 武山县| 屏东市| 扶绥县| 阳东县| 东海县|