实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式)

这篇具有很好参考价值的文章主要介绍了实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。


💖The Begin💖点点关注,收藏不迷路💖

实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式),# Linux运维笔记,# 数据库--mysql篇,mysql,运维,mysql5. 7升级8.2,msyql rpm方式升级

注:本文在测试环境升级测试,建议先在测试环境验证。mysql-5.7.42为rpm安装,所以用rpm方式升级

1、升级准备

1、数据备份:在升级之前,务必对当前的 MySQL 5.7 数据库进行完整备份,以防止数据丢失或损坏。确保备份文件的安全存储,并测试其可恢复性。

2、安全性考虑:建议在测试环境中进行升级测试,以模拟真实场景并检测潜在问题。这有助于减少生产环境中的不确定性和风险。

1、使用mysql-shell 检查工具检查兼容性

下载地址:https://downloads.mysql.com/archives/shell/

实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式),# Linux运维笔记,# 数据库--mysql篇,mysql,运维,mysql5. 7升级8.2,msyql rpm方式升级

上传mysql-shell:

实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式),# Linux运维笔记,# 数据库--mysql篇,mysql,运维,mysql5. 7升级8.2,msyql rpm方式升级

安装 mysql-shell rpm 软件包::

rpm -Uvh mysql-shell-8.2.0-1.el7.x86_64.rpm --force --nodeps

查看 mysql-shel安装版本:

mysqlsh --version

实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式),# Linux运维笔记,# 数据库--mysql篇,mysql,运维,mysql5. 7升级8.2,msyql rpm方式升级

检查该版本是否可以升级到MySQL 8.2.0:

mysqlsh -uroot -p -S /var/lib/mysql/mysql.sock -e "util.checkForServerUpgrade()"

检查结果报告:

[root@zyl-server ~]# mysqlsh -uroot -p -S /var/lib/mysql/mysql.sock -e "util.checkForServerUpgrade()"
Please provide the password for 'root@/var%2Flib%2Fmysql%2Fmysql.sock': ********(zyl@2024Save password for 'root@/var%2Flib%2Fmysql%2Fmysql.sock'? [Y]es/[N]o/Ne[v]er (default No): Y
The MySQL server at /var%2Flib%2Fmysql%2Fmysql.sock, version 5.7.42 - MySQL
Community Server (GPL), will now be checked for compatibility issues for
upgrade to MySQL 8.2.0...

1) Usage of old temporal type
  No issues found

2) MySQL 8.0 syntax check for routine-like objects
  No issues found

3) Usage of db objects with names conflicting with new reserved keywords
  No issues found

4) Usage of utf8mb3 charset
  No issues found

5) Table names in the mysql schema conflicting with new tables in 8.0
  No issues found

6) Partitioned tables using engines with non native partitioning
  No issues found

7) Foreign key constraint names longer than 64 characters
  No issues found

8) Usage of obsolete MAXDB sql_mode flag
  No issues found

9) Usage of obsolete sql_mode flags
  Notice: The following DB objects have obsolete options persisted for
    sql_mode, which will be cleared during upgrade to 8.0.
  More information:
    https://dev.mysql.com/doc/refman/8.0/en/mysql-nutshell.html#mysql-nutshell-removals

  db_zyl.InsertMultipleUsers - PROCEDURE uses obsolete NO_AUTO_CREATE_USER
    sql_mode
  global system variable sql_mode - defined using obsolete NO_AUTO_CREATE_USER
    option

10) ENUM/SET column definitions containing elements longer than 255 characters
  No issues found

11) Usage of partitioned tables in shared tablespaces
  No issues found

12) Circular directory references in tablespace data file paths
  No issues found

13) Usage of removed functions
  No issues found

14) Usage of removed GROUP BY ASC/DESC syntax
  No issues found

15) Removed system variables for error logging to the system log configuration
  To run this check requires full path to MySQL server configuration file to be specified at 'configPath' key of options dictionary
  More information:
    https://dev.mysql.com/doc/relnotes/mysql/8.0/en/news-8-0-13.html#mysqld-8-0-13-logging

16) Removed system variables
  To run this check requires full path to MySQL server configuration file to be specified at 'configPath' key of options dictionary
  More information:
    https://dev.mysql.com/doc/refman/8.0/en/added-deprecated-removed.html#optvars-removed

