解决mysql“Access denied for user 'root'@'IP地址'

转载 2013年12月05日 16:48:03

http://www.cnblogs.com/wonder315/archive/2011/11/02/2233010.html

解决mysql“Access denied for user 'root'@'IP地址'

在MYSQL 中,用远程软件登陆服务器,有时出现:Access denied for user 'root'@'localhost' 

出现这种问题,主要的原因就是权限配置的时候 没有配置正确。

解决方法如下:

当用Linux/unix的tty 登陆进MYSQL 时, mysql -u root -p 会提示你输入密码,输入正确的密码后正常登陆。

然后在提示符下,打命令:show grants; 会出现root如下的权限表示:GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY PASSWORD '565491d704013245' WITH GRANT OPTION

 

此时,注意看那个“@”后面的,是localhost 意思是本机登陆,,此时,如果你用远程登陆软件来登陆的话,会出现错误提示:Access denied for user 'root'@'IP地址'。。IP地址那块是你远程机器的IP地址。也就是服务器在告诉你,当你用“IP地址”登陆时,是拒绝的,因为,MYSQL权限设置里并没有给你对应你IP地址登陆的权限。因为刚才的SHOW GRANTS;命令结果已经告诉你了,仅限本机登陆。

那解决方法如下:此时,你可以尝试用空密码连接,是可以连接进入的。或者你在服务器的tty 或者pts操作台中进入服务器后执行如下的命令:

grant all privileges on *.* to 'root'@'%' with grant option;

意思是让root在所有机器都可以登陆到MYSQL服务器(拥有所有权限)。当执行完这条命令后,用客户端登陆,此时,是需要输入口令了。

 

 

GRANT ALL PRIVILEGES

1。 改表法。可能是你的帐号不允许从远程登陆,只能在localhost。这个时候只要在localhost的那台电脑,登入mysql后,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称"%" 

Sql代码 复制代码 

   1. mysql -u root -pvmwaremysql>use mysql;  
   2. mysql>update user set host = '%' where user = 'root';  
   3. mysql>select host, user from user; 

2. 授权法。例如,你想myuser使用mypassword从任何主机连接到mysql服务器的话。 

Sql代码 复制代码

  1. GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'%' IDENTIFIED BY 'mypassword' WITH

      GRANT OPTION;  
  2.FLUSH   PRIVILEGES; 

 

 

如果你想允许用户myuser从ip为192.168.1.6的主机连接到mysql服务器,并使用mypassword作为密码 

Sql代码 复制代码 

   1. GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY   
   2. 'mypassword' WITH GRANT OPTION;   
   3. FLUSH   PRIVILEGES;  

GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY 
'mypassword' WITH GRANT OPTION; 
FLUSH   PRIVILEGES; 



如果你想允许用户myuser从ip为192.168.1.6的主机连接到mysql服务器的dk数据库,并使用mypassword作为密码 
Sql代码 复制代码 

   1. GRANT ALL PRIVILEGES ON dk.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY   
   2. 'mypassword' WITH GRANT OPTION;   
   3. FLUSH   PRIVILEGES;  

GRANT ALL PRIVILEGES ON dk.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY 
'mypassword' WITH GRANT OPTION; 
FLUSH   PRIVILEGES; 


注意授权后必须FLUSH PRIVILEGES;否则无法立即生效。 

另外一种方法. 

在安装mysql的机器上运行: 
1、d:\mysql\bin\>mysql -h localhost -u root 
//这样应该可以进入MySQL服务器 
2、mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION 
//赋予任何主机访问数据的权限 
3、mysql>FLUSH PRIVILEGES 
//修改生效 
4、mysql>EXIT 
//退出MySQL服务器 
这样就可以在其它任何的主机上以root身份登录啦!

Access denied for user(这个几乎让我怀疑人生的异常)

昨天一时兴起,打算根据自己的某些想法,业余时间写一个简单的项目,用以巩固那些重要的知识,以及练手一些即将学习的技术。 然而才一开始,便有一盆冷水迎面而来,在搭建整个框架环境的时候竟然就被卡住了!主要...
  • tuzongxun
  • tuzongxun
  • 2016年11月29日 11:08
  • 5366

MySQL用户权限导致的创建Trigger失败

说来惭愧,MySQL一直处于只会用,不怎么理解的阶段。甚至是一些较为深层次的管理,都不怎么熟悉,得加强啊!近日,系统测试,使用MySQL数据库,需要在某个表上创建触发器,数据库是在本机安装。但是,无论...
  • cyq1984
  • cyq1984
  • 2014年06月25日 11:10
  • 11122

我的MYSQL学习心得(十三) 权限管理

这一篇《我的MYSQL学习心得(十三)》将会讲解MYSQL的用户管理   在mysql数据库中,有mysql_install_db脚本初始化权限表,存储权限的表有: 1、user表 2、db表...
  • mao834099514
  • mao834099514
  • 2016年09月18日 19:03
  • 321

Qt连接mysql数据库,及出现的问题

1.首先在.pro文件中添加QT += sql; 2.在程序中添加如下代码: //输出可用数据库 qDebug()...
  • songsong9181
  • songsong9181
  • 2016年10月24日 10:48
  • 315

CentOS 7安装MYSQL5.7(access denied问题解决方法)

CentOS 7安装MYSQL5.7 access denied for root@localhost
  • Aries1995
  • Aries1995
  • 2016年03月27日 10:22
  • 999

yii2 strace 追踪,本地文件

13631 16:16:13 execve("/usr/local/php/bin/php", ["/usr/local/php/bin/php", "/www/web/develop/erp2/ba...
  • terry_water
  • terry_water
  • 2016年02月27日 16:23
  • 754

xtrabackup的初使用

这里参考了jeanron大师的文章:http://chuansong.me/n/1696438151334 经过前边恶心的安装以后,接下来尝试一番xtrabackup的备份功能。 xtraback...
  • chen1511XIQIANG
  • chen1511XIQIANG
  • 2017年04月10日 11:52
  • 364

安装Zabbix过程中出现的问题集

安装Zabbix过程中出现的问题集: zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案。 zabbix能监视各种网络参数,保证服务器...
  • u010098331
  • u010098331
  • 2016年02月26日 17:17
  • 6384

mysql新增专给特定IP访问的用户

1 新创建同时授权用户: Sql代码   [root@XX-90 ~]# mysql -root -p   Enter password:    Welcome t...
  • cpk154505
  • cpk154505
  • 2013年04月07日 16:25
  • 5550

Mac上配置MySQL5.7.17出现问题Access denied解决

配置基本是按照此篇文章可以进行的,但是在配置mysql的过程中遇到一个问题ERROR 1045 (28000): Access denied for user 'root'@'localhost' (...
  • u012894479
  • u012894479
  • 2016年12月21日 17:46
  • 1807
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:解决mysql“Access denied for user 'root'@'IP地址'
举报原因:
原因补充:

(最多只允许输入30个字)