了
解
紅
點
最
新
動
態(tài)
和
行
業(yè)
資
訊
最近重啟服務器的mysql總是報大量的如下錯誤:
這個錯誤其實是mysql在對DNS做反查,由于反查的接續(xù)速度過慢,大量的查詢處理不及時,線程得不到釋放,造成MySQL“ 假死”。
解決辦法:
linux服務器
修改mysql的配置文件(my.cnf)在[mysqld]下添加:
skip-name-resolve
windows服務器
修改mysql的配置文件(my.ini)在[mysqld]下添加:
修改完成后,重啟mysql服務。
參數用途:
skip-name-resolve #禁止MySQL對外部連接進行DNS解析skip-grant-tables
添加–skip-name-resolve方法:
修改配置文件添加并需要重啟。
參數優(yōu)化:
skip-name-resolve 參數的目的是不再進行反解析(ip不反解成域名),這樣可以加快數據庫的反應時間。
內部有DNS服務器,對各服務器的IP做了反向解析,但未對內網IP做反向解析,所以使用skip-name-resolve以后用內網地址向mysqlslap請求響應快了一半。
添加“–skip-name-resolve mode”參數后發(fā)現錯誤日志有
只需去服務器里邊把用戶root@jimmyli和@jimmyli刪除即可。
提示Warning信息:
一般在優(yōu)化MySQL配置參數時,添加“–skip-name-resolve”,然后在重新啟動MYSQL時檢查啟動日志,發(fā)現有警告信息。如上。
原因分析:
“–skip-name-resolve mode”是禁用dns解析,避免網絡DNS解析服務引發(fā)訪問MYSQL的錯誤,一般應當啟用。
啟用“–skip-name-resolve mode”后,在MySQL的授權表中就不能使用主機名了,只能使用IP ,出現此警告是由于mysql 表中已經存在有 localhost.localdomain 帳號信息。
解決方法:
把Warning的賬號刪除就解決了。
MySQL命令行:
最后,重啟MySQL,再看錯誤信息提示,日志發(fā)現警告已經沒有啦。該方法是mysql啟用skip-name-resolve模式時出現Warning的處理辦法。