17) System variables with new default values
  To run this check requires full path to MySQL server configuration file to be specified at 'configPath' key of options dictionary
  More information:
    https://mysqlserverteam.com/new-defaults-in-mysql-8-0/

18) Zero Date, Datetime, and Timestamp values
  No issues found

19) Schema inconsistencies resulting from file removal or corruption
  No issues found

20) Tables recognized by InnoDB that belong to a different engine
  No issues found

21) Issues reported by 'check table x for upgrade' command
  No issues found

22) New default authentication plugin considerations
  Warning: The new default authentication plugin 'caching_sha2_password' offers
    more secure password hashing than previously used 'mysql_native_password'
    (and consequent improved client connection authentication). However, it also
    has compatibility implications that may affect existing MySQL installations. 
    If your MySQL installation must serve pre-8.0 clients and you encounter
    compatibility issues after upgrading, the simplest way to address those
    issues is to reconfigure the server to revert to the previous default
    authentication plugin (mysql_native_password). For example, use these lines
    in the server option file:
    
    [mysqld]
    default_authentication_plugin=mysql_native_password
    
    However, the setting should be viewed as temporary, not as a long term or
    permanent solution, because it causes new accounts created with the setting
    in effect to forego the improved authentication security.
    If you are using replication please take time to understand how the
    authentication plugin changes may impact you.
  More information:
    https://dev.mysql.com/doc/refman/8.0/en/upgrading-from-previous-series.html#upgrade-caching-sha2-password-compatibility-issues
    https://dev.mysql.com/doc/refman/8.0/en/upgrading-from-previous-series.html#upgrade-caching-sha2-password-replication

23) Columns which cannot have default values
  No issues found

24) Check for invalid table names and schema names used in 5.7
  No issues found

25) Check for orphaned routines in 5.7
  No issues found

26) Check for deprecated usage of single dollar signs in object names
  No issues found

27) Check for indexes that are too large to work on higher versions of MySQL
Server than 5.7
  No issues found

28) Check for deprecated '.<table>' syntax used in routines.
  No issues found

29) Check for columns that have foreign keys pointing to tables from a diffrent
database engine.
  No issues found

Errors:   0
Warnings: 1
Notices:  2

NOTE: No fatal errors were found that would prevent an upgrade, but some potential issues were detected. Please ensure that the reported issues are not significant before upgrading.
[root@zyl-server ~]# 

检查结果显示:

没有发现使用旧的时间类型的问题。
没有发现MySQL 8.0 语法检查问题。
没有发现与新保留关键字冲突的数据库对象使用问题。
没有发现使用utf8mb3字符集的问题。
没有发现mysql模式中的表名与MySQL 8.0中的新表冲突的问题。
没有发现使用非原生分区引擎的分区表的问题。
没有发现外键约束名称超过64个字符的问题。
没有发现使用已弃用MAXDB sql_mode标志的问题。
发现某些数据库对象具有过时的sql_mode选项,将在升级到8.0时清除。
没有发现ENUM/SET列定义中包含超过255个字符的元素的问题。
没有发现在共享表空间中使用分区表的问题。
没有发现循环目录引用的问题。
没有发现使用已删除函数的问题。
没有发现使用已删除的GROUP BY ASC/DESC语法的问题。
没有发现已删除的系统变量以进行错误日志记录的问题。
没有发现已删除的系统变量的问题。
检查到有新的默认值的系统变量。
没有发现零日期、日期时间和时间戳值的问题。
没有发现由于文件删除或损坏导致的模式不一致问题。
没有发现被InnoDB识别为属于不同引擎的表的问题。
没有发现通过'check table x for upgrade'命令报告的问题。
发现新的默认身份验证插件的注意事项。
没有发现不能具有默认值的列的问题。
没有发现在5.7中使用无效的表名和模式名的问题。
没有发现在5.7中存在的孤立例程的问题。
没有发现在对象名称中使用单个美元符号的已弃用用法的问题。
没有发现在高于MySQL 5.7版本的MySQL服务器上无法工作的太大的索引的问题。
没有发现在例程中使用已弃用的'.<table>'语法的问题。
没有发现具有指向来自不同数据库引擎的表的外键的列的问题。


总结:

