首页 | 源码下载 | 网站模板 | 网页特效 | 广告代码 | 网页素材 | 字体下载 | 书库
会员投稿 投稿指南 RSS订阅
当前位置:主页>网络编程>Mysql教程>资讯:Host "localhost " is not allowed to conn

Host "localhost " is not allowed to conn

www.jz123.cn  2011-02-21   来源:   站长家园    责任编辑(袁袁)    我要投递新闻

  一、原因:

  今天在尝试初始化一个WEB应用的时候,发现其连接不上MySQL,从Traceback看到使用的默认密码为‘YES’。没辙,居然尝试把MySQL的密码也改成'YES',疯了...我是疯子。任意键在哪儿呢...

  USE mysql

  UPDATE uesr SET password='YES' where user='root' AND host='localhost';

  FLUSH PRIVILEGES;

  退出控制台后就再进不去了。

  mysql -u root -p

  mysql -h localhost -u root -p

  都不行,出现错误:

  "Host 'localhost' is not allowed to connect to this MySQL server."

  二、方法

  首先停止mysql服务:

  sc stop mysql

  然后:

  mysqld --skip-grant-tables

  另开一个终端,继续

  mysqlcheck --check-upgrade --all-databases --auto-repair

  然后再输入

  mysql

  就可以进入MySQL控制台了。这样进去以后使用SELECT语句会发现密码使用的是明文:'YES',哈哈,我真是个疯子。

  三、问题

  以上进去控制台后并不能执行账户维护工作。正确的方法为:

  mysql -u root

  然后使用以下语句将密码还原为 root 的 HASH 值:

  UPDATE uesr SET password=PASSWORD('YES') where user='root' AND host='localhost';

  然后,mysqld --skip-grant-tables 这个命令似乎只可以在本地运行。

  如果mysql服务无法正常停止,使用命令:mysqladmin -u root shutdown


上一篇:MySQL 重装笔记 下一篇:完全卸载MYSQL

评论总数:0 [ 查看全部 ] 网友评论


关于我们隐私版权广告服务友情链接联系我们网站地图