国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

mysql could not be resolved: Name or service not known

2024-07-24 13:07:48
字體:
供稿:網(wǎng)友
今天查看mysql日志的時(shí)候發(fā)現(xiàn)[Warning] IP address '10.0.0.220' could not be resolved: Name or service not known,原來是mysql DNS反解:skip-name-resolve的原因,屏蔽一下就可以了
 

問題: mysql DNS反解:skip-name-resolve

錯(cuò)誤日志有類似警告:


1.120119 16:26:04 [Warning] IP address '192.168.1.10' could not be resolved: Name or service not known
2.120119 16:26:04 [Warning] IP address '192.168.1.14' could not be resolved: Name or service not known
3.120119 16:26:04 [Warning] IP address '192.168.1.17' could not be resolved: Name or service not known

通過show processlist發(fā)現(xiàn)大量類似如下的連接:

1.|592|unauthenticated user|192.168.1.10:35320|NULL|Connect| |login|NULL|
2.|593|unauthenticated user|192.168.1.14:35321|NULL|Connect| |login|NULL|
3.|594|unauthenticated user|192.168.1.17:35322|NULL|Connect| |login|NULL|

skip-name-resolve 參數(shù)的作用:不再進(jìn)行反解析(ip不反解成域名),這樣可以加快數(shù)據(jù)庫的反應(yīng)時(shí)間。

修改配置文件添加并需要重啟:

 

復(fù)制代碼代碼如下:

[mysqld] 
skip-name-resolve

 

其實(shí)就是在[mysqld]下面一行加入skip-name-resolve重啟mysql服務(wù)就可以了。

下面是更加詳細(xì)的解釋:

現(xiàn)象:

程序連接mysql時(shí),mysql的error.log里面提示:

[Warning] IP address '10.0.0.220' could not be resolved: Name or service not known

原因:

Mysql數(shù)據(jù)庫服務(wù)器沒有配置 /etc/hosts,也沒有DNS服務(wù),導(dǎo)致mysqld線程解析IP對應(yīng)的主機(jī)名時(shí),解析失敗。

參考資料:

Mysql域名解析:

當(dāng)一個(gè)新的客戶端嘗試跟mysqld創(chuàng)建連接時(shí),mysqld產(chǎn)生一個(gè)新線程來處理這個(gè)請求。新線程會先檢查請求建立連接的主機(jī)名是否在Mysql的主機(jī)名緩沖中,如果不在,線程會嘗試去解析請求連接的主機(jī)名。

解析的邏輯如下:

a. Mysql線程通過gethostbyaddr()把獲取的IP地址解析成主機(jī)名,然后通過gethostbyname()把獲取的主機(jī)名解析成IP地址,保障主機(jī)名和IP地址對應(yīng)關(guān)系的準(zhǔn)確;

b. 如果操作系統(tǒng)支持使用安全進(jìn)程的gethostbyaddr_r()和gethostbyname_r() 調(diào)用,Mysqld線程可以用它倆來優(yōu)化主機(jī)名解析;

c. 如果操作系統(tǒng)不支持安全線程調(diào)用,Mysqld進(jìn)程先做一個(gè)互斥鎖,然后調(diào)用gethostbyaddr()和gethostbyname()解析主機(jī)名。此時(shí),在第一個(gè)進(jìn)程釋放掉主機(jī)名緩沖池的主機(jī)名之前,其它進(jìn)程無法再次解析這個(gè)主機(jī)名; <-------MySQL手冊里面在此處說的host name ,意思應(yīng)該是指同一個(gè)IP地址和對應(yīng)的第一個(gè)主機(jī)名關(guān)系。

在啟動(dòng)mysqld進(jìn)程是,可以使用 --skip-name-resolve 參數(shù)禁用DNS的主機(jī)名解析功能,禁用該功能后,在MySQL授權(quán)表里面,你只能使用IP地址。

如果你所處環(huán)境的DNS非常慢 或者 有很多主機(jī), 你可以通過禁用DNS解析功能--skip-name-resolve 或者 提高 HOST_CACHE_SIZE大小 來提升數(shù)據(jù)庫的響應(yīng)效率。