错误:0
警告:1
注意事项:2

2、操作环境

1、查看当前数据库版本

mysql> select@@version;
+-----------+
| @@version |
+-----------+
| 5.7.42    |
+-----------+
1 row in set (0.00 sec)

mysql> 

2、操作系统版本

[root@zyl-server ~]#  cat /etc/redhat-release
CentOS Linux release 7.9.2009 (Core)
[root@zyl-server ~]# 
[root@zyl-server ~]# 

3、备份数据库、my.cnf文件,停止mysql服务(重要)

[root@zyl-server ~]# mysqldump -hlocalhost -uroot -p --all-databases > /home/db_back_2024.sql
Enter password: 
[root@zyl-server ~]# ll
total 1317800
-rw-------. 1 root  root       1419 Aug 30  2023 anaconda-ks.cfg
-rw-------. 1 root  root  453727744 Mar 13 19:40 image_mysql.tar
-rwxrwxrwx. 1 mysql mysql        58 Mar 17 16:39 init-file
drwxr-xr-x. 2 root  root         88 Mar 11 10:59 mynginx-app
-rw-r--r--. 1 root  root  447283712 Mar 13 19:24 mysql-5.7-container02.tar
-rw-r--r--. 1 root  root  447283712 Mar 13 19:23 mysql-5.7-container.tar
drwxr-xr-x. 9 mfs   mfs         186 Feb 28 20:38 nginx-1.24.0
-rw-r--r--. 1 root  root    1112471 Feb 28 20:37 nginx-1.24.0.tar.gz
[root@zyl-server ~]# cd /home/
[root@zyl-server home]# ll
total 876
-rw-r--r--. 1 root  root  890551 Mar 17 16:58 db_back_2024.sql
drwx------. 2 mfs   mfs       99 Feb 29 21:49 mfs
drwx------. 2 redis redis     99 Mar  3 02:43 redis
drwx------. 3 zyl   zyl     4096 Mar 16 13:47 zyl
[root@zyl-server home]# 

[root@zyl-server home]# cp /etc/my.cnf /home/5.7.37_my.cnf
[root@zyl-server home]# 
[root@zyl-server home]# 
[root@zyl-server home]# systemctl stop mysqld

4、上传、解压安装包

下载mysql8.2.0:

https://downloads.mysql.com/archives/community/

实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式),# Linux运维笔记,# 数据库--mysql篇,mysql,运维,mysql5. 7升级8.2,msyql rpm方式升级

创建"mysql8.2.0-bundle"的文件夹,用于存放解压文件。

mkdir mysql8.2.0-bundle

tar -xvf mysql-8.2.0-1.el7.x86_64.rpm-bundle.tar 

实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式),# Linux运维笔记,# 数据库--mysql篇,mysql,运维,mysql5. 7升级8.2,msyql rpm方式升级

5、查看已安装的mysql-5.7.42有关的包

列出系统中所有与 mysql 相关的 RPM 软件包。

rpm -qa|grep -i mysql

实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式),# Linux运维笔记,# 数据库--mysql篇,mysql,运维,mysql5. 7升级8.2,msyql rpm方式升级

6、升级、按顺序执行

[root@zyl-server mysql8.2.0-bundle]# rpm -Uvh mysql-community-server-8.2.0-1.el7.x86_64.rpm --force --nodeps
warning: mysql-community-server-8.2.0-1.el7.x86_64.rpm: Header V4 RSA/SHA256 Signature, key ID 3a79bd29: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:mysql-community-server-8.2.0-1.el################################# [ 50%]
Cleaning up / removing...
   2:mysql-community-server-5.7.42-1.e################################# [100%]
   
[root@zyl-server mysql8.2.0-bundle]# rpm -Uvh mysql-community-client-
mysql-community-client-8.2.0-1.el7.x86_64.rpm          mysql-community-client-plugins-8.2.0-1.el7.x86_64.rpm  
[root@zyl-server mysql8.2.0-bundle]# rpm -Uvh mysql-community-client-8.2.0-1.el7.x86_64.rpm --force --nodeps
warning: mysql-community-client-8.2.0-1.el7.x86_64.rpm: Header V4 RSA/SHA256 Signature, key ID 3a79bd29: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:mysql-community-client-8.2.0-1.el################################# [ 50%]
Cleaning up / removing...
   2:mysql-community-client-5.7.42-1.e################################# [100%]
   
