線上調整InnoDB Buffer Pool Size

来源:https://www.cnblogs.com/Y3boy001/archive/2019/03/20/10564760.html
-Advertisement-
Play Games

InnoDB Buffer Pool主要是用來緩存數據表和索引數據的記憶體區域,它的預設值為134217728位元組(128MB)。最大值取決於CPU架構;32位系統上的最大值為4294967295(232-1),64位系統上的最大值為18446744073709551615(264-1)。在32位系統 ...


 

       InnoDB Buffer Pool主要是用來緩存數據表和索引數據的記憶體區域,它的預設值為134217728位元組(128MB)。最大值取決於CPU架構;32位系統上的最大值為4294967295(232-1),64位系統上的最大值為18446744073709551615(264-1)。在32位系統上,CPU體繫結構和操作系統的實際最大大小可能低於標準的最大大小。當緩衝池的大小大於1GB時,將innodb_buffer_pool_instances設置為大於1的值可以提高繁忙伺服器上的可伸縮性。

       InnoDB緩衝池更大的場景下,多次訪問相同的數據表數據所需要的磁碟I/O就更少。在專用資料庫伺服器上,可以將緩衝池大小設置為機器物理記憶體大小的80%。在配置緩衝池大小時要註意以下潛在問題,並準備在必要時縮減緩衝池的大小。

◾對物理記憶體的競爭會導致操作系統分頁。
◾InnoDB儲備增加記憶體緩衝區和控制結構,以便總分配空間約10%大於指定的緩衝池大小。
◾地址空間的緩衝池必須是連續的,可以是一個問題在Windows系統負載在特定地址的dll。
◾緩衝池初始化時間大約是與它的大小成正比。對於具有大型緩衝池的實例,初始化時間可能很重要。要縮短初始化周期,可以在伺服器關閉時保存緩衝池狀態,併在伺服器啟動時恢復它。

       當您增加或減少緩衝池大小時,操作將以塊的形式執行。塊大小由innodb_buffer_pool_chunk_size配置選項定義,預設值為128mb。

       緩衝池大小必須始終等於或多個innodb_buffer_pool_chunk_size * innodb_buffer_pool_instances。如果將緩衝池大小更改為不等於或多個innodb_buffer_pool_chunk_size * innodb_buffer_pool_instances的值,緩衝池大小將自動調整為等於或多個innodb_buffer_pool_size * innodb_buffer_pool_instances的值。

       innodb_buffer_pool_size可以動態設置,這允許您在不重啟伺服器的情況下調整緩衝池的大小。Innodb_buffer_pool_resize_status變數報告線上緩衝池調整大小操作的狀態。

◾通過InnoDB api執行的活動事務和操作應該在調整緩衝池大小之前完成。
◾當啟動調整大小操作時,該操作直到所有活動事務完成後才開始。調整大小操作進行後,需要訪問緩衝池的新事務和操作必須等待調整大小操作完成。該規則的一個例外是,當緩衝池被碎片化併在緩衝池大小減小時回收頁面時,允許對緩衝池進行併發訪問。允許併發訪問的一個缺點是,在提取頁面時,可能會導致可用頁面暫時短缺。
◾請註意如果在緩衝池調整大小操作開始後啟動嵌套事務,則可能會失敗。
◾線上調整Innodb緩衝池大小請在業務低峰期進行。

      接下來,我們來線上調整InnoDB Buffer Pool

      查看當前系統MySQL的InnoDB Buffer Pool Size為128M

mysql> show global variables like '%innodb_buffer%';
+-------------------------------------+----------------+
| Variable_name                       | Value          |
+-------------------------------------+----------------+
| innodb_buffer_pool_chunk_size       | 134217728      |
| innodb_buffer_pool_dump_at_shutdown | ON             |
| innodb_buffer_pool_dump_now         | OFF            |
| innodb_buffer_pool_dump_pct         | 25             |
| innodb_buffer_pool_filename         | ib_buffer_pool |
| innodb_buffer_pool_instances        | 1              |
| innodb_buffer_pool_load_abort       | OFF            |
| innodb_buffer_pool_load_at_startup  | ON             |
| innodb_buffer_pool_load_now         | OFF            |
| innodb_buffer_pool_size             | 134217728      |
+-------------------------------------+----------------+
10 rows in set (0.00 sec)
View Code

       通過設定全局系統變數innodb_buffer_pool_size來線上調整InnoDB Buffer Pool為1GB

mysql> set global innodb_buffer_pool_size=1073741824;
Query OK, 0 rows affected (0.04 sec)

mysql> show global variables like '%innodb_buffer%';
+-------------------------------------+----------------+
| Variable_name                       | Value          |
+-------------------------------------+----------------+
| innodb_buffer_pool_chunk_size       | 134217728      |
| innodb_buffer_pool_dump_at_shutdown | ON             |
| innodb_buffer_pool_dump_now         | OFF            |
| innodb_buffer_pool_dump_pct         | 25             |
| innodb_buffer_pool_filename         | ib_buffer_pool |
| innodb_buffer_pool_instances        | 1              |
| innodb_buffer_pool_load_abort       | OFF            |
| innodb_buffer_pool_load_at_startup  | ON             |
| innodb_buffer_pool_load_now         | OFF            |
| innodb_buffer_pool_size             | 1073741824     |
+-------------------------------------+----------------+
10 rows in set (0.00 sec)

mysql> select 1073741824/1024/1024/1024
    -> ;
+---------------------------+
| 1073741824/1024/1024/1024 |
+---------------------------+
|            1.000000000000 |
+---------------------------+
1 row in set (0.00 sec)
View Code

       當我們線上調整InnoDB Buffer Pool Size的時候,我們可以通過狀態變數Innodb_buffer_pool_resize_status來監控Resize的進度

