MySQL之Innodb_buffer_pool_size設(shè)置方式
Innodb_buffer_pool_size設(shè)置方式
緩沖池是用于存儲InnoDB表,索引和其他輔助緩沖區(qū)的緩存數(shù)據(jù)的內(nèi)存區(qū)域。緩沖池的大小對于系統(tǒng)性能很重要。更大的緩沖池可以減少磁盤I/O來多次訪問同一表數(shù)據(jù)。在專用數(shù)據(jù)庫服務(wù)器上,可以將緩沖池大小設(shè)置為計算機物理內(nèi)存大小的80%
緩沖池相關(guān)參數(shù)說明
1)系統(tǒng)變量參數(shù)
Innodb_page_size
- InnoDB頁面大?。J為16KB)。頁面中包含許多值,頁面大小使它們可以輕松轉(zhuǎn)換為字節(jié)。
Innodb_buffer_pool_chunk_size
- innodb_buffer_pool_chunk_size 定義InnoDB緩沖池大小調(diào)整操作的塊大小。默認128M。最大值可設(shè)置innodb_buffer_pool_size / innodb_buffer_pool_instances
innodb_buffer_pool_instances
- InnoDB 緩沖池劃分為的區(qū)域數(shù)。
Innodb_buffer_pool_pages_data
- 數(shù)頁在 InnoDB 緩沖池中包含的數(shù)據(jù)。該數(shù)字包括 臟頁和干凈頁。使用壓縮表時,報告的 Innodb_buffer_pool_pages_data 值可能大于 Innodb_buffer_pool_pages_total (錯誤#59550)。
Innodb_buffer_pool_pages_total
- InnoDB 緩沖池 的總大?。ㄒ皂摓閱挝唬J褂脡嚎s表時,報告的 Innodb_buffer_pool_pages_data 值可能大于 Innodb_buffer_pool_pages_total (錯誤#59550)
2)運行狀態(tài)變量
Innodb_buffer_pool_pages_flushed
- 從緩沖池刷新頁面的請求數(shù) 。
Innodb_buffer_pool_read_requests
- 表示從內(nèi)存中讀取邏輯的請求數(shù)。
Innodb_buffer_pool_reads
- InnoDB 不能從緩沖池滿足的邏輯讀取的數(shù)量,必須直接從磁盤讀取。
Innodb_buffer_pool_wait_free
- 通常,對InnoDB緩沖池的寫入是在后臺進行的。當(dāng)InnoDB需要讀取或創(chuàng)建一個頁面而沒有可用的干凈頁面時,InnoDB會首先刷新一些臟頁面并等待該操作完成。此計數(shù)器統(tǒng)計這些等待的實例。如果innodb_ buffer_pool_size設(shè)置正確,這個值應(yīng)該很小。
合理的設(shè)置緩存池相關(guān)參數(shù)
1、innodb_buffer_pool_size 默認設(shè)置系統(tǒng)內(nèi)存百分之80%,后按如下規(guī)則配合實際情況調(diào)整
mysql> show global status like 'Innodb_buffer_pool_pages_data'; +-------------------------------+---------+ | Variable_name | Value | +-------------------------------+---------+ | Innodb_buffer_pool_pages_data | 1894874 | +-------------------------------+---------+ 1 row in set (0.00 sec) mysql> show global status like 'Innodb_buffer_pool_pages_total'; +--------------------------------+---------+ | Variable_name | Value | +--------------------------------+---------+ | Innodb_buffer_pool_pages_total | 1965960 | +--------------------------------+---------+ 1 row in set (0.00 sec) # 計算是否應(yīng)該添加內(nèi)存 使用率 = Innodb_buffer_pool_pages_data/Innodb_buffer_pool_pages_total*100% 當(dāng)結(jié)果 > 95% 則增加 innodb_buffer_pool_size 當(dāng)結(jié)果 < 95% 則減少 innodb_buffer_pool_size, 可適當(dāng)較少,當(dāng)然獨享業(yè)務(wù)機器多了也沒啥問題
2、innodb_buffer_pool_instances 默認設(shè)置為8,最小1,最大64
對于緩沖池在數(shù)千兆字節(jié)范圍內(nèi)的系統(tǒng),通過減少爭用不同線程讀寫緩存頁面的爭用,將緩沖池劃分為多個單獨的實例可以提高并發(fā)性。此功能通常用于緩沖池大小在數(shù)GB范圍內(nèi)的系統(tǒng)。使用innodb_buffer_pool_instances 配置選項配置了多個緩沖池實例 ,您也可以調(diào)整該innodb_buffer_pool_size值。
當(dāng)InnoDB緩沖池很大時,可以通過從內(nèi)存中檢索來滿足許多數(shù)據(jù)請求。您可能會遇到多個線程試圖立即訪問緩沖池的瓶頸。您可以啟用多個緩沖池以最小化此爭用。使用散列函數(shù),將存儲在緩沖池中或從緩沖池中讀取的每個頁面隨機分配給其中一個緩沖池。每個緩沖池管理自己的空閑列表,刷新列表,LRU和連接到緩沖池的所有其他數(shù)據(jù)結(jié)構(gòu),并受其自己的緩沖池互斥量保護。
要啟用多個緩沖池實例,請將innodb_buffer_pool_instances配置選項設(shè)置為 大于1(默認)的值,最大為64(最大)。僅當(dāng)您將innodb_buffer_pool_size大小設(shè)置為1GB或更大時,此選項才生效 。您指定的總大小將分配給所有緩沖池。為了獲得最佳效率,指定的組合 innodb_buffer_pool_instances 和innodb_buffer_pool_size,使得每個緩沖池實例是至少為1GB。
總結(jié):
# cat /etc/my.cnf [mysqld] ...... innodb_buffer_pool_size = 系統(tǒng)內(nèi)存%80 innodb_buffer_pool_instances = 大于8的情況下,每個緩沖池實例至少1GB ......
Reference:
- https://dev.mysql.com/doc/refman/5.7/en/innodb-parameters.html
- https://dev.mysql.com/doc/refman/5.7/en/server-status-variables.htm
- https://dev.mysql.com/doc/refman/5.7/en/innodb-buffer-pool-resize.html
設(shè)置innodb_buffer_pool_size參數(shù)
用于緩存索引和數(shù)據(jù)的內(nèi)存大小,這個當(dāng)然是越多越好, 數(shù)據(jù)讀寫在內(nèi)存中非???, 減少了對磁盤的讀寫。
當(dāng)數(shù)據(jù)提交或滿足檢查點條件后才一次性將內(nèi)存數(shù)據(jù)刷新到磁盤中。
然而內(nèi)存還有操作系統(tǒng)或數(shù)據(jù)庫其他進程使用, 根據(jù)經(jīng)驗,推薦設(shè)置innodb-buffer-pool-size為服務(wù)器總可用內(nèi)存的75%。 若設(shè)置不當(dāng), 內(nèi)存使用可能浪費或者使用過多。
對于繁忙的服務(wù)器, buffer pool 將劃分為多個實例以提高系統(tǒng)并發(fā)性, 減少線程間讀寫緩存的爭用。buffer pool 的大小首先受 innodb_buffer_pool_instances 影響, 當(dāng)然影響較小。
1.Innodb_buffer_pool_pages_data: Innodb buffer pool緩存池中包含數(shù)據(jù)的頁的數(shù)目,包括臟頁。單位是page。
show global status like 'Innodb_buffer_pool_pages_data';
2.Innodb_buffer_pool_pages_total: innodb buffer pool的頁總數(shù)目。單位是page。
show global status like 'Innodb_buffer_pool_pages_total';
3.show global status like 'Innodb_page_size'; 查看@@innodb_buffer_pool_size大小,單位字節(jié)
SELECT @@innodb_buffer_pool_size/1024/1024/1024; #字節(jié)轉(zhuǎn)為G
4.在線調(diào)整InnoDB緩沖池大小,如果不設(shè)置,默認為128M
set global innodb_buffer_pool_size = 4227858432; ##單位字節(jié)
計算Innodb_buffer_pool_pages_data/Innodb_buffer_pool_pages_total*100%
- 當(dāng)結(jié)果 > 95% 則增加 innodb_buffer_pool_size, 建議使用物理內(nèi)存的 75%
- 當(dāng)結(jié)果 < 95% 則減少 innodb_buffer_pool_size, 建議設(shè)置大小為: Innodb_buffer_pool_pages_data * Innodb_page_size * 1.05 / (1024*1024*1024)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
MySQL視圖的概念、創(chuàng)建、查看、刪除和修改詳解
視圖是指計算機數(shù)據(jù)庫中的視圖,是一個虛擬表,其內(nèi)容由查詢定義,下面這篇文章主要給大家介紹了關(guān)于MySQL視圖的概念、創(chuàng)建、查看、刪除和修改的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-08-08Windows系統(tǒng)下MySQL無法啟動的萬能解決方法
這篇文章主要給大家介紹了關(guān)于Windows系統(tǒng)下MySQL無法啟動的萬能解決方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12CentOS 7 下使用yum安裝MySQL5.7.20 最簡單方法
這篇文章主要介紹了CentOS 7 下使用yum安裝MySQL5.7.20 最簡單 方法,需要的朋友可以參考下2018-11-11