Mysql默认root用户只能本地访问,不能远程链接管理mysql数据库,Linux如何开启mysql远程链接?设置步骤以下:
一、GRANT命令建立远程链接mysql受权用户itlogger
mysql -u root -p
mysql>GRANT ALL PRIVILEGES ON *.* TO itlogger@localhost IDENTIFIED BY ‘www.itlogger.com’ WITH GRANT OPTION;
mysql>GRANT ALL PRIVILEGES ON *.* TO itlogger@”%” IDENTIFIED BY ‘www.itlogger.com’ WITH GRANT OPTION;html
第一句增长itlogger用户受权经过本地机(localhost)访问,密码“www.itlogger.com”。第二句则是授与itlogger用户从任何其它主机发起的访问(通配符%)。
二、设置防火墙容许3306端口
vi /etc/sysconfig/IPtables
添加-A RH-Firewall-1-INPUT -m state –state NEW -m tcp -p tcp –dport 3306 -j ACCEPT
(注意添加在-A RH-Firewall-1-INPUT -j REJECT –reject-with icmp-host-prohibited以前,不然可能致使规则不生效)
重启防火墙service iptables restart
三、附:Mysql没法远程链接的常见问题mysql
1)查看Mysql的端口是否正确,经过netstat -ntlp查看端口占用状况,通常状况下端口是3306。linux
2)报错:ERROR 2003 (HY000): Can’t connect to MySQL server on ’192.168.51.112′ (111)
查看/etc/my.cnf中,skip-networking 是否已被注掉,须要注掉。
3)报错:ERROR 2003 (HY000): Can’t connect to MySQL server on ’192.168.51.112′ (113)
查看是否iptables没有容许mysql链接,经过:service iptables stop临时关闭测试是否能够正常远程访问,若是能够,按上面方面设置iptable容许3306端口
4)远程访问mysql速度很慢的解决方法
修改/etc/my.cnf或my.ini
[mysqld]下添加
skip-name-resolve
skip-grant-tablessql
**********************************************************************************************************************数据库
mysql数据库远程访问设置方法安全
一、修改localhost
更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改为"%"
mysql>use mysql;
mysql>update user set host = '%' where user = 'root';
mysql>select host, user from user;
mysql>FLUSH PRIVILEGES;服务器
二、指定受权
使用myuser/mypassword从任何主机链接到mysql服务器:
GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;tcp
使用myuser/mypassword从ip为192.168.225.166的主机链接到mysql服务器:
GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'192.168.225.166' IDENTIFIED BY 'mypassword' WITH GRANT OPTION; 工具
三、泛受权
mysql -h localhost -u root
mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION; //赋予任何主机上以root身份访问数据的权限
mysql>FLUSH PRIVILEGES;测试
解决Mysql没法远程链接的问题
一、Mysql的端口是否正确
经过netstat -ntlp查看端口占用状况,通常状况下端口是3306。在用工具链接MySQl是要用到端口。例如My Admin\My Query Browser\MySQl Front等。
二、检查用户权限是否正确
mysql库的user表里有两条记录:host分别为localhost和%(为了安全,%能够换成你须要外部链接的IP)。
三、查看/etc/mysql/my.cnf中,skip-networking 是否已被注掉
须要注掉
报错:ERROR 2003 (HY000): Can't connect to MySQL server on '192.168.51.112' (111)
sudo gedit /etc/mysql/my.cnf
#skip-external-locking
#bind-address = 127.0.0.1
skip-name-resolve
四、查看iptables是否停掉,没关的状况下,没法链接
经过:service iptables stop临时关闭。
报错:ERROR 2003 (HY000): Can't connect to MySQL server on '192.168.51.112' (113)
设置好之后须要重启:sudo service mysql restart