[Warning] IP address'10.0.9.121' could not be resolved: Temporary failure in name resolution

发现mysql错误日志中经常出现类似这样的警告:

160716 18:14:49 [Warning] IP address'10.0.9.121' could not be resolved: Temporary failure in name resolution

原因是由于mysql对连接的客户端进行DNS反向解析。

我理解mysql是这样来处理客户端解析过程的,
1,当mysql的client连过来的时候,服务器会主动去查client的域名。
2,首先查找 /etc/hosts 文件,搜索域名和IP的对应关系。
3,如果hosts文件没有,则查找DNS设置,如果没有设置DNS服务器,会立刻返回失败,就相当于mysql设置了skip-name-resolve参数,如果设置了DNS服务器,就进行反向解析,直到timeout。

 有2种解决办法:

1把client的ip和主机名写在mysql服务器的/etc/hosts文件里。

记录完之后,直接Ping主机名就能ping通了。

2在 my.cnf 中加入skip-name-resolve,来禁用DNS主机名查找 。

 对于第一种方法比较笨,也不实用,skip-name-resolve 选项可以禁用dns解析,但是,这样不能在mysql授权时中指定主机名了,只能指定IP。

比如10.0.9.121要访问10.192.203.201.

 我在10.192.203.201上授权:

mysql> grant all privileges on *.* to'baidd'@'ocp' identified by '123456';

Query OK, 0 rows affected, 1 warning (0.00sec)

 此时,在9.121上访问则会报错:

[root@ocp shell_script2]# mysql -u baidd-p123456 -h 10.192.203.201 -P 3307

Warning: Using a password on the commandline interface can be insecure.

ERROR 1045 (28000): Access denied for user'baidd'@'10.0.9.121' (using password: YES)

 所以假如要添加参数skip-name-resolve,需要先查看下host有没有是主机名的,有的话,删掉,然后创建对应的IP用户。

mysql> delete from mysql.user wherehost='ocp';

Query OK, 1 row affected (0.05 sec)

mysql> grant all privileges on *.* to'baidd'@'10.0.9.121' identified by '123456';

Query OK, 0 rows affected (0.00 sec)

 

 --本篇文章参考自:http://blog.sina.com.cn/s/blog_96ae64bd0100wtn3.html并做了些许修改。

你可能感兴趣的:(1,MySql,学习,#,MySql,报错集锦)