MySQL open_tables和opened_tables

来源:https://www.cnblogs.com/leohahah/archive/2018/04/23/8921107.html
-Advertisement-
Play Games

官網解釋參見:https://dev.mysql.com/doc/refman/5.7/en/table-cache.html 其他可供參考的文章有: 關於表限制參數的使用:https://dba.stackexchange.com/questions/5232/mysql-table-cache- ...


官網解釋參見:https://dev.mysql.com/doc/refman/5.7/en/table-cache.html 其他可供參考的文章有: 關於表限制參數的使用:https://dba.stackexchange.com/questions/5232/mysql-table-cache-and-opened-tables 關於SHOW OPEN TABLES命令的使用:https://www.percona.com/blog/2008/12/14/show-open-tables-what-is-in-your-table-cache/   一、本文涉及到的系統參數有3個:
  • table_open_cache
這個參數表示針對所有threads的table cache總和,5.6.7之前預設是400,5.6.8之後是2000。
這是個server層的參數,mysql不支持並行查詢,mysql的會話也沒有PGA的概念,一個thread引用myisam表時需要在server層上創建一個table對象(索引也需要創建一個但是是共用的,self join會創建2個,分區表每個分區按單表對待),如果同時多個會話引用一個表也會創建多個表對象,雖然會加大記憶體使用量,但是卻極大的減少了內部表鎖的爭用。 這個值的數目建議設置為max_connections*你的表數目,當然你可能也需要為一些臨時表等對象預留,但是這個數目已經足夠大啦。 那麼mysql什麼時候釋放這些表對象呢?
  1. 當緩衝已滿,而連接想要打開一個不在緩衝中的表時。
  2. 當緩衝數目已經超過了table_open_cache設置的值,mysql開始使用LRU演算法釋放表對象。
  3. 當你用flush tables;語句時。
  • open_files_limit
這個參數表示mysqld可用的最大文件描述符數目,如果你遇到“Too many open files”的錯誤,應當考慮加大它。這個參數的預設值是0表示無限制,但其實他的值是與操作系統相關的,在Unix系統下這個值的數目不能大於ulimit -n。 這個參數應當大於等於table_open_cache。
  • innodb_open_files
這個參數只對InnoDB存儲引擎有效,它指定了mysql可以同時打開的最大.ibd文件的數目。這個參數即不影響table_open_cache也不受open_files_limit影響,是獨立的只對InnoDB有效的。所以在預設為InnoDB存儲引擎時可以不考慮open_files_limit只去設innodb_open_files。   這3個參數的關係可以總結如下,為保證性能,你應當設置為如下值: max_connections*你的表數目 = table_open_cache <=open_files_limit< ulimit -n innodb_open_files<ulimit -n   二、本文涉及到的status參數有2個:open_tables和opened_tables 其中open_tables表示當前打開的table總和,即所有connection打開的table總數。 opened_tables表示打開過的表的數量總和,只有show global status才能看到它的值。這是個計數器,Opened_tables/Uptime的值過大說明table_open_cache過小,導致一些table對象(即下文說的table對象)經常會刷出server層,需要的時候再創建,最終導致此計數過大。     三、相關原理圖 參考:http://www.cnblogs.com/xpchild/p/3780625.html的源碼解析。 如下圖,有個表叫xpchild(小屁孩666)庫中的pp表: table: MySQL會為一個join查詢中涉及的每個表建一個TABLE對象,引用innodb表時還會創建innodb層的handler,server層的table指向此handler,此handler指向innodb層的共用表字典Dict_table_t。 table_share: MySQL為每一張表建立一個table_share對象,與frm文件對應。 handler: 在Innodb層對應於每個TABLE對象,innodb引擎創建一個handler(windows叫句柄,linux叫file descriptor)。 dict_table_t: innodb為每一個innodb表load一個數據字典對象,這些對象的集合就是innodb中的data dictionary。
  flush tables:close了server層創建的所有的table_share和table,當然innodb層中指向table對象的handler也就無用了。
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 寫作背景: 項目是基於java、weblogic及timer的處理模式,每次服務部署之後timer的整體狀態是一個盲區,因為100多個進程,是否有啟動遺漏或者啟動重覆的,想做到一目瞭然是件困難的事情。所以我考慮用shell腳本的文件查找與匹配方法來解決這個問題,簡單記錄下,僅供參考。 程式說明: 1 ...
  • 非常強大的文本操縱工具,sed,awk,grep 這個三個命令 都是操作文本文件的unix系統有幾個非常命令的特點:1. 對於內核而言,unix文件都是位元組序列。io設備也是文件。2. 至於文件的含義交由應用程式來解釋。其中文本文件非常重要,因為unix提供 很多了實用程式(utility),這些程 ...
  • 在VMware workstation12上新建虛擬機,發現無法連接網路。然後查了一些資料,知道了怎樣配置網路,記錄一下。 1、首先用ifconfig命令查看虛擬機的IP地址及網關信息 觀察顯示內容,查看虛擬機的網關名稱ens33是否有IP地址 2、如果沒有,使用vi /etc/sysconfig/ ...
  • 設計好處 良好的資料庫邏輯設計和物理設計師資料庫獲得高性能的基礎 範式化設計和反範式化設計(減少冗餘、減少異常、讓數據組織的更加和諧) 優化目的 減少數據冗餘(儘量) 儘量避免數據維護中出現更新、插入和刪除等異常 插入:如果表中的某個實體隨著另一個實體而存在 更新:如果更改表中的某個實體的單獨屬性時 ...
  • 使用變數並不能完全滿足SQL語句嚮應用程式輸出數據的要求的,一組變數只能存放一條記錄,而查詢結果的記錄數是不確定的,所以才有了游標的概念。 基本原理 在PL/SQL中執行select、insert、update和delete語句時,oracle會在記憶體中分配上下文區,即一個緩衝區。而游標就是指向該區 ...
  • 轉載自:http://www.cnblogs.com/knowledgesea/p/3699851.html。 什麼是游標 結果集,結果集就是select查詢之後返回的所有行數據的集合。 游標則是處理結果集的一種機制吧,它可以定位到結果集中的某一行,多數據進行讀寫,也可以移動游標定位到你所需要的行中 ...
  • set 是無序集合,最大可以包含(2 的 32 次方-1)個元素。set 的是通過 hash table 實現的, 所以添加,刪除,查找的複雜度都是 O(1) sadd key member 添加一個 string 元素到 key 對應 set 集合中,成功返回 1,如果元素以及 在集合中則返回 0 ...
  • 目前Oracle資料庫的管理,數據查詢等都需要安裝Oracle軟體或安裝Oracle Client等,遠程訪問都需要先登錄到伺服器等繁瑣的操作。如果是開發團隊,那麼每個開發,測試,管理人員都要經歷這個麻煩的過程。 使用Treesoft資料庫管理系統,基於web方式管理ORACLE,只需安裝一次,大家 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...