mysql 5.7.9 初始密码_更改密码后无法登录mysql 5.7.9

这篇博客介绍了如何在MySQL 5.7.10及之后的版本中,由于systemd取代了mysqld_safe来管理MySQL服务,如何通过设置环境变量来启动MySQL并重置root用户的密码。步骤包括停止服务,设置启动选项,更新user表,刷新权限,然后正常启动MySQL。特别指出,从5.7.6版开始,对于RPM分发的MySQL,不再需要mysqld_safe。
摘要由CSDN通过智能技术生成

自早期版本的mySQL(我使用5.7.10)以来,有两件事发生了变化:

systemd 现在用来照顾mySQL而不是 mysqld_safe (这就是我收到 -bash: mysqld_safe: command not found 错误的原因 - 它没有安装)

user 表结构已更改 .

因此,要重置root密码,您仍然可以使用 --skip-grant-tables 选项启动mySQL并更新 user 表,但是如何更改它 .

1. Stop mysql:

systemctl stop mysqld

2. Set the mySQL environment option

systemctl set-environment MYSQLD_OPTS="--skip-grant-tables"

3. Start mysql usig the options you just set

systemctl start mysqld

4. Login as root

mysql -u root

5. Update the root user password with these mysql commands

mysql> UPDATE mysql.user SET authentication_string = PASSWORD('MyNewPassword')

-> WHERE User = 'root' AND Host = 'localhost';

mysql> FLUSH PRIVILEGES;

mysql> quit

6. Stop mysql

systemctl stop mysqld

7. Unset the mySQL envitroment option so it starts normally next time

systemctl unset-environment MYSQLD_OPTS

8. Start mysql normally:

systemctl start mysqld

Try to login using your new password:

7. mysql -u root -p

Reference

注意从MySQL 5.7.6开始,对于使用RPM分发的MySQL安装,服务器启动和关闭由systemd在几个Linux平台上管理 . 在这些平台上,不再安装mysqld_safe,因为它是不必要的 . 有关更多信息,请参见第2.5.10节“使用systemd管理MySQL服务器” .

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值