远程登陆数据库的时候出现了下面出错信息:
ERROR 2003 (HY000): Can’t connect to MySQL server on ‘xxx.xxx.xxx.xxx’,
经过今天下午的反复纠结,关于MySql数据库无法远程连接的问题可以归结为以下几点:
- 没有授予相应权限
- 例如你想root使用123456 从任何主机连接到mysql服务器
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY '123456' WITH GRANT OPTION;
-如果你想允许用户zhumingzhen从ip为115.29.79.115的主机连接到mysql服务器并使用654321作为密码
GRANT ALL PRIVILEGES ON *.* TO 'zhumingzhen'@'115.29.79.115' IDENTIFIED BY '654321' WITH GRANT OPTION;
执行完成执行flush rivileges 使配置生效
FLUSH RIVILEGES
2.修改mysql数据库中的user表使相应的用户能从某一主机登陆
mysql -u root -p
use mysql;
update user srt host='%' where user='root';
select host,user from user;
3.防火墙禁止了3306端口,以iptable为例
vi /etc/sysconfig/iptables
增加下面一行:
-A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 3306-j ACCEPT
service iptables restart
ps: iptables设置
1) 重启后生效
开启: chkconfig iptables on
关闭: chkconfig iptables off
2) 即时生效,重启后失效
开启: service iptables start
关闭: service iptables stop
4.修改MySQL的配置文件/etc/mysql/my.cnf,因为默认3306端口只允许本地访问的,注释掉这行
#bind-address = 127.0.0.1
然后重启Mysql,/etc/init.d/mysql restart