mysql报错IP address could not be resolved解决方法

这个警告不会影响数据库的访问 但是当有大量的这种日志产生的时候,数据库之前的错误信息 就会很难去查询了。连接数越多,产生报警日志的频率越高。 一、错误描述 数据库的alert.log中,我们经常会出现下面的警告: IP address 172.16.12.195 could not be re

这个警告不会影响数据库的访问 但是当有大量的这种日志产生的时候,数据库之前的错误信息 就会很难去查询了。连接数越多,产生报警日志的频率越高。

一、错误描述

数据库的alert.log中,我们经常会出现下面的警告:

IP address '172.16.12.195' could not be resolved: Temporary failure in name resolution
IP address '172.16.12.67' could not be resolved: Temporary failure in name resolution
IP address '172.16.12.67' could not be resolved: Temporary failure in name resolution
IP address '172.16.12.195' could not be resolved: Temporary failure in name resolution
IP address '172.16.12.195' could not be resolved: Temporary failure in name resolution
IP address '172.16.12.195' could not be resolved: Temporary failure in name resolution
IP address '172.16.12.196' could not be resolved: Temporary failure in name resolution
IP address '172.16.12.196' could not be resolved: Temporary failure in name resolution
IP address '172.16.12.195' could not be resolved: Temporary failure in name resolution
IP address '172.16.12.195' could not be resolved: Temporary failure in name resolution
IP address '172.16.12.68' could not be resolved: Temporary failure in name resolution

二、问题产生的原因

出现错误的原因是MYSQL Server在本地内存中维护了一个非本地的Client TCP cache,这个cache中包含了远程Client的登录信息,比如IP地址,hostname等信息。

如果Client连接到服务器后,Mysql首先会在本地TCP池中根据IP地址解析客户端的hostname或者反解析,如果解析不到,就会去DNS中进行解析,如果还是解析失败

就是在error log中写入这样的警告信息。

三、解决的办法:

1、修改配置文件

可以通过两个参数来disable这个功能,在MYSQL的配置文件中[mysqld]中加入下面的参数:

[mysqld]
--skip-host-cache
--skip-name-resolve

重新授权,将所有访问数据库服务器的授权方式都改成IP形式的。

grant all on *.* to ‘root’@’172.16.12.68’identified by ‘123456’;

2、添加授权。

将所有访问数据库服务器的授权方式都改成IP形式。
不同的用户用不同的用户名和密码。

grant all on *.* to ‘user_68’@’172.16.12.68’identified by ‘pwd_68’;
grant all on *.* to ‘user_67’@’172.16.12.67’identified by ‘pwd_67’;
....

然后去 mysql数据库下面的 user表  和db表 下面删除掉那些含有含有主机名字的权限记录。

四、总结

1、要么加上

--skip-host-cache
--skip-name-resolve

使得MySQL将不再通过DNS解析地址。

2、赋予权限

要么在赋予权限的时候 直接用ip地址,去掉那些用主机名字的权限。

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

一、 创建用户: 命令:CREATE USER username@host IDENTIFIED BY password; 说明:username - 你将创建的用户名, host - 指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost, 如果想让该用户可以从任意远程主机登陆,可以使用通配符%. password - 该
在mysql中可以用group by对查询出的数据分组 select id,service,name FROM service GROUP BY name,service 如果要查看每组数据的总数,可以 select count(*) FROM service GROUP BY name,service 当要查询group by后的总数,可以这样 select count(*) from(s
mysql count group by统计条数方法 mysql 分组之后如何统计记录条数? gourp by 之后的 count,把group by查询结果当成一个表再count一次 select count(*) as count from(SELECT count(*) FROM 表名 WHERE 条件 GROUP BY id ) a; 实战例子: select count(*)
1.首先停止MySQL服务:service mysqld stop 2.加参数启动mysql:/usr/bin/mysqld_safe --skip-grant-tables 然后就可以无任何限制的访问mysql了 3.root用户登陆系统:mysql -u root -p mysql 4.切换数据库:use mysql 5.显示所有的表:show tables; 这里就可
float,double容易产生误差,对精确度要求比较高时,建议使用decimal来存,decimal在mysql内存是以字符串存储的,用于定义货币要求精确度高的数据。在数据迁移中,float(M,D)是非标准定义,最好不要这样使用。M为精度,D为标度。 mysql create table t1(c1 fl
MySQL 支持的三个浮点类型是 FLOAT、DOUBLE 和 DECIMAL 类型。FLOAT 数值类型用于表示单精度浮点数值,而 DOUBLE 数值类型用于表示双精度浮点数值。 与整数一样,这些类型也带有附加参数:一个显示宽度指示器和一个小数点指示器。比如语句 FLOAT(7,3) 规定显