无法远程访问Mysql的解决方案
来源:互联网 发布:西门子编程器pg m4价格 编辑:程序博客网 时间:2024/05/17 08:12
在网上有很多关于这个的解决方案,我也采用了
写的比较详细的如:
1。 改表法。可能是你的帐号不允许从远程登陆,只能在localhost。这个时候只要在localhost的那台电脑,登入mysql后,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称"%"
CODE:mysql -u root -p123
mysql>use mysql;
mysql>update user set host = '%' where user = 'root';
mysql>select host, user from user;
2. 授权法。例如,你想kevin使用mypassword从任何主机连接到mysql服务器的话。
CODE:GRANT ALL PRIVILEGES ON *.* TO 'kevin'@'%' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
如果你想允许用户kevin从ip为192.168.101.234的主机连接到mysql服务器,并使用mypassword作为密码
CODE:GRANT ALL PRIVILEGES ON *.* TO 'kevin'@'192.168.101.234' IDENTIFIED BY 'mypassword' WITH GRANT OPTION;
3.如果按照上面这样做还不行(一般好像在windows下那样就可以了)那就修改下面这个配置文件吧(我是在linux环境下 大家可以找到自己mysql安装目录下的相应配置文件)
CODE:vi /etc/mysql/my.cnf
注释掉
CODE:#bind-address = 127.0.0.1
大功告成!!!
然后我采用的是第一种方法,然后在运行完最后一句话后出了个错误ERROR 1062 (23000): Duplicate entry '%-root' for key 'PRIMARY'
于是又去找解决方案,发现先
mysql> select host from user where user = 'root';
+-----------------------+
| host |
+-----------------------+
| % |
| 127.0.0.1 |
| localhost.localdomain |
+-----------------------+
3 rows in set (0.00 sec)
host已经有了%这个值,所以直接运行命令:
mysql>flush privileges;
果然还行的通,由于对mysql不是很深入的了解,通过php果然可以远程访问了,但是我忽略了一点
这里将host = '%'后,是可以远程访问了,但是我们使用root不能访问本地了
这是由于%的意思就是允许除本机外的所有都可以访问
如果前面已经如上操作了,那么你再在本地访问的时候
#mysql -u root -p
输入密码后会提示
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
这就很郁闷,本机已经无法登陆了,这时我们需要安全模式进入(个人理解为安全模式)
首先,将mysql服务停止
#/etc/init.d/mysql stop 或者 #sudo service mysqld stop
然后再执行
# mysqld_safe --user=mysql --skip-grant-tables --skip-networking &
记住 后面那个 &是需要的
等出现一些提示后 应该是在starting...之后
直接输入 mysql 即可进入数据库了 (这里其实也可以是忘记密码后进行修改密码的方法)
进入后,修改密码的语句为:
mysql> use mysql;
进入数据库修改密码
mysql> update user set password = PASSWORD('你的新密码') where user='root'
如果是要解决上面修改了host的方法就是执行
mysql> update user set host='localhost' where user='root' and host='%'
将host改回来
但是改回来岂不是又无法远程访问了?
其实我们可以新增一个用户,把必要的权限授予于这个用户,且将这个用户的host设为%
过程中出现的错误要仔细查看,要注意防火墙的状态,可能影响数据库的远端连接。
- 无法远程访问Mysql的解决方案
- 无法远程访问Mysql的解决方案
- 无法远程访问Mysql的解决方案
- MySql远程访问解决方案
- 无法远程访问Mysql
- mysql 无法远程访问
- mysql无法远程访问?
- Mysql 无法远程登录的解决方案
- 无法连接远程MySQL数据库的解决方案
- 解决MySQL无法远程访问的方法
- mysql 无法进行远程访问的问题
- 无法远程访问服务器上的mysql
- MySQL无法远程访问的问题解决
- MySql远程访问无法连接的问题!
- mysql远程访问失败解决方案
- 远程访问mysql bug-解决方案
- 远程访问linux下的mysql,完整解决方案
- mysql Error 1130 远程连接访问 问题的解决方案
- 实现AOP动态代理原理
- pyhon中input()和raw_input()函数的区别
- wps面试一小时的面经
- 网络连接评分机制之NetworkAgent
- SQL*Plus copy命令处理大批量数据复制
- 无法远程访问Mysql的解决方案
- Ubuntu16.04下hadoop-2.6.0单机配置和伪分布式配置
- request详解
- 集群hadoop版本升级(2.6.4--2.7.2)
- 数字签名
- TCP三次握手(建立连接)与四次挥手(释放连接)详细图解
- Codevs 1116 四色问题(DFS)
- 系统状态检测命令
- Android下拉刷新