英文:
MySQL update 10.2 to 11.0 with yum issue (centos 7.9)
问题
切换 MariaDB 仓库版本时,升级到 11.0.1 后遇到错误。尝试以下解决方案:
- 进行手动升级,备份数据和配置,移除旧版本,安装新版本并运行
mysql_upgrade
。 - 或者回滚到 10.2 版本,但官方仓库已移除。可以尝试安装 10.3 版本。
- 你也尝试过切换到 10.3 仓库,但未成功。
目前 MariaDB 10.2.41 启动失败,需要进一步解决。
英文:
After I changed repo for Marinadb from 10.2 to 11 and launch yum update the server stack on error with not update/remove marinadb-server.
-bash-# yum -y update
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
Resolving Dependencies
--> Running transaction check
---> Package MariaDB-server.x86_64 0:10.2.41-1.el7.centos will be updated
---> Package MariaDB-server.x86_64 0:11.0.1-1.el7.centos will be an update
--> Finished Dependency Resolution
Dependencies Resolved
=============================================================================================================================================================
Package Arch Version Repository Size
=============================================================================================================================================================
Updating:
MariaDB-server x86_64 11.0.1-1.el7.centos mariadb 27 M
Transaction Summary
=============================================================================================================================================================
Upgrade 1 Package
Total download size: 27 M
Downloading packages:
No Presto metadata available for mariadb
MariaDB-server-11.0.1-1.el7.centos.x86_64.rpm | 27 MB 00:02:42
Running transaction check
Running transaction test
Transaction test succeeded
Running transaction
******************************************************************
A MySQL or MariaDB server package (MariaDB-server-10.2.41-1.el7.centos.x86_64) is installed.
Upgrading directly from MySQL 10.2 to MariaDB 11.0 may not
be safe in all cases. A manual dump and restore using mysqldump is
recommended. It is important to review the MariaDB manual's Upgrading
section for version-specific incompatibilities.
A manual upgrade is required.
- Ensure that you have a complete, working backup of your data and my.cnf
files
- Shut down the MySQL server cleanly
- Remove the existing MySQL packages. Usually this command will
list the packages you should remove:
rpm -qa | grep -i '^mysql-'
You may choose to use 'rpm --nodeps -ev <package-name>' to remove
the package which contains the mysqlclient shared library. The
library will be reinstalled by the MariaDB-shared package.
- Install the new MariaDB packages supplied by MariaDB Foundation
- Ensure that the MariaDB server is started
- Run the 'mysql_upgrade' program
This is a brief description of the upgrade process. Important details
can be found in the MariaDB manual, in the Upgrading section.
******************************************************************
error: %pre(MariaDB-server-11.0.1-1.el7.centos.x86_64) scriptlet failed, exit status 1
Error in PREIN scriptlet in rpm package MariaDB-server-11.0.1-1.el7.centos.x86_64
MariaDB-server-10.2.41-1.el7.centos.x86_64 was supposed to be removed but is not!
Verifying : MariaDB-server-10.2.41-1.el7.centos.x86_64 1/2
Verifying : MariaDB-server-11.0.1-1.el7.centos.x86_64 2/2
Failed:
MariaDB-server.x86_64 0:10.2.41-1.el7.centos MariaDB-server.x86_64 0:11.0.1-1.el7.centos
Complete!
When I try to remove old 10.2 it shows
-bash-# sudo yum remove MariaDB-server galera
Loaded plugins: fastestmirror
No Match for argument: galera
Resolving Dependencies
--> Running transaction check
---> Package MariaDB-server.x86_64 0:10.2.41-1.el7.centos will be erased
--> Finished Dependency Resolution
Dependencies Resolved
=============================================================================================================================================================
Package Arch Version Repository Size
=============================================================================================================================================================
Removing:
MariaDB-server x86_64 10.2.41-1.el7.centos @mariadb 117 M
Transaction Summary
=============================================================================================================================================================
Remove 1 Package
Installed size: 117 M
Is this ok [y/N]: y
Downloading packages:
Running transaction check
ERROR with transaction check vs depsolve:
MariaDB-server >= 11.0.0 is needed by (installed) MariaDB-server-compat-11.0.1-1.el7.centos.noarch
** Found 4 pre-existing rpmdb problem(s), 'yum check' output follows:
MariaDB-client-11.0.1-1.el7.centos.x86_64 has installed conflicts MariaDB-server < ('0', '11.0.0', None): MariaDB-server-10.2.41-1.el7.centos.x86_64
MariaDB-common-11.0.1-1.el7.centos.x86_64 has installed conflicts MariaDB-server < ('0', '10.6.1', None): MariaDB-server-10.2.41-1.el7.centos.x86_64
MariaDB-server-10.2.41-1.el7.centos.x86_64 has missing requires of galera
MariaDB-server-compat-11.0.1-1.el7.centos.noarch has missing requires of MariaDB-server >= ('0', '11.0.0', None)
Your transaction was saved, rerun it with:
yum load-transaction /tmp/yum_save_tx.2023-04-10.16-35.Pz_MRr.yumtx
How I can finish installation of version 11
or recover back to 10.2 (official repo removed)
or delete 11 and update to 10.3
or anything to resolve problem.
PS: Following commands do not work anymore:
-bash-# mysql
mysql: Deprecated program name. It will be removed in a future release, use '/usr/bin/mariadb' instead
ERROR 2002 (HY000): Can't connect to local server through socket '/var/lib/mysql/mysql.sock' (2)
-bash-# mysql_upgrade
-bash: mysql_upgrade: command not found
My OS: CentOS Linux release 7.9
I tried to change marinadb repo to 10.3 and then update but it does not work.
current mysql status:
-bash-# systemctl status mariadb.service
* mariadb.service - MariaDB 10.2.41 database server
Loaded: loaded (/usr/lib/systemd/system/mariadb.service; enabled; vendor preset: disabled)
Drop-In: /etc/systemd/system/mariadb.service.d
`-migrated-from-my.cnf-settings.conf
Active: failed (Result: exit-code) since 2023-04-10 08:54:36 MSK; 7h ago
Docs: man:mysqld(8)
https://mariadb.com/kb/en/library/systemd/
Process: 11167 ExecStart=/usr/sbin/mysqld $MYSQLD_OPTS --basedir=/usr $_WSREP_NEW_CLUSTER $_WSREP_START_POSITION (code=exited, status=203/EXEC)
Process: 11156 ExecStartPre=/bin/sh -c [ ! -e /usr/bin/galera_recovery ] && VAR= || VAR=`cd /usr/bin/..; /usr/bin/galera_recovery`; [ $? -eq 0 ] && systemctl set-environment _WSREP_START_POSITION=$VAR || exit 1 (code=exited, status=0/SUCCESS)
Process: 11154 ExecStartPre=/bin/sh -c systemctl unset-environment _WSREP_START_POSITION (code=exited, status=0/SUCCESS)
Main PID: 11167 (code=exited, status=203/EXEC)
Help please No rush but need to resolve.
答案1
得分: 0
抱歉,我猜想 Stackoverflow 对类似问题也起到了作用。很高兴知道只应添加与编程相关的问题。
帮助我恢复到以前版本的方法:
-
从上面的日志中删除 Galera 的确切版本:
sudo yum remove galera-4-26.4.14-1.el7.centos.x86_64
-
从存档中安装实际的 10.2.41 版 galera:
yum install -y https://archive.mariadb.org/yum/10.2.41/centos7-amd64/rpms/galera-25.3.34-1.el7.centos.x86_64.rpm
-
通过提供日志上显示的完整软件包名称来删除 MariaDB 11 软件包。
sudo yum remove MariaDB-server-compat-11.0.1-1.el7.centos.noarch
sudo yum remove MariaDB-common-11.0.1-1.el7.centos.x86_64
sudo yum remove MariaDB-client-11.0.1-1.el7.centos.x86_64
-
从存档中重新安装 10.2 版:
yum install -y https://archive.mariadb.org/yum/10.2.41/centos7-amd64/rpms/MariaDB-server-10.2.41-1.el7.centos.x86_64.rpm
-
启动 mariadb 10.2
systemctl start mariadb
英文:
Sorry, I guess Stackoverflow works for similar the issues as well. Good to know that only programming related question should be added.
What helps for me to recover back previous version:
-
Remove Galera exact from the logs above:
sudo yum remove galera-4-26.4.14-1.el7.centos.x86_64
-
Install actual galera for 10.2.41 from archive:
yum install -y https://archive.mariadb.org/yum/10.2.41/centos7-amd64/rpms/galera-25.3.34-1.el7.centos.x86_64.rpm
-
remove MariaDB 11 packages by provide full package names as shows on logs above.
sudo yum remove MariaDB-server-compat-11.0.1-1.el7.centos.noarch
sudo yum remove MariaDB-common-11.0.1-1.el7.centos.x86_64
sudo yum remove MariaDB-client-11.0.1-1.el7.centos.x86_64
-
Install back 10.2 from archive
yum install -y https://archive.mariadb.org/yum/10.2.41/centos7-amd64/rpms/MariaDB-server-10.2.41-1.el7.centos.x86_64.rpm
-
Launch mariadb 10.2
systemctl start mariadb
通过集体智慧和协作来改善编程学习和解决问题的方式。致力于成为全球开发者共同参与的知识库,让每个人都能够通过互相帮助和分享经验来进步。
评论