您好,欢迎访问一九零五行业门户网

PAIP.MYSQL设置远程账户登陆总结

mysql设置远程账户登陆总结 1.error2003(hy00 1 2.error1045(28000):accessdeniedforuser'test'@'x.x.x.x'(usingpassword:no) 1 3.取回 root 密码并设置远程登录 2 4.rror1062(23000):duplicateentry'%-root'forkey'primary' 2 5.error1044(42000):accessden
mysql设置远程账户登陆总结
1. error 2003 (hy00 1
2. error 1045 (28000): access denied for user 'test'@'x.x.x.x' (using password: no) 1
3. 取回root密码并设置远程登录 2
4. rror 1062 (23000): duplicate entry '%-root' for key 'primary' 2
5. error 1044 (42000): access denied for user ''@'localhost' to database 'mysql'。 3
6. 设置用户远程主机连接权限 4
7. 设置用户与库的权限 4
 ----作者attilax , 1466519819@qq.com---  
为了给mysql用户设置一个远程连接权限,经历了很多曲折..特此纪录下来..先是玉到了2003错误
error 2003 (hy00原因是mysql考虑到安全因素,默认配置只让从本地登录
打开 /etc/mysql/my.cnf 文件,找到 bind-address = 127.0.0.1 修改为 bind-address = 0.0.0.0
重启mysql : sudo /etc/init.d/mysql restart
再次连接,发生错误 1045
error 1045 (28000): access denied for user 'test'@'x.x.x.x' (using password: no)a: 原因是没有给登录用户名设置远程主机登录的权限。还有种可能是你需要重设下密码....可能是授权操作引起这种后遗症..
在本地用 root 登录: mysql -u root -p
修改 mysql 数据库中 user 表中 对应用户名的 host 字段,将 localhost 改为 %
use mysql;
update user set host = '%' where user = 'username';
给这个设置权限需要root用户登录才行.可惜root密码不记得了.
取回root密码并设置远程登录
mysqld_safe --skip-grant-tables &
mysql -u root mysql
mysql> update user set password=password('newpassword') where user='root';
mysql> flush privileges;
设置 root 远程连接  update user set host = '%'   where user='root';
查看进程,可看到mysqld_safe与mysql进程,此时mysql可正常使用,不过查看参数,可看到--skip-grant-tab
输入mysqld_safe命令行,要立马输入mysql -u root mysql,不得有误..或者新开一个窗口也可.
执行update时出现1062错误
rror 1062 (23000): duplicate entry '%-root' for key 'primary' 如果执行update语句时出现error 1062 (23000): duplicate entry '%-root' for key 'primary' 错误,说明有多个root用户纪录在user表中了.
需要select host from user where user = 'root';
查看一下host是否已经有了%这个值,有了就可以了.
mysql> select host,user from user where user='root';
+-----------------------+------+
| host                  | user |
+-----------------------+------+
| %                     | root |
| 127.0.0.1             | root |
| ::1                   | root |
| localhost.localdomain | root |
然后用root用户登录更改用户账户的远程连接权限时.出现提示:error 1044 (42000): access denied for user ''@'localhost' to database 'mysql'。
 error 1044 (42000): access denied for user ''@'localhost' to database 'mysql'。是因为mysql数据库的user表里,存在用户名为空的账户即匿名账户,导致登录的时候是虽然用的是root,但实际是匿名登录的,通过错误提示里的''@'localhost'可以看出来,于是解决办法见
先关闭mysql进程..
然后
   # mysqld_safe --skip-grant-table
   屏幕出现: starting demo from .....
此时要记得,紧接着输入
   # mysql -u root mysql
   mysql> delete from user where user='';
   mysql> flush privileges;
如果出现  starting demo from .. 后..先输入其它命令,再用mysql -u root mysql .它又会出现这个错误了.
然后kill掉mysql进程,..重启正常的进程..
设置用户远程主机连接权限update user set host = '%'  where user='fanzkcom_fanzk'; 
flush privileges; 
但是在实际连接中,虽然可以连接,但是去没有所在库的权限,晕.
只好接下来设置权限
设置用户与库的权限grant all privileges on fanzkcom_fanzk.* to fanzkcom_fanzk@'%' identified by '1234';
flush privileges; 
百分号两边要有单引号,否则语法错误
然后连接时,竟然提示1045 错误了.晕,,想了半天,还是重设下密码试下.
 update mysql.user set password=password('xxx') where user=fanzkcom_fanzk  
 flush privileges;
竟然好了.晕.也不知道为什么设置授权会改动了密码了呢.奇怪..应该是mysql的bug
其它类似信息

推荐信息