最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
MySQL 8.0安装后怎样重置root用户密码?
时间:2026-06-24 09:01:03 编辑:袖梨 来源:一聚教程网
MySQL 8.0安装后忘掉root密码,不能靠配置文件改password或客户端操作,必须绕过认证:首选查错误日志获取临时密码(Linux用sudo grep 'temporary password' /var/log/mysqld.log,macOS查/usr/local/var/mysql/*.err,Windows查C:ProgramDataMySQLMySQL Server 8.0Data*.err),日志丢失则用--skip-grant-tables(Windows需加--shared-memory)或--init-file方式重置。
直接告诉你结论:MySQL 8.0安装后忘掉root密码,**不能靠配置文件改 password=xxx,也不能用客户端工具连上再操作**——因为根本连不进去。必须绕过认证流程,要么从错误日志里捞出初始密码(最轻量),要么用--skip-grant-tables或--init-file启动 mysqld 手动重置。
怎么找安装时生成的临时 root 密码?
这是首选方案,前提是错误日志没被清理。MySQL 8.0首次初始化会把临时密码写进错误日志,不是控制台输出,也不是安装向导界面弹窗。
- Linux:执行
sudo grep 'temporary password' /var/log/mysqld.log(路径也可能是/var/log/mysql/error.log) - macOS(Homebrew):查
/usr/local/var/mysql/*.err,运行grep 'temporary password' /usr/local/var/mysql/*.err - Windows:打开隐藏文件夹
C:ProgramDataMySQLMySQL Server 8.0Data*.err,用记事本或 PowerShell 搜索temporary password - 如果用
mysqld --initialize --user=mysql手动初始化过,密码一定出现在该命令的 stderr 输出里,或同一目录下的 err 文件中
找不到日志?别硬翻,直接进下一步。删日志或重装会丢数据,完全没必要。
用 --skip-grant-tables 启动失败怎么办?
常见于 Windows 或启用了 caching_sha2_password 插件、binlog 压缩等配置的环境。mysqld --skip-grant-tables 单独运行大概率崩溃或报错 TCP/IP, --shared-memory, or --named-pipe should be configured。
- Windows 必须加
--shared-memory(推荐)或--enable-named-pipe,例如:mysqld --defaults-file="C:ProgramDataMySQLMySQL Server 8.0my.ini" --shared-memory --skip-grant-tables - Linux/macOS 若崩溃,先看
error.log是否提示插件冲突;可临时在配置中加binlog_checksum=NONE再试 - 更稳妥的替代是
--init-file方式:新建一个 SQL 文件(如/tmp/reset.sql),内容只有一行:ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPass123';;停服务后执行mysqld --init-file=/tmp/reset.sql启动一次即可
免密登录后改密码为什么还登不上?
常见现象:执行了 ALTER USER,退出再 mysql -u root -p 还是报 ERROR 1045 (28000)。问题往往出在 host 匹配、字段残留或刷新遗漏。
- MySQL 8.0 的 root 用户默认是
'root'@'localhost',不是'root'@'127.0.0.1'或'root'@'%';登录时 host 必须严格匹配,否则仍走旧认证逻辑 - 执行
ALTER USER前,建议先清空authentication_string字段:UPDATE user SET authentication_string = '' WHERE user = 'root' AND host = 'localhost';(注意 USE mysql;) -
FLUSH PRIVILEGES;必须执行,否则新密码不会加载进内存权限缓存 - 改完密码后,一定要终止那个卡住的
mysqld --skip-grant-tables进程(Ctrl+C),并确认配置文件里没有残留skip_grant_tables=1—— 否则下次启动仍是无密码模式
最易被忽略的点:MySQL 8.0+ 不再支持 PASSWORD() 函数,也不接受直接 UPDATE authentication_string 字段的哈希值。必须用 ALTER USER ... IDENTIFIED BY,且密码要满足默认策略(至少 8 位,含大小写字母、数字、特殊字符)。临时密码只出现一次,错过就得走恢复流程。
相关文章
- 《和平精英》火箭少女皮肤怎么获得-火箭少女皮肤价格解析 06-25
- Vivacut怎么设置比例 06-25
- hive archive数据迁移如何进行 06-25
- hive archive能实现数据权限管理吗 06-25
- hive archive 如何执行数据统计 06-25
- hive archive能实现数据搜索吗 06-25