MySQL有关1042 Can’t get hostname for your address的问题分析解决过程
2015-04-28 11:02
821 查看
[Comment 1]
前同事企鹅上面说他安装的mysql 5.5,发现用mysql客户端远程连接的时候,报1042-Can’t get hostname for your address错误,但是权限已经grant了并且grant成功了。
这个报错的意思是“您的地址无法获得主机名”,我就想到了skip-name-resolve参数。
官方文档:
Use IP addresses rather than host names when creating grant table entries. This option can be useful if your DNS does not work.
Do not resolve host names when checking client connections. Use only IP numbers. If you use this option, all
“How MySQL Uses DNS”.
mysql> show variables like '%skip_name_resolve%';
+-------------------+-------+
| Variable_name | Value |
+-------------------+-------+
| skip_name_resolve | ON |
+-------------------+-------+
1 row in set (0.00 sec)
mysql> set global skip_name_resolve=0;
ERROR 1238 (HY000): Variable 'skip_name_resolve' is a read only variable
mysql>
失败了,看来是只有修改my.cnf了
在[mysqld]节点下修改
skip-name-resolve
#忽略主机名的方式访问
lower_case_table_names=1
#忽略数据库表名大小写
重启MySQLD process即可。
[Comment 2]
前同事企鹅留言:
mysql -h 192.168.1.101 -u root -p
访问不了,我本地的mysql.192.168.1.101是本地ip地址。
grant all privileges on *.* to 'hive'@'192.168.1.101' identified by 'hive' with grant option;就是报连接不上,权限问题,怎么搞定。
查看官方文档:
The server sets this variable to the server host name at startup.
mysql> show variables like '%hostname%';
+---------------+-------------------------------------------+
| Variable_name | Value |
+---------------+-------------------------------------------+
| hostname | xxxxx.china.online.xx.com |
+-----
4000
----------+-------------------------------------------+
1 row in set (0.00 sec)
mysql> set global hostname='xxxxx2.china.online.xx.com';
ERROR 1238 (HY000): Variable 'hostname' is a read only variable
mysql>
失败了,只有修改my.cnf了,在mysqld选项下面
[mysqld]
# 注释掉参数即可,mysql直接用本机ip不能访问
# hostname
然后重启mysqld 服务即可。
前同事企鹅上面说他安装的mysql 5.5,发现用mysql客户端远程连接的时候,报1042-Can’t get hostname for your address错误,但是权限已经grant了并且grant成功了。
这个报错的意思是“您的地址无法获得主机名”,我就想到了skip-name-resolve参数。
官方文档:
--skip-name-resolve
Use IP addresses rather than host names when creating grant table entries. This option can be useful if your DNS does not work.
--skip-name-resolve
Do not resolve host names when checking client connections. Use only IP numbers. If you use this option, all
Hostcolumn values in the grant tables must be IP numbers or
localhost. See Section 7.7.11,
“How MySQL Uses DNS”.
mysql> show variables like '%skip_name_resolve%';
+-------------------+-------+
| Variable_name | Value |
+-------------------+-------+
| skip_name_resolve | ON |
+-------------------+-------+
1 row in set (0.00 sec)
mysql> set global skip_name_resolve=0;
ERROR 1238 (HY000): Variable 'skip_name_resolve' is a read only variable
mysql>
失败了,看来是只有修改my.cnf了
在[mysqld]节点下修改
skip-name-resolve
#忽略主机名的方式访问
lower_case_table_names=1
#忽略数据库表名大小写
重启MySQLD process即可。
[Comment 2]
前同事企鹅留言:
mysql -h 192.168.1.101 -u root -p
访问不了,我本地的mysql.192.168.1.101是本地ip地址。
grant all privileges on *.* to 'hive'@'192.168.1.101' identified by 'hive' with grant option;就是报连接不上,权限问题,怎么搞定。
查看官方文档:
hostname
Variable Name | hostname |
Variable Scope | Global |
Dynamic Variable | No |
Permitted Values | |
Type | string |
mysql> show variables like '%hostname%';
+---------------+-------------------------------------------+
| Variable_name | Value |
+---------------+-------------------------------------------+
| hostname | xxxxx.china.online.xx.com |
+-----
4000
----------+-------------------------------------------+
1 row in set (0.00 sec)
mysql> set global hostname='xxxxx2.china.online.xx.com';
ERROR 1238 (HY000): Variable 'hostname' is a read only variable
mysql>
失败了,只有修改my.cnf了,在mysqld选项下面
[mysqld]
# 注释掉参数即可,mysql直接用本机ip不能访问
# hostname
然后重启mysqld 服务即可。
相关文章推荐
- MySQL有关1042 Can’t get hostname for your address的问题分析解决过程
- MySQL有关1042 Can’t get hostname for your address的问题分析解决过程
- MySQL 1042, "Can't get hostname for your address"问题解决方案
- Navicat连接Mysql报1042- Can't get hostname for your address错误的解决办法
- mysql 1042 can't get hostname for your address解决办法(navicat链接)
- 解决(针对Windows)MySQL:1042错误-Can't get hostname for your address
- Linux下mysql用sqlyog连接报1042 can not get hostname for your address的问题
- MySQL错误1042-Can't get hostname for your address解决方法
- MySQL 1042, "Can't get hostname for your address" 解决
- 解决MySQL:1042错误-Can't get hostname for your address
- mysql远程访问出现MySQL错误1042-Can't get hostname for your address解决方法
- MySQL错误1042-Can't get hostname for your address解决方法
- (1042)-MySQL报错1042-Can’t get hostname for your address解决
- Mysql 访问,提示无法连接Can't get hostname for your address Error 1042
- MySqL遇到Can't get hostname for your address解决办法
- 1042-Can't get hostname for your address , navicat无法连接mysql
- 关于MySQL问题:can't get hostname for your address
- [Navicat] 连接Mysql错误 1042 Can't get hostname for your address
- MySql连接错误:Can‘t get hostname for your address解决办法之小白篇
- Navicat连接mysql出现1042错误 Can’t get hostname for your address