亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL專用服務(wù)器自動配置參數(shù)的實(shí)現(xiàn)

 更新時間:2024年09月03日 10:13:29   作者:V1ncent Chen  
本文主要介紹了MySQL專用服務(wù)器自動配置參數(shù)的實(shí)現(xiàn),MySQL8.0推出了專用數(shù)據(jù)庫服務(wù)器自動配置參數(shù),通過打開innodb_dedicated_server,下面就來詳細(xì)的介紹一下,感興趣的可以了解一下

MySQL8.0推出了專用數(shù)據(jù)庫服務(wù)器自動配置參數(shù),通過打開innodb_dedicated_server,數(shù)據(jù)庫會自己完成緩沖池大小,重做日志,磁盤刷新方式等一系列配置,且配置還會根據(jù)服務(wù)器的配置升級自行調(diào)整。

一、打開參數(shù)

需要注意的是innodb_dedicated_server只能在數(shù)據(jù)庫專用服務(wù)器上打開,因?yàn)榇蜷_此參數(shù)MySQL會盡可能多的使用服務(wù)器資源。如果服務(wù)器上還運(yùn)行了其他應(yīng)用,則不推薦打開此參數(shù)。

innodb_dedicated_server是一個靜態(tài)參數(shù),我們需要通過配置文件來開打此特性,在my.cnf的[mysqld]或[server]模塊下添加下面參數(shù)后重啟mysqld,重啟后確認(rèn)參數(shù)是否打開:

innodb_dedicated_server = on;

在這里插入圖片描述

此參數(shù)打開后,每次重啟MySQL都會評估服務(wù)器配置,服務(wù)器升級后,相關(guān)配置也會相應(yīng)升級。

二、參數(shù)自動配置內(nèi)容

打開innodb_dedicated_server后,MySQL會自動配置下列參數(shù):

  • innodb_buffer_pool_size
  • innodb_log_file_size, innodb_log_files_in_group(MySQL8.0.30后廢棄)
  • innodb_redo_log_capacity(替代上面2個參數(shù))
  • innodb_flush_method

2.1 innodb_buffer_pool_size

innodb_buffer_pool_size是緩沖池的大小,這是MySQL最關(guān)鍵的參數(shù)之一,buffer pool緩存了數(shù)據(jù),索引等對象,足夠的大的緩沖池意味著可以緩存更多的內(nèi)容,避免數(shù)據(jù)頻繁被刷回磁盤。在打開innodb_dedicated_server參數(shù)的情況下,MySQL按照下面的規(guī)則計(jì)算緩沖池大小:

服務(wù)器內(nèi)存緩沖池大小
小于1G128M(默認(rèn)值)
1G到4G服務(wù)器內(nèi)存 * 50%
4G以上服務(wù)器內(nèi)存 * 75%

注意:如果參數(shù)innodb_buffer_pool_size和innodb_dedicated_server同時配置,那么MySQL會按照innodb_buffer_pool_size配置buffer pool的大小,即buffer pool自動配置會失效。這里我的服務(wù)器內(nèi)存是4G,按照自動配置應(yīng)該是4G*0.5=2G,但啟動后buffer pool依然是1G:

在這里插入圖片描述

在這里插入圖片描述

將參數(shù)innodb_buffer_pool_size注銷后,重啟MySQL,可以看到buffer pool的大小變成了2G,自動配置成功:

在這里插入圖片描述

在這里插入圖片描述

2.2 innodb_log_file_size 和 innodb_log_files_in_group

innodb_log_file_size控制的是innodb重做日志的大小,它會根據(jù)自動配置規(guī)則計(jì)算出的緩沖池大小進(jìn)行配置(不是顯式指定的innodb_buffer_pool_size值),配置規(guī)則如下(MySQL8.0.30后廢棄):

緩沖池大小重做日志大小
小于8G512M
8G到128G1G
大于128G2G

innodb_log_files_in_group控制innodb重做日志的數(shù)量,它也是根據(jù)自動配置規(guī)則計(jì)算出的緩沖池的大小進(jìn)行配置,采用round(緩沖池的GB數(shù))計(jì)算,最小值為2,配置規(guī)則如下(MySQL8.0.30后廢棄):

緩沖池大小重做日志數(shù)量(緩沖池大小單位為G)
小于8Ground(緩沖池大小)
8G到128Ground(緩沖池大小*0.75)
大于128G64

2.3 innodb_redo_log_capacity

