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
# 关闭后再重启即可

小结

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

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

相关推荐
AAA修煤气灶刘哥6 小时前
后端人速藏!数据库PD建模避坑指南
数据库·后端·mysql
程序新视界7 小时前
学习MySQL绕不开的两个基础概念:聚集索引与非聚集索引
mysql
RestCloud10 小时前
跨境数据传输:ETL如何处理时区与日期格式差异
mysql·api
得物技术13 小时前
MySQL单表为何别超2000万行?揭秘B+树与16KB页的生死博弈|得物技术
数据库·后端·mysql
xiaok14 小时前
mysql中怎么创建一个可控权限数据库账号密码给到开发者
mysql
ByteBlossom17 小时前
MySQL 面试场景题之如何处理 BLOB 和CLOB 数据类型?
数据库·mysql·面试
玉衡子17 小时前
九、MySQL配置参数优化总结
java·mysql
-Xie-18 小时前
Mysql杂志(十六)——缓存池
数据库·mysql·缓存
玉衡子18 小时前
八、MySQL全局优化总结&MySQL8新特性
java·mysql
计算机毕业设计木哥19 小时前
计算机毕设选题推荐:基于Java+SpringBoot物品租赁管理系统【源码+文档+调试】
java·vue.js·spring boot·mysql·spark·毕业设计·课程设计