Mysql 版本升级-二进制安装方式

8.0.20 -8.0.40

总体参考见下

fw_error_www

前置环境说明

glibc 版本,安装mysql二进制文件时需要匹配,安装的版本只能比系统的低

shell 复制代码
ldd --version

# 查看库的位置
ldd `which top` | grep "libc.so"

逻辑备份

卸载旧版本相关数据(注意,如果不存在时才卸载)谨慎操作

shell 复制代码
yum list installed | grep mariadb
yum list installed | grep mysql
# 如果是刚装的centos 一般有 mariadb

注意这里的 glibc 版本,需要低于机器上的版本

shell 复制代码
## 安装部分参考语句
tar xvf mysql-8.0.20-linux-glibc2.12-x86_64.tar.xz -C /usr/local

# 创建 Mysql 相关的用户
groupadd mysql
useradd -r -g mysql -s /bin/false mysql

# 创建 mysql 的数据文件夹
cd /usr/local/mysql
mkdir data
chown mysql:mysql data
chmod 750 data

# /etc/my.cnf 注意这个配置文件如果有,需要删除,或者重新配置,一般会有
# 初始化
bin/mysqld --initialize --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql --console
# 可选
cp support-files/mysql.server /etc/init.d/mysql
service mysql start

./bin/mysql -uroot -p
# 可选 设置 mysql 的指令 到 /etc/profile
echo 'export PATH=$PATH:/usr/local/mysql/bin' >> /etc/profile
# 修改密码
ALTER user 'root'@'localhost' IDENTIFIED BY 'your new password';
# 或者
ALTER USER USER() IDENTIFIED BY 'your new password';

## 升级部分参考语句
# 设置参数,保证数据完整性
SET GLOBAL innodb_fast_shutdown=0;    # 设置innodb_fast_shutdown
SHOW GLOBAL VARIABLES LIKE '%innodb_fast_shutdown%'; 

# 备份
bin/mysqldump -u root -p --add-drop-table --routines --events --all-databases --force > /root/data-for-upgrade.sql
# 关闭
bin/mysqladmin -u root -p shutdown
# 启动
bin/mysqld_safe --user=mysql --datadir=/usr/local/mysql/data & 
# 恢复
bin/mysql -u root -p --force < /root/data-for-upgrade.sql
# 重新启动并执行升级,观察日志成功后重启
bin/mysqld_safe --user=mysql --datadir=/usr/local/mysql/data --upgrade=FORCE & 

小结

老版本:设置关闭参数->备份->关闭->文件夹移动

新版本: 安装->文件夹移动->创建新的数据文件->使用新数据文件夹初始化->使用新数据文件夹启动->登录修改密码->恢复数据库文件->关闭->更新模式启动->观察日志成功后关闭->再次正常模式启动

inplace 备份

前置安装过程相同,不需要备份sql文件

用新 mysql,指定原来的data文件夹启动即可,需要注意文件夹下文件的权限,可能存在子文件权限不对的情况,使用 chrown -R 重置

或者复制的时候注意使用完全复制 -ap

在 8.0.16 之后,无需更多操作,如果是之前需要手动执行升级

shell 复制代码
mysql_upgrade -u root -p
# 关闭后再重启即可

小结

老版本: 设置关闭参数->关闭

新版本: 使用老数据文件夹启动->观察日志等待完成->重启

相关推荐
网硕互联的小客服24 分钟前
MYSQL数据库和MSSQL数据库有什么区别?分别适用于什么脚本程序?
数据库·mysql·sqlserver
计算机毕设匠心工作室1 小时前
【python大数据毕设实战】全球大学排名数据可视化分析系统、Hadoop、计算机毕业设计、包括数据爬取、数据分析、数据可视化、机器学习、实战教学
后端·python·mysql
千寻技术帮1 小时前
10413_基于Springboot的智慧养老院管理系统
spring boot·mysql·源码·安装·文档·ppt·养老院
我的offer在哪里3 小时前
MySQL 底层文件的备份与恢复(分「文本类文件」「二进制核心文件」,附全场景实操)
数据库·mysql
小张程序人生5 小时前
MySQL一主一从搭建详细讲解
mysql
默恋~微凉5 小时前
Mysql 备份与还原
数据库·mysql
大锦终5 小时前
【MySQL】索引
数据库·mysql
星环处相逢6 小时前
MySQL MHA 全解析与实战部署指南
数据库·mysql
qq_12498707536 小时前
基于springboot+vue+mysql的校园博客系统(源码+论文+部署+安装)
java·vue.js·spring boot·mysql·毕业设计
runfarther6 小时前
mysql_mcp_server部署及应用案例
linux·mysql·centos·mcp