upgrade mysql 8.0 from 5.7 inplace

本文记录了一次MySQL服务器启动失败的经历,详细描述了错误信息,包括优化器成本常量表无法打开、未知变量、权限系统初始化失败等问题。通过重新初始化数据库和清理数据目录,最终解决了启动问题。
部署运行你感兴趣的模型镜像

Sep 07 07:39:52 ntgmysql06.ap.acxiom.net mysqld[72973]: 2019-09-06T23:39:52.986257Z 0 [Warning] [MY-010441] [Server] Failed to open optimizer cost constant tables
Sep 07 07:39:52 ntgmysql06.ap.acxiom.net mysqld[72973]: 2019-09-06T23:39:52.986404Z 0 [ERROR] [MY-013129] [Server] A message intended for a client cannot ...'t exist
Sep 07 07:39:52 ntgmysql06.ap.acxiom.net mysqld[72973]: 2019-09-06T23:39:52.986419Z 0 [Warning] [MY-013129] [Server] A message intended for a client canno...inition.
Sep 07 07:39:52 ntgmysql06.ap.acxiom.net mysqld[72973]: 2019-09-06T23:39:52.986505Z 0 [ERROR] [MY-000067] [Server] unknown variable 'query_cache_type=0'.
Sep 07 07:39:54 ntgmysql06.ap.acxiom.net mysqld[72973]: 2019-09-06T23:39:52.986788Z 0 [ERROR] [MY-010119] [Server] Aborting
 

need to disable that option;

try to start service again:

Sep 07 07:58:56 ntgmysql06.ap.acxiom.net mysqld[74069]: 2019-09-06T23:58:56.455603Z 0 [ERROR] [MY-013129] [Server] A message intended for a client cannot be sent there as no client-session
Sep 07 07:58:56 ntgmysql06.ap.acxiom.net mysqld[74069]: 2019-09-06T23:58:56.455617Z 0 [Warning] [MY-013129] [Server] A message intended for a client cannot be sent there as no client-sessio
Sep 07 07:58:56 ntgmysql06.ap.acxiom.net mysqld[74069]: 2019-09-06T23:58:56.456026Z 0 [ERROR] [MY-010326] [Server] Fatal error: Can't open and lock privilege tables: Table 'mysql.user' does
Sep 07 07:58:56 ntgmysql06.ap.acxiom.net mysqld[74069]: 2019-09-06T23:58:56.456095Z 0 [ERROR] [MY-010952] [Server] The privilege system failed to initialize correctly. For complete instruct
Sep 07 07:58:57 ntgmysql06.ap.acxiom.net mysqld[74069]: 2019-09-06T23:58:56.456424Z 0 [ERROR] [MY-010119] [Server] Aborting
Sep 07 07:58:57 ntgmysql06.ap.acxiom.net mysqld[74069]: 2019-09-06T23:58:57.499797Z 0 [System] [MY-010910] [Server] /usr/sbin/mysqld: Shutdown complete (mysqld 8.0.17)  MySQL Community Serv
Sep 07 07:58:57 ntgmysql06.ap.acxiom.net systemd[1]: mysqld.service: main process exited, code=exited, status=1/FAILURE
Sep 07 07:58:57 ntgmysql06.ap.acxiom.net systemd[1]: Failed to start MySQL Server.
Sep 07 07:58:57 ntgmysql06.ap.acxiom.net systemd[1]: Unit mysqld.service entered failed state.
 

-----------------------

mysqld --initialize-insecure
2019-09-07T00:05:56.474696Z 0 [System] [MY-013169] [Server] /usr/sbin/mysqld (mysqld 8.0.17) initializing of server in progress as process 74454
2019-09-07T00:05:56.476577Z 0 [ERROR] [MY-010457] [Server] --initialize specified but the data directory has files in it. Aborting.
2019-09-07T00:05:56.476588Z 0 [ERROR] [MY-013236] [Server] The designated data directory /var/lib/mysql/ is unusable. You can remove all files that the server added to it.
2019-09-07T00:05:56.476638Z 0 [ERROR] [MY-010119] [Server] Aborting
2019-09-07T00:05:56.476863Z 0 [System] [MY-010910] [Server] /usr/sbin/mysqld: Shutdown complete (mysqld 8.0.17)  MySQL Community Server - GPL.


ok, now I have to move all mysql folder out:

$mv /var/lib/mysql /var/lib/mysql2
and run again, Bingo, good to go now~~

您可能感兴趣的与本文相关的镜像

ACE-Step

ACE-Step

音乐合成
ACE-Step

ACE-Step是由中国团队阶跃星辰(StepFun)与ACE Studio联手打造的开源音乐生成模型。 它拥有3.5B参数量,支持快速高质量生成、强可控性和易于拓展的特点。 最厉害的是,它可以生成多种语言的歌曲,包括但不限于中文、英文、日文等19种语言

