安装完MySQL后,远程链接数据库的时候,出现 ERROR 1130 (HY000): Host '192.168.56.102' is not allowed to connect to this MySQL server提示信息,不能远程链接数据库。 mysql
一、更改环境mysql系统host环境变量值:(不推荐) sql
考虑多是由于系统数据库mysql中user表中的host是localhost的缘由,因而,我尝试把这个值改成本身服务器的ip,果真就好用了,不过用 mysql -u root -p命令就连不上数据库了,须要用mysql -h 服务器ip -u root -p由于默认的链接mysql数据库user表中host的值,而这个命令的默认host是localhost,就连不上了。 数据库
具体操做方法: 安全
用localhost链接上mysql后, 服务器
use mysql; update user set host='123.456.789.254';(IP为你想要远程链接数据库的本地机器的IP) \q;
退出mysql,而后从新启动mysql就能够了。 this
其余解决方案 code
2. 改表法。多是你的账号不容许从远程登录,只能在localhost。这个时候只要在localhost的那台电脑,登入mysql后,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称"%" server
mysql -u root -pvmware mysql>use mysql; mysql>update user set host = '%' where user = 'root'; mysql>flush privileges; mysql>select host, user from user;
3. 受权法。例如,你想myuser使用mypassword从任何主机链接到mysql服务器的话。 ip
GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;若是你想容许用户myuser从ip为192.168.1.3的主机链接到mysql服务器,并使用mypassword做为密码
GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'192.168.0.1' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
四、顺便提下另外一个错误码:1045错误的解决方案 class
在安装完MYSQL后,初次使用PHP联接数据,系统报1045错误说明你没有将权限下放到远端链接账户上,因为mysql的安全性在不断的提升,权限设置默认是拒绝的,你必须本身开放权限。
在服务器上用
mysql -h 192.168.0.1 -u root -p #mysql命令登陆mysql数据库。而后用grant命令下放权限。 GRANT ALL PRIVILEGES ON *.* TO root@localhost IDENTIFIED BY 'root-password' WITH GRANT OPTION;