激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

Mysql|Sql Server|Oracle|Redis|MongoDB|PostgreSQL|Sqlite|DB2|mariadb|Access|數(shù)據(jù)庫技術(shù)|

服務(wù)器之家 - 數(shù)據(jù)庫 - Mysql - mysql could not be resolved: Name or service not known

mysql could not be resolved: Name or service not known

2020-05-16 18:32MYSQL教程網(wǎng) Mysql

今天查看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對(duì)應(yīng)的主機(jī)名時(shí),解析失敗。

參考資料:

Mysql域名解析:

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

解析的邏輯如下:

a. Mysql線程通過gethostbyaddr()把獲取的IP地址解析成主機(jī)名,然后通過gethostbyname()把獲取的主機(jī)名解析成IP地址,保障主機(jī)名和IP地址對(duì)應(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手冊(cè)里面在此處說的host name ,意思應(yīng)該是指同一個(gè)IP地址和對(duì)應(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對(duì)應(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對(duì)應(yīng)的第一個(gè)主機(jī)名關(guān)系時(shí),就不再解析后面這個(gè)IP對(duì)應(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對(duì)應(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手冊(cè)中對(duì)"How MySQL Uses DNS"的解釋。

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

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

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久精品亚洲精品国产欧美kt∨ | 欧美激情图区 | 黄色网址在线免费播放 | 欧美中文日韩 | 亚洲欧洲av在线 | 精品中文字幕视频 | 一级视频片 | 成人在线第一页 | 中国一级免费视频 | 午色影院 | xnxx18日本 | 国产精品久久久久久久久久三级 | 91色琪琪电影亚洲精品久久 | 免费一级特黄毛片 | 伦一区二区三区中文字幕v亚洲 | 国产精品视频导航 | 亚洲第一页中文字幕 | 国产精品一区二区日韩 | 91精品国产乱码久久桃 | 午夜伦情电午夜伦情电影 | 欧美成人精品一区二区男人小说 | 久久精品欧美电影 | av在线免费网| 黄色网页在线观看 | sesee99| 成人黄色免费小视频 | 日本娇小videos高潮 | 综合精品一区 | 福利一区二区三区视频在线观看 | 欧美成人激情在线 | 国产欧美日韩久久久 | 毛片免费视频网站 | 国产99久久久久久免费看 | 免费一区区三区四区 | 日日草天天干 | 国产毛片在线看 | 日本成年免费网站 | 日本视频免费 | 一级空姐毛片 | 草久影视 | 免费一级毛片在线播放视频老 |