[root@zyl-server mysql8.2.0-bundle]# rpm -Uvh mysql-community-libs-8.2.0-1.el7.x86_64.rpm --force --nodeps
warning: mysql-community-libs-8.2.0-1.el7.x86_64.rpm: Header V4 RSA/SHA256 Signature, key ID 3a79bd29: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:mysql-community-libs-8.2.0-1.el7 ################################# [ 50%]
Cleaning up / removing...
   2:mysql-community-libs-5.7.42-1.el7################################# [100%]
   
[root@zyl-server mysql8.2.0-bundle]#  rpm -Uvh mysql-community-common-8.2.0-1.el7.x86_64.rpm --force --nodeps
warning: mysql-community-common-8.2.0-1.el7.x86_64.rpm: Header V4 RSA/SHA256 Signature, key ID 3a79bd29: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:mysql-community-common-8.2.0-1.el################################# [ 50%]
Cleaning up / removing...
   2:mysql-community-common-5.7.42-1.e################################# [100%]
[root@zyl-server mysql8.2.0-bundle]# 

实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式),# Linux运维笔记,# 数据库--mysql篇,mysql,运维,mysql5. 7升级8.2,msyql rpm方式升级

7、升级验证

1、检查登录正常


systemctl start mysqld

mysql -u root -p



[root@zyl-server mysql8.2.0-bundle]# mysql -u root -p
Enter password: (zyl@2024)
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 12
Server version: 8.2.0 MySQL Community Server - GPL

Copyright (c) 2000, 2023, Oracle and/or its affiliates.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> 

2、检查升级版本

已由mysql-5.7.42 升级到 mysql-8.2.0 。

mysql> select@@version;
+-----------+
| @@version |
+-----------+
| 8.2.0     |
+-----------+
1 row in set (0.00 sec)

mysql> 

实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式),# Linux运维笔记,# 数据库--mysql篇,mysql,运维,mysql5. 7升级8.2,msyql rpm方式升级
3、检查数据

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| db_zyl             |
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
5 rows in set (0.00 sec)

mysql> use db_zyl;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A

Database changed
mysql> 
mysql> 
mysql> show tables;
+------------------+
| Tables_in_db_zyl |
+------------------+
| users            |
+------------------+
1 row in set (0.00 sec)

mysql> select * from users;
+----+----------+----------------------+-------------+---------------------+
| id | name     | email                | password    | created_at          |
+----+----------+----------------------+-------------+---------------------+
|  1 | John Doe | john.doe@example.com | password123 | 2024-03-15 00:11:46 |
|  2 | John Doe | john.doe@example.com | password123 | 2024-03-15 00:11:50 |
|  3 | John Doe | john.doe@example.com | password123 | 2024-03-15 00:11:52 |
|  4 | John Doe | john.doe@example.com | password123 | 2024-03-15 00:11:55 |
|  5 | John Doe | john.doe@example.com | password123 | 2024-03-15 00:11:56 |
+----+----------+----------------------+-------------+---------------------+
5 rows in set (0.00 sec)

mysql> 

实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式),# Linux运维笔记,# 数据库--mysql篇,mysql,运维,mysql5. 7升级8.2,msyql rpm方式升级

实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式),# Linux运维笔记,# 数据库--mysql篇,mysql,运维,mysql5. 7升级8.2,msyql rpm方式升级文章来源地址https://www.toymoban.com/news/detail-842237.html


💖The End💖点点关注,收藏不迷路💖

