(转)Linux开启mysql远程链接的设置步骤

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

相关文章
相关标签/搜索