inodb_redo_log_capacity配置重做日志文件可以占用的磁盤大小,這個參數(shù)是innodb_log_file_size和innodb_log_files_in_group的替代,默認(rèn)的配置規(guī)則是:

  • 當(dāng)inodb_redo_log_capacity顯式配置時,參數(shù)innodb_log_file_size和innodb_log_files_in_group將被忽略。
  • 當(dāng)inodb_redo_log_capacity未顯式配置時,將使用innodb_log_file_size*innodb_log_files_in_group的值作為其配置。

當(dāng)打開innodb_dedicated_server后,此參數(shù)計(jì)算規(guī)則在某些情況下會同時受到"服務(wù)器內(nèi)存"和"緩沖池是否顯式配置(innodb_buffer_pool_size)"2個因素影響,計(jì)算規(guī)則如下:

服務(wù)器內(nèi)存緩沖池innodb_redo_log_capacity(表內(nèi)服務(wù)器內(nèi)存大小單位為G)
小于2G無影響100M
2G到4G未顯式配置1G
2G到4G顯式配置round(0.5*服務(wù)器內(nèi)存大小)*0.5G
4G到10.66G無影響round(0.75*服務(wù)器內(nèi)存大小)*0.5G
10.66G170.66G無影響round(0.5625*服務(wù)器內(nèi)存大小)*1G
170.66G以上無影響128G

2.4 innodb_flush_method

innodb_fulsh_method控制的是MySQL的數(shù)據(jù)文件和日志文件寫磁盤的方式,默認(rèn)值為fsync,即每次寫磁盤實(shí)際寫入的是操作系統(tǒng)緩存,后續(xù)需要操作系統(tǒng)調(diào)用fsync才會真正將數(shù)據(jù)寫到磁盤上(innodb_flush_log_at_trx_commit=1這個經(jīng)常推薦的安全設(shè)置就是事務(wù)提交時將日志寫入操作系統(tǒng)緩存后立刻調(diào)用sync寫入磁盤,防止系統(tǒng)崩潰導(dǎo)致事務(wù)丟失),而MySQL的buffer pool和redo log buffer已經(jīng)實(shí)現(xiàn)了緩存,沒必要經(jīng)過操作系統(tǒng)再緩存一次(反正都在內(nèi)存中,斷電都會丟失,寫來寫去沒有意義)。

而打開innodb_dedicated_server后,innodb_flush_method會被嘗試設(shè)置為o_direct_no_fsync,數(shù)據(jù)文件和日志文件會忽略操作系統(tǒng)緩存直接寫磁盤文件并忽略fsync調(diào)用。如果設(shè)置不成功則會保持默認(rèn)值。

show variables like 'innodb_flush_method';

在這里插入圖片描述

innodb_dedicated_server可以自動完成數(shù)據(jù)庫的部分參數(shù)配置,并且可以做到隨服務(wù)器升級自動升級。簡化了DBA的調(diào)試工作,在專有服務(wù)器上,還是推薦打開此參數(shù)(MySQL在參數(shù)的自適應(yīng)調(diào)整上越來越像Oracle了)。

到此這篇關(guān)于MySQL專用服務(wù)器自動配置參數(shù)的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)MySQL服務(wù)器自動配置參數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Linux系統(tǒng)下mysql的徹底卸載步驟

    Linux系統(tǒng)下mysql的徹底卸載步驟

    MySQL是一款常用的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),但是在使用過程中,有時候需要卸載MySQL,有些用戶在卸載MySQL時會遇到一些問題,這篇文章主要給大家介紹了關(guān)于Linux系統(tǒng)下mysql的徹底卸載的相關(guān)資料,需要的朋友可以參考下
    2024-07-07
  • 麒麟系統(tǒng)上安裝?MySQL?8.0.24的詳細(xì)步驟(避坑指南)

    麒麟系統(tǒng)上安裝?MySQL?8.0.24的詳細(xì)步驟(避坑指南)

    這篇文章主要介紹了麒麟系統(tǒng)上安裝MySQL8.0.24的詳細(xì)步驟,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-08-08
  • 使用MySQL的LAST_INSERT_ID來確定各分表的唯一ID值

    使用MySQL的LAST_INSERT_ID來確定各分表的唯一ID值

    MySQL數(shù)據(jù)表結(jié)構(gòu)中,一般情況下,都會定義一個具有‘AUTO_INCREMENT’擴(kuò)展屬性的‘ID’字段,以確保數(shù)據(jù)表的每一條記錄都可以用這個ID唯一確定
    2011-08-08
  • MySQL是如何保證數(shù)據(jù)的完整性

    MySQL是如何保證數(shù)據(jù)的完整性

    這篇文章主要介紹了MySQL是如何保證數(shù)據(jù)的完整性,幫助大家更好的理解和學(xué)習(xí)MySQL,感興趣的朋友可以了解下
    2020-08-08
  • 最新評論