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
  • Timer是什麼 Timer 是一種用於創建定期粒度行為的機制。 與標準的 .NET System.Threading.Timer 類相似,Orleans 的 Timer 允許在一段時間後執行特定的操作,或者在特定的時間間隔內重覆執行操作。 它在分散式系統中具有重要作用,特別是在處理需要周期性執行的 ...
  • 前言 相信很多做WPF開發的小伙伴都遇到過表格類的需求,雖然現有的Grid控制項也能實現,但是使用起來的體驗感並不好,比如要實現一個Excel中的表格效果,估計你能想到的第一個方法就是套Border控制項,用這種方法你需要控制每個Border的邊框,並且在一堆Bordr中找到Grid.Row,Grid. ...
  • .NET C#程式啟動閃退,目錄導致的問題 這是第2次踩這個坑了,很小的編程細節,容易忽略,所以寫個博客,分享給大家。 1.第一次坑:是windows 系統把程式運行成服務,找不到配置文件,原因是以服務運行它的工作目錄是在C:\Windows\System32 2.本次坑:WPF桌面程式通過註冊表設 ...
  • 在分散式系統中,數據的持久化是至關重要的一環。 Orleans 7 引入了強大的持久化功能,使得在分散式環境下管理數據變得更加輕鬆和可靠。 本文將介紹什麼是 Orleans 7 的持久化,如何設置它以及相應的代碼示例。 什麼是 Orleans 7 的持久化? Orleans 7 的持久化是指將 Or ...
  • 前言 .NET Feature Management 是一個用於管理應用程式功能的庫,它可以幫助開發人員在應用程式中輕鬆地添加、移除和管理功能。使用 Feature Management,開發人員可以根據不同用戶、環境或其他條件來動態地控制應用程式中的功能。這使得開發人員可以更靈活地管理應用程式的功 ...
  • 在 WPF 應用程式中,拖放操作是實現用戶交互的重要組成部分。通過拖放操作,用戶可以輕鬆地將數據從一個位置移動到另一個位置,或者將控制項從一個容器移動到另一個容器。然而,WPF 中預設的拖放操作可能並不是那麼好用。為瞭解決這個問題,我們可以自定義一個 Panel 來實現更簡單的拖拽操作。 自定義 Pa ...
  • 在實際使用中,由於涉及到不同編程語言之間互相調用,導致C++ 中的OpenCV與C#中的OpenCvSharp 圖像數據在不同編程語言之間難以有效傳遞。在本文中我們將結合OpenCvSharp源碼實現原理,探究兩種數據之間的通信方式。 ...
  • 一、前言 這是一篇搭建許可權管理系統的系列文章。 隨著網路的發展,信息安全對應任何企業來說都越發的重要,而本系列文章將和大家一起一步一步搭建一個全新的許可權管理系統。 說明:由於搭建一個全新的項目過於繁瑣,所有作者將挑選核心代碼和核心思路進行分享。 二、技術選擇 三、開始設計 1、自主搭建vue前端和. ...
  • Csharper中的表達式樹 這節課來瞭解一下表示式樹是什麼? 在C#中,表達式樹是一種數據結構,它可以表示一些代碼塊,如Lambda表達式或查詢表達式。表達式樹使你能夠查看和操作數據,就像你可以查看和操作代碼一樣。它們通常用於創建動態查詢和解析表達式。 一、認識表達式樹 為什麼要這樣說?它和委托有 ...
  • 在使用Django等框架來操作MySQL時,實際上底層還是通過Python來操作的,首先需要安裝一個驅動程式,在Python3中,驅動程式有多種選擇,比如有pymysql以及mysqlclient等。使用pip命令安裝mysqlclient失敗應如何解決? 安裝的python版本說明 機器同時安裝了 ...