来源:自学PHP网 时间:2015-04-16 10:51 作者: 阅读:次
[导读] 现象: 程序连接mysql时,mysql的error log里面提示:[Warning] IP address 10 0 0 220 could not be resolved: Name or service not known原因: Mysql数据库服务器没有配置...
现象: 程序连接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/hosts192.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)。 |
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com