IP address could not be resolved: Name or service not known

 

 

[root@test ~]# /usr/local/mysql/bin/mysqld
2018-08-05T07:00:33.647509Z 0 [Warning] [MY-011070] [Server] 'Disabling symbolic links using --skip-symbolic-links (or equivalent) is the default. Consider not using this option as it' is deprecated and will be removed in a future release.
2018-08-05T07:00:33.647654Z 0 [System] [MY-010116] [Server] /usr/local/mysql/bin/mysqld (mysqld 8.0.12) starting as process 12515
2018-08-05T07:00:34.591235Z 0 [System] [MY-010229] [Server] Starting crash recovery...
2018-08-05T07:00:34.591283Z 0 [System] [MY-010232] [Server] Crash recovery finished.
2018-08-05T07:00:34.664056Z 0 [Warning] [MY-010068] [Server] CA certificate ca.pem is self signed.
2018-08-05T07:00:34.695818Z 0 [System] [MY-010931] [Server] /usr/local/mysql/bin/mysqld: ready for connections. Version: '8.0.12' socket: '/tmp/mysql.sock' port: 3306 MySQL Community Server - GPL.
2018-08-05T07:06:56.802280Z 8 [Warning] [MY-010055] [Server] IP address '211.161.60.12' could not be resolved: Name or service not knownmysql

 

 

 

mysql could not be resolved: Name or service not known_Mysql_脚本之家 https://www.jb51.net/article/70893.htmsql

问题: mysql DNS反解:skip-name-resolve

错误日志有相似警告:数据库


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发现大量相似以下的链接:服务器

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|socket

skip-name-resolve 参数的做用:再也不进行反解析(ip不反解成域名),这样能够加快数据库的反应时间。ide

修改配置文件添加并须要重启:优化

 

复制代码代码以下:

[mysqld] 
skip-name-resolve

 

其实就是在[mysqld]下面一行加入skip-name-resolve重启mysql服务就能够了。ui

下面是更加详细的解释:this

现象:

程序链接mysql时,mysql的error.log里面提示:

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

缘由:

Mysql数据库服务器没有配置 /etc/hosts,也没有DNS服务,致使mysqld线程解析IP对应的主机名时,解析失败。

参考资料:

Mysql域名解析:

当一个新的客户端尝试跟mysqld建立链接时,mysqld产生一个新线程来处理这个请求。新线程会先检查请求创建链接的主机名是否在Mysql的主机名缓冲中,若是不在,线程会尝试去解析请求链接的主机名。

解析的逻辑以下:

a. Mysql线程经过gethostbyaddr()把获取的IP地址解析成主机名,而后经过gethostbyname()把获取的主机名解析成IP地址,保障主机名和IP地址对应关系的准确;

b. 若是操做系统支持使用安全进程的gethostbyaddr_r()和gethostbyname_r() 调用,Mysqld线程能够用它俩来优化主机名解析;

c. 若是操做系统不支持安全线程调用,Mysqld进程先作一个互斥锁,而后调用gethostbyaddr()和gethostbyname()解析主机名。此时,在第一个进程释放掉主机名缓冲池的主机名以前,其它进程没法再次解析这个主机名; <-------MySQL手册里面在此处说的host name ,意思应该是指同一个IP地址和对应的第一个主机名关系。

在启动mysqld进程是,可使用 --skip-name-resolve 参数禁用DNS的主机名解析功能,禁用该功能后,在MySQL受权表里面,你只能使用IP地址。

若是你所处环境的DNS很是慢 或者 有不少主机, 你能够经过禁用DNS解析功能--skip-name-resolve 或者 提升 HOST_CACHE_SIZE大小 来提高数据库的响应效率。

禁用主机名缓冲的发方法: 使用--skip-host-cache 参数; 刷新主机名缓冲区: 执行 flush hosts 或者执行mysqladmin flush-hosts;

禁用TCP/IP链接: 使用--skip-networking参数。

实验:
# 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没有刷新主机池缓冲池中的IP和主机名信息,此时IP对应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里面同一个IP对应的第一个主机名关系时,就再也不解析后面这个IP对应的主机名关系

# 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

【实验:】验证解析相同IP对应的第一个主机名关系后,就再也不解析相同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被拒绝; 从两个IP均可以访问mysql.

【结论】

此实验验证了,上述mysql手册中对"How MySQL Uses DNS"的解释。

即mysqld线程解析/etc/hosts是,是以IP做为惟一标识的,及时一个IP对应了多个主机名,可是mysqld线程只解析第一条对应关系,不论后面有几条这个IP对应的不一样主机名的记录,Mysqld进程都不会去解析,都是无效的。

【适用环境:】

没有DNS服务器,主机很是很是多,或者 不想维护/etc/hosts里面手动配置的IP和主机名对应列表时,能够在mysql受权时执行主机名为"%" 或者禁用IP和主机名解析功能(--skip-name-resolve)。

相关文章
相关标签/搜索