禁用主機(jī)名緩沖的發(fā)方法: 使用--skip-host-cache 參數(shù); 刷新主機(jī)名緩沖區(qū): 執(zhí)行 flush hosts 或者執(zhí)行mysqladmin flush-hosts;

禁用TCP/IP連接: 使用--skip-networking參數(shù)。

實(shí)驗(yàn):
# grep 192.168.1.1 /etc/hosts 
192.168.1.1 hostname_online

sql> grant usage on *.* to root@'h_tt_%' identified by 'root';

sql> flush hosts;

# mysql -h 192.168.1.1 -uroot -proot

ERROR 1045 (28000): Access denied for user 'root'@'hostname_online' (using password: YES) ### IP解析為hostname_online,不是h_tt_%,訪問被拒。

# grep 192.168.1.1 /etc/hosts

192.168.1.1 hostname_online

192.168.1.1 h_tt_1

# mysql -h 192.168.1.1 -uroot -proot

ERROR 1045 (28000): Access denied for user 'root'@'hostname_online' (using password: YES)#### mysqld沒有刷新主機(jī)池緩沖池中的IP和主機(jī)名信息,此時(shí)IP對應(yīng)hostname_online

sql> flush hosts;

# mysql -h 192.168.1.1 -uroot -proot

ERROR 1045 (28000): Access denied for user 'root'@'hostname_online' (using password: YES) #### mysqld解析了/etc/hosts里面同一個(gè)IP對應(yīng)的第一個(gè)主機(jī)名關(guān)系時(shí),就不再解析后面這個(gè)IP對應(yīng)的主機(jī)名關(guān)系

# grep 192.168.1.1 /etc/hosts

192.168.1.1 h_tt_1

192.168.1.1 hostname_online

sql> flush hosts;

# mysql -h 192.168.1.1 -uroot -proot

sql> exit

【實(shí)驗(yàn):】驗(yàn)證解析相同IP對應(yīng)的第一個(gè)主機(jī)名關(guān)系后,就不再解析相同IP:

Sql>grant usage on *.* to root@'h_tt_%' identified by ‘root';

Sql>flush hosts;

# grep h_tt /etc/hosts # grep h_tt /etc/hosts

192.168.1.1hostname_online 192.168.1.1h_tt_1

192.168.1.1h_tt_1 192,168.1.2h_tt_1

訪問mysql被拒絕; 從兩個(gè)IP都可以訪問mysql.

【結(jié)論】

此實(shí)驗(yàn)驗(yàn)證了,上述mysql手冊中對"How MySQL Uses DNS"的解釋。

即mysqld線程解析/etc/hosts是,是以IP作為唯一標(biāo)識的,及時(shí)一個(gè)IP對應(yīng)了多個(gè)主機(jī)名,但是mysqld線程只解析第一條對應(yīng)關(guān)系,不論后面有幾條這個(gè)IP對應(yīng)的不同主機(jī)名的記錄,Mysqld進(jìn)程都不會去解析,都是無效的。

【適用環(huán)境:】

沒有DNS服務(wù)器,主機(jī)非常非常多,或者 不想維護(hù)/etc/hosts里面手動(dòng)配置的IP和主機(jī)名對應(yīng)列表時(shí),可以在mysql授權(quán)時(shí)執(zhí)行主機(jī)名為"%" 或者禁用IP和主機(jī)名解析功能(--skip-name-resolve)。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 墨玉县| 安阳县| 犍为县| 河北省| 洞口县| 枣强县| 大埔区| 明溪县| 安徽省| 柘荣县| 大田县| 遵义县| 隆德县| 玛纳斯县| 锡林浩特市| 登封市| 重庆市| 资兴市| 小金县| 峨边| 阿拉尔市| 多伦县| 彭泽县| 青海省| 巴林左旗| 石屏县| 嘉兴市| 洮南市| 黎城县| 龙胜| 阿合奇县| 磐石市| 息烽县| 同仁县| 东乡族自治县| 新安县| 万年县| 临颍县| 陵水| 句容市| 股票|