当前位置: 首页 >数据库 > Linux下MySQL忘记密码的解决方法

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),我们将第一时间核实后及时予以删除。





本文链接:https://www.javaclub.cn/database/118255.html

分享给朋友:

“Linux下MySQL忘记密码的解决方法” 的相关文章

MySQL数据库(基础) 2022年05月16日 21:54:19
mysql查询最新的一条记录 2022年06月06日 16:04:12
MySQL 查询指定时间范围内的数据 2022年06月06日 16:59:25
mysql 查询或 2022年06月07日 13:56:22
mysql的查询句 2022年06月09日 23:40:52
mysql 查询某字段最小的记录 2022年06月12日 13:41:31
MySQL查询优化 2022年06月14日 16:56:49
MySQL基本查询 2022年06月15日 12:06:53