Linux下MySQL忘记密码的解决方法
1.先停止MySQL服务
sudo systemctl stop mysql
2.用MySQL安全命令启动,跳过权限表和网络
sudo mysqld_safe --skip-grant-tables --skip-networking &
末尾的&符号的作用是让进程在后台运行,可以让用户继续输入命令。
执行此命令后,就可以使用#mysql -u root免密登录了。
3.如果输入该命令后返回以下错误提示
2018-02-12T08:57:39 mysqld_safe Directory '/var/run/mysqld' for UNIX
socket file don't exists. mysql -u root ERROR 2002 (HY000): Can't connect to local MySQL server through socket
'/var/run/mysqld/mysqld.sock' (2) [1]+ Exit 1
# 创建MySQL服务目录
sudo mkdir /var/run/mysqld
# 修改该目录的读写权限
sudo chown mysql: /var/run/mysqld
4.运行第2点的命令
5.运行mysql -u root命令免密登录MySQL。
mysql> FLUSH PRIVILEGES;
# 对于MySQL 5.7.6及以上版本
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'new_password';
# 对于MySQL 5.7.5及以下版本
mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('new_password');
# 如果以上命令报错,就运行以下命令
mysql> UPDATE mysql.user SET authentication_string=PASSWORD('new_password') WHERE User='root' AND Host='localhost';
6.停止该安全服务,用kill命令终止进程
sudo kill `cat /var/run/mysqld/mysqld.pid`
# 如果命令报错,就运行以下命令
sudo pkill mysql
7.重启正常的MySQL服务
sudo systemctl start mysql
作者:Clotho_Lee
来源链接:https://www.cnblogs.com/live41/p/14236527.html
版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。
2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。