Ubuntu系统忘记mysql root密码

环境

Ubuntu

情景

忘记mysql root用户密码,现在需要重置root用户密码

解决

1、停止mysql服务

$ service mysql stop
2、修改my.cnf文件
# 查找my.cnf文件在哪里
$ find / -name my.cnf
/var/lib/dpkg/alternatives/my.cnf
/etc/alternatives/my.cnf
/etc/mysql/my.cnf

# 修改my.cnf文件,在文件新增 skip-grant-tables,在启动mysql时不启动grant-tables,授权表
$ vim /etc/mysql/my.cnf
[mysqld]
skip-grant-tables
3、启动mysql服务
$ service mysql restart
4、更改mysql root用户密码
$ mysql

# 选择mysql数据库
mysql> use mysql;

# 更改user表中root用户密码
mysql> update user set authentication_string=PASSWORD("new_pass") where user='root';

# 注意:可能不同的数据库版本密码的字段名称不一样
# 我的数据库版本是5.7.21,user表中的密码字段是:authentication_string
mysql> select version();
+-------------------------+
| version()               |
+-------------------------+
| 5.7.21-0ubuntu0.16.04.1 |
+-------------------------+
1 row in set (0.00 sec)

# 可以通过以下命令查看user表的密码字段名称
mysql> show create table user\G;
5、再次修改my.cnf文件

需要把my.cnf配置文件改回去,我们把skip-grant-tables注释掉就可以了

$ vim /etc/mysql/my.cnf
[mysqld]
# skip-grant-tables
6、再次重启mysql
$ service mysql restart

# 现在我们可以用新root密码登录mysql了
$ mysql -u root -p
  • 2
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值