mysql> show global status like '%Innodb_buffer_pool_resize_status%';
+----------------------------------+----------------------------------------------------+
| Variable_name                    | Value                                              |
+----------------------------------+----------------------------------------------------+
| Innodb_buffer_pool_resize_status | Completed resizing buffer pool at 190320 11:30:07. |
+----------------------------------+----------------------------------------------------+
1 row in set (0.00 sec)
View Code

        當然我們也可以通過查看MySQL標準錯誤輸出文件error.log觀察Resize的相關輸出信息

#increasing the size of the buffer pool ouput
2019-03-20T03:30:06.852669Z 0 [Note] InnoDB: Resizing buffer pool from 134217728 to 1073741824 (unit=134217728).
2019-03-20T03:30:06.861219Z 1930980 [Note] InnoDB: Requested to resize buffer pool. (new size: 1073741824 bytes)
2019-03-20T03:30:06.872100Z 0 [Note] InnoDB: Disabling adaptive hash index.
2019-03-20T03:30:06.873145Z 0 [Note] InnoDB: disabled adaptive hash index.
2019-03-20T03:30:06.873209Z 0 [Note] InnoDB: Withdrawing blocks to be shrunken.
2019-03-20T03:30:06.873246Z 0 [Note] InnoDB: Latching whole of buffer pool.
2019-03-20T03:30:06.873283Z 0 [Note] InnoDB: buffer pool 0 : resizing with chunks 1 to 8.
2019-03-20T03:30:07.007923Z 0 [Note] InnoDB: buffer pool 0 : 7 chunks (57344 blocks) were added.
2019-03-20T03:30:07.008025Z 0 [Note] InnoDB: Resizing hash tables.
2019-03-20T03:30:07.016691Z 0 [Note] InnoDB: buffer pool 0 : hash tables were resized.
2019-03-20T03:30:07.016973Z 0 [Note] InnoDB: Resizing also other hash tables.
2019-03-20T03:30:07.053148Z 0 [Note] InnoDB: Resized hash tables at lock_sys, adaptive hash index, dictionary.
2019-03-20T03:30:07.053287Z 0 [Note] InnoDB: Completed to resize buffer pool from 134217728 to 1073741824.
2019-03-20T03:30:07.053317Z 0 [Note] InnoDB: Re-enabled adaptive hash index.
2019-03-20T03:30:07.053362Z 0 [Note] InnoDB: Completed resizing buffer pool at 190320 11:30:07.
線上緩衝池調整內部大小
調整大小操作由後臺線程執行。當增加緩衝池大小時,調整操作:
•以塊的形式添加頁面(塊大小由innodb_buffer_pool_chunk_size定義)
•覆蓋哈希表、列表和指針來使用記憶體中的新地址
•在空閑列表中添加新頁面
當這些操作正在進行時,其他線程將被阻止訪問緩衝池。
當減小緩衝池大小時,調整操作:
•對緩衝池進行碎片整理並回收(釋放)頁面
•以塊的形式刪除頁面(塊大小由innodb_buffer_pool_chunk_size定義)
•轉換哈希表、列表和指針,以在記憶體中使用新地址
在這些操作中,只有對緩衝池進行碎片整理和回收頁面才能允許其他線程併發地訪問緩衝池。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.linux 查看安裝了什麼擴展 2.查看文件位置 3. 查看php.ini位置 ...
  • 轉載自:http://www.cnblogs.com/wainiwann/p/3942203.html 在開發的一個基於rtmp聊天的程式時發現了一個很奇怪的現象。 在windows下當我們執行 closesocket的操作之後,阻塞的 recv會立即返回 1 。 而在linux下當我們執行clos ...
  • 作者:不悔 原文鏈接: "https://www.opsbj.com/2019/03/20/mysql install/" 常見的 MySQL 安裝方式有如下三種: 1. RPM 包方式:這種方式安裝適合對資料庫要求不太高的場合,安裝速度快; 2. 通用二進位包方式:安裝速度相較於源碼方式快,可以自 ...
  • 大數據是什麼? 首先提一個問題:“大數據"是一項專門的技術嗎?有的人可能會以為大數據是一項專門的技術,其實不是。“大數據"這三個字只是一門市場語言(Marketing Language),其背後是硬體、資料庫、操作系統、I-ladoop等一系列技術的綜合應用。 大數據導論 <!--[if gte v ...
  • 概述 本lab將用go完成一個MapReduce框架,完成後將大大加深對MapReduce的理解。 Part I: Map/Reduce input and output 這部分需要我們實現common_map.go中的doMap()和common_reduce.go中的doReduce()兩個函數 ...
  • 1.rpm安裝mysql5.7 2.啟動mysql,更改root密碼 3.主從配置 查看master狀態 在slave上設置master 查看slave狀態 4.配置3個節點ssh互信 最後測試三個節點之間可以無密碼登錄 5.安裝MHA 安裝依賴包 在3個節點安裝MHA的node 在slave/MH ...
  • 關於Redis和Memcache在應用中,都可以實現緩存的功能,但是,具體使用情況需要根據具體業務場景,尤其是對緩存數據有特性要求時,需要選擇對應的緩存機制。 共同點: 都是基於記憶體的資料庫,可用作緩存機制 區別: 1、關於數據類型:Memcache只支持簡單的Key/Value數據結構;Redis ...
  • [20190320]測試相同語句遇到導致cursor pin S的情況.txt--//前面測試鏈接:http://blog.itpub.net/267265/viewspace-2636342/--//各個會話執行語句相同的,很容易出現cursor: pin S等待事件.看看如果各個會話執行的語句不 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...