前言
最近發(fā)現(xiàn)CentOS 7下升級(jí)MySQL5.7.23的一個(gè)坑,以前面升級(jí)到MySQL 5.7.23的一個(gè)集群為例
在我們環(huán)境下打開文件描述符個(gè)數(shù)的參數(shù)open_files_limit在MySQL 5.6.21下都統(tǒng)一配置為65535,而CentOS 7系統(tǒng)下安裝MySQL5.7.23的open_files_limit參數(shù)的默認(rèn)值為5000
否則像分區(qū)表數(shù)量較多的集群,打開的文件個(gè)數(shù)過大時(shí),數(shù)據(jù)庫(kù)就會(huì)報(bào)錯(cuò)。
原因如下:
1、CentOS 7安裝MySQL5.7.23,服務(wù)管理發(fā)生了變化,從sysvinit(service mysql start)變化為systemd(systemctl start mysqld.service)
2、CentOS 7下Limit的配置由下面配置文件來(lái)決定
全局設(shè)置:/etc/systemd/system.conf(如DefaultLimitNOFILE=65535)
服務(wù)設(shè)置:[Service]默認(rèn)值為5000,應(yīng)該將LimitNOFILE修改為65535
【測(cè)試】
1、全局配置文件/etc/systemd/system.conf
2、service配置文件/usr/lib/systemd/system/mysqld.service
3、mysql配置文件/etc/my.cnf
【結(jié)論】
1、當(dāng)以systemd管理mysql服務(wù)時(shí),在下面3個(gè)配置文件中同時(shí)制定open_files_limit參數(shù)時(shí),最終會(huì)以service配置文件為準(zhǔn)
2、當(dāng)service相關(guān)配置值注釋掉時(shí),會(huì)以全局配置文件為準(zhǔn)
【解決方案】
1、單臺(tái)修復(fù)方法,按下面步驟
#修改配置
vim /usr/lib/systemd/system/mysqld.service
#重載
systemctl daemon-reload
#重啟服務(wù)生效
systemctl restart mysqld@replica01.service
2、安裝包修復(fù)方法,修改下面兩個(gè)源文件,將5000增加到65535,重新打包發(fā)布,這樣新版本默認(rèn)會(huì)保持與MySQL5.6.21相同的配置
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
您可能感興趣的文章:- MySQL 5.7.30 安裝與升級(jí)問題詳細(xì)教程
- Docker版的MySQL5.7升級(jí)到MySQL8.0.13,數(shù)據(jù)遷移
- phpstudy2018升級(jí)MySQL5.5為5.7教程(圖文)
- 升級(jí)到MySQL5.7后開發(fā)不得不注意的一些坑
- 實(shí)戰(zhàn)MySQL升級(jí)的最佳方法
- phpStudy中升級(jí)MySQL版本到5.7.17的方法步驟
- Win下Mysql5.6升級(jí)到5.7的方法
- Windows(x86,64bit)升級(jí)MySQL 5.7.17免安裝版的詳細(xì)教程
- MySQL數(shù)據(jù)庫(kù)升級(jí)的一些"陷阱"