<think>好的,我现在需要处理用户关于MySQL 5.7版本中'in-place'升级或操作的具体实现和注意事项的问题。首先,我需要明确用户的需求,他们可能是在计划将现有的MySQL 5.7实例升级到更高版本,比如8.0,或者进行其他in-place操作,比如配置调整。用户提到的是“in-place”相关的技术问题或功能需求,所以重点应该放在原地升级的过程、步骤以及需要注意的事项上。 接下来,我需要查阅提供的引用资料,看看有哪些相关信息。引用[1]和[3]都提到了MySQL 5.7升级到8.0的注意事项,特别是配置参数的调整,比如sql_mode、basedir、密码认证插件等。引用[2]虽然主要讲的是5.6到5.7的升级,但其中提到的参数变化也可能对5.78.0的升级有参考价值,比如sql_mode的严格模式、innodb参数的调整等。 首先,我应该整理出in-place升级的基本步骤。根据引用[3],升级过程包括备份、停止服务、替换二进制文件、启动并升级数据字典等步骤。同时,需要注意配置文件的调整,比如sql_mode中去掉不再支持的选项,如NO_AUTO_CREATE_USER,以及设置正确的认证插件和字符集。 然后,注意事项方面,引用[1]提到升级前需要检查版本兼容性,确保当前版本在支持升级的范围内。例如,MySQL 8.0可能要求从特定的5.7版本开始升级。此外,需要处理参数的变化,比如sql_mode中废弃的选项,这可能导致初始化失败。引用[2]中的参数调整,如show_compatibility_56和log_timestamps,虽然主要是针对5.6到5.7,但也可能在5.78.0的升级中有类似的问题,需要检查。 另外,密码认证插件的变更也是一个重点。MySQL 8.0默认使用caching_sha2_password,而5.7可能使用mysql_native_password。用户可能需要提前更新账户插件,或者在配置文件中指定默认使用旧插件,避免连接问题。 还需要考虑备份和回滚方案。即使进行in-place升级,也需要有完整的备份,以防升级失败时能够恢复。此外,测试环境的验证是必不可少的,尤其是在处理生产环境之前,应在测试环境中模拟升级过程,检查是否存在兼容性问题。 可能的问题包括升级过程中由于参数不兼容导致的启动失败,或者SQL模式变化引发的应用程序错误。例如,在引用[1]中提到的sql_mode问题导致初始化失败,用户需要提前清理不再支持的sql_mode选项。另外,引用[2]提到的show_compatibility_56参数可能影响状态信息的获取,这在升级后需要调整。 最后,应该总结这些步骤和注意事项,以清晰的逻辑呈现给用户,确保他们能够逐步执行,并避免常见陷阱。同时,生成的相关问题可以帮助用户进一步了解其他可能相关的主题,比如性能优化或兼容性测试方法。</think>### MySQL 5.7 in-place升级的实现步骤与注意事项 #### 一、in-place升级的实现步骤 1. **环境检查与兼容性验证** - 确认当前MySQL 5.7版本是否支持直接升级到目标版本(如MySQL 8.0)。例如,MySQL 8.0要求从5.7.13或更高版本升级[^1]。 - 使用`mysqlcheck --all-databases --check-upgrade`命令检查表兼容性。 2. **备份数据** - 全量备份数据库,包括系统表(如`mysql`库)和用户数据。 - 建议使用物理备份工具(如`mysqldump`或Percona XtraBackup)。 3. **停止MySQL服务** ```bash systemctl stop mysqld ``` 4. **替换MySQL二进制文件** - 卸载旧版本MySQL,安装新版本(如8.0),注意保留原数据目录(如`/var/lib/mysql`)[^3]。 5. **调整配置文件** - 修改`my.cnf`,移除废弃参数(如`NO_AUTO_CREATE_USER`),并添加新版本支持的参数。例如: ```ini [mysqld] sql_mode = "STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION" # 移除不支持的选项 default_authentication_plugin = mysql_native_password # 兼容旧客户端 character_set_server = utf8mb4 # 使用推荐字符集 ``` 6. **启动MySQL并升级系统表** ```bash systemctl start mysqld mysql_upgrade -u root -p # 自动更新数据字典和系统表 ``` 7. **验证与测试** - 检查错误日志`/var/log/mysqld.log`,确认无报错。 - 运行应用程序测试,验证SQL兼容性。 --- #### 二、关键注意事项 1. **参数兼容性问题** - **sql_mode**:MySQL 8.0废弃了部分模式(如`NO_AUTO_CREATE_USER`),需在配置文件中移除[^1]。 - **身份认证插件**:MySQL 8.0默认使用`caching_sha2_password`,若客户端不支持,需在配置中显式指定`mysql_native_password`[^3]。 2. **字符集与排序规则** - MySQL 8.0默认字符集为`utf8mb4`,排序规则为`utf8mb4_0900_ai_ci`。若需保持与5.7一致,需在配置中显式指定。 3. **系统表变更** - 升级后,`mysql.user`表的字段和权限模型可能发生变化,需检查用户权限是否正常[^3]。 4. **回滚策略** - 若升级失败,需从备份中恢复数据,并重新安装原版本MySQL二进制文件。 5. **复制环境特殊处理** - 主从复制环境中,需先升级从库,再升级主库,并确保版本兼容性(如避免跨大版本的复制)[^2]。 --- #### 三、常见问题与解决方案 - **启动失败**:检查错误日志中是否包含废弃参数(如`sql_mode`配置错误),需清理配置文件。 - **客户端连接失败**:确认身份认证插件是否兼容,必要时修改用户密码插件: ```sql ALTER USER 'user'@'host' IDENTIFIED WITH mysql_native_password BY 'password'; ``` --- 相关问题
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值