到了这里,关于实现:mysql-5.7.42 到 mysql-8.2.0 的升级(rpm方式)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Linux中安装mysql5.7.42学习笔记

    1. 首先,下载mysql5.7.42的安装包(下方是下载地址),选择红色框框的下载(注意的是,这个链接只提供5.7的版本下载,可能还会更新,不一定打开就是5.7.42的版本,后续可能会有43 ,44版本,但流程都是一样的)  (本文参考来源: (40条消息) Linux安装MySQL5.7及自启_linux启动

    2024年02月13日
    浏览(37)
  • 运维笔记之centos7安装mysql数据库

    如果使用的4.1以上版本的rpm的话,除了import mysql的公钥到个人用户的配置中,还需要import mysql的公钥到RPM的配置中

    2024年02月04日
    浏览(63)
  • Linux RPM包安装、卸载和升级(rpm命令)

    通常情况下,RPM 包采用系统默认的安装路径,所有安装文件会按照类别分散安装到表 1 所示的目录中。 表 1 RPM 包默认安装路径 安装路径 含 义 /etc/ 配置文件安装目录 /usr/bin/ 可执行的命令安装目录 /usr/lib/ 程序所使用的函数库保存位置 /usr/share/doc/ 基本的软件使用手册保存

    2024年02月15日
    浏览(50)
  • Linux RPM包安装、卸载和升级(rpm命令)详解

    下面讲解一下,如何使用 rpm 命令对 RPM 二进制包进行安装、卸载和升级操作。我们以安装 apache 程序为例。 通常情况下,RPM 包采用系统默认的安装路径,所有安装文件会按照类别分散安装到下表所示的目录中。 RPM 包默认安装路径 安装路径 含 义 /etc/ 配置文件安装目录 /u

    2024年02月14日
    浏览(58)
  • CentOS7下rpm包方式升级openssl到安全版本1.1.1q

    参考链接:https://cloud.tencent.com/developer/article/1767718 OpenSSL 是一个安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及SSL协议,并提供丰富的应用程序供测试或其它目的使用。 OpenSSL是Openssl团队的一个开源的能够实现安全套接层(SSLv2/v3)和安全传输

    2024年02月05日
    浏览(42)
  • Mysql漏洞处理之升级版本到5.7.42过程指导手册

    某次安全漏扫,发现MySQL大量漏洞,基于Mysql之用于内网,且版本确实有点旧,考虑升级,综合漏洞分析,只能升级到最新版5.7.42和8.0.33,现场环境:Mysql 5.7.28、5.7.20 和mysql:8.0.21 漏洞编号 漏洞描述 CVE-2023-21912 MySQL 5.7.41 版本及之前版本和 8.0.30 版本及之前版本的 Server: Secur

    2024年02月16日
    浏览(54)
  • 安装MySql(rpm方式安装)

    地址:https://dev.mysql.com/downloads/mysql/ 下载这个:mysql-8.0.35-1.el7.x86_64.rpm-bundle.tar 进入解压路径执行安装以下程序/依赖,必须依次安装 缺少net-tools 缺少libcrypto.so.10 缺少libncurses.so.5、libtinfo.so.5 mariadb被mysql取代 用临时密码登陆mysql,修改root密码 添加远程连接用户 赋予远程用户

    2024年01月17日
    浏览(29)
  • Mysql漏洞处理之升级版本到5.7.42/5.7.43过程指导手册

    某次安全漏扫,发现MySQL大量漏洞,基于Mysql之用于内网,且版本确实有点旧,考虑升级,综合漏洞分析,只能升级到最新版5.7.42和8.0.33,现场环境:Mysql 5.7.28、5.7.20 和mysql:8.0.21 漏洞编号 漏洞描述 CVE-2023-21912 MySQL 5.7.41 版本及之前版本和 8.0.30 版本及之前版本的 Server: Secur

    2024年02月13日
    浏览(43)
  • Linux常见命令 25 - RPM包安装、升级、卸载、查询、校验、提取

    目录 1. 包名与包全名 2. RPM安装 3. RPM包升级 4. RPM包卸载 5. 查询是否安装RPM包  6. RPM包校验 7.  RPM包中文件提取 1. 包名与包全名 包全名:操作的包是没有安装的软件包时,使用包全名,而且要注意路径 包名:操作已经安装的软件包时,使用包名。是搜索 /var/lib/rpm/ 中的数据

    2024年02月04日
    浏览(46)
  • 【linux升级ssh】 利用rpmbuild工具对ssh打包为rpm包进场安装升级

    rpmbuild命令用于创建软件的二进制包和源代码包。 官方文档:rpm.org - RPM Reference Manual rpmbuild 中文手册:rpmbuild 中文手册 [金步国] 使用rpmbuild将tar包打成rpm包 执行如下命令来生成rpmbuild的工作目录 SPEC撰写是打包RPM的核心,也算是最难的一步,好在我们可以从参照一个简单的模

    2024年02月15日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包