一台服务器部署多个版本的MySQL,不会冲突吗?如何管理?

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介: 一台服务器部署多个版本的MySQL,不会冲突吗?如何管理?

⛳️ 1.安装包下载



官网链接

https://dev.mysql.com/downloads/mysql/

此次我们部署4个版本

75014fb78d024cd9b8448033e19be13e.png


⛳️ 2.安装部署


🐴 2.1 环境部署


[root@centos7 ~]# mkdir /soft --上传软件包

#初始化一个容器作为主机

docker run -d --name mysqlhost02 -h mysqlhost02

-p 232:22 -p 3506-3606:3506-3606

-v /sys/fs/cgroup:/sys/fs/cgroup

–privileged=true

–network=mynet --ip 172.18.12.9

centos:7.6.1810 /usr/sbin/init

[root@centos7 ~]# docker ps --查询容器

[root@centos7 ~]# docker update --restart=always mysqlhost02 --开机自启动

[root@centos7 ~]# docker exec -it mysqlhost02 bash


🐴 2.2 安装包拷到容器


#把安装包拷贝到容器里边

[root@mysqlhost02 /]# mkdir /soft

[root@centos7 soft]# docker cp mysql-5.5.62-linux-glibc2.12-x86_64.tar.gz mysqlhost02:/soft/

[root@centos7 soft]# docker cp mysql-5.6.48-linux-glibc2.12-x86_64.tar.gz mysqlhost02:/soft/

[root@centos7 soft]# docker cp mysql-5.7.30-linux-glibc2.12-x86_64.tar.gz mysqlhost02:/soft/

[root@centos7 soft]# docker cp mysql-8.0.19-linux-glibc2.12-x86_64.tar.xz mysqlhost02:/soft/


🐴 2.3 二进制方式安装 MySQL


[root@mysqlhost02 ~]# mkdir -p /usr/local/mysqlsoft
[root@mysqlhost02 soft]# tar -zxvf mysql-5.5.62-linux-glibc2.12-x86_64.tar.gz -C /usr/local/mysqlsoft
[root@mysqlhost02 soft]# tar -zxvf mysql-5.6.48-linux-glibc2.12-x86_64.tar.gz -C /usr/local/mysqlsoft
[root@mysqlhost02 soft]# tar -zxvf mysql-5.7.30-linux-glibc2.12-x86_64.tar.gz -C /usr/local/mysqlsoft
[root@mysqlhost02 soft]# tar -Jxf mysql-8.0.19-linux-glibc2.12-x86_64.tar.xz -C /usr/local/mysqlsoft
[root@mysqlhost02 soft]# cd /usr/local/mysqlsoft
[root@mysqlhost02 mysqlsoft]# du -sh ./*
752M    ./mysql-5.5.62-linux-glibc2.12-x86_64
1.2G    ./mysql-5.6.48-linux-glibc2.12-x86_64
2.5G    ./mysql-5.7.30-linux-glibc2.12-x86_64
2.5G    ./mysql-8.0.19-linux-glibc2.12-x86_64
#快捷方式创建
[root@mysqlhost02 /]# mkdir -p /usr/local/mysql55
[root@mysqlhost02 /]# mkdir -p /usr/local/mysql56
[root@mysqlhost02 /]# mkdir -p /usr/local/mysql57
[root@mysqlhost02 /]# mkdir -p  /usr/local/mysql80
ln -s /usr/local/mysqlsoft/mysql-5.5.62-linux-glibc2.12-x86_64 /usr/local/mysql55/mysql5562
ln -s /usr/local/mysqlsoft/mysql-5.6.48-linux-glibc2.12-x86_64 /usr/local/mysql56/mysql5648
ln -s /usr/local/mysqlsoft/mysql-5.7.30-linux-glibc2.12-x86_64 /usr/local/mysql57/mysql5730
ln -s /usr/local/mysqlsoft/mysql-8.0.19-linux-glibc2.12-x86_64 /usr/local/mysql80/mysql8019


[root@mysqlhost02 local]# ll



7cd273214e784c8dbfb93a6a76c32671.png
[root@mysqlhost02 mysql55]# ll
lrwxrwxrwx 1 root root 56 Feb 28 15:15 mysql5562 -> /usr/local/mysqlsoft/mysql-5.5.62-linux-glibc2.12-x86_64
[root@mysqlhost02 ~]# groupadd mysql
[root@mysqlhost02 ~]# useradd -r -g mysql mysql
[root@mysqlhost02 ~]# chown -R mysql.mysql /usr/local/mysqlsoft/
[root@mysqlhost02 ~]# cd /usr/local/mysqlsoft/
[root@mysqlhost02 mysqlsoft]# ll
drwxr-xr-x 13 mysql mysql 256 Feb 28 15:15 mysql-5.5.62-linux-glibc2.12-x86_64
drwxr-xr-x 13 mysql mysql 234 Feb 28 15:15 mysql-5.6.48-linux-glibc2.12-x86_64
drwxr-xr-x  9 mysql mysql 172 Feb 28 15:15 mysql-5.7.30-linux-glibc2.12-x86_64
drwxr-xr-x  9 mysql mysql 172 Feb 28 15:16 mysql-8.0.19-linux-glibc2.12-x86_64
--必须yum安装这个
yum install libaio  
--- 5.5、5.6 --MySQL 5.5、5.6 的二进制安装默认密码为空
/usr/local/mysql55/mysql5562/scripts/mysql_install_db --user=mysql \
--basedir=/usr/local/mysql55/mysql5562 --datadir=/usr/local/mysql55/mysql5562/data
-必须yum安装这个
yum -y install perl perl-devel
yum -y install autoconf
yum remove libnuma.so.1
yum -y install numactl.x86_64
/usr/local/mysql56/mysql5648/scripts/mysql_install_db --user=mysql \
--basedir=/usr/local/mysql56/mysql5648 --datadir=/usr/local/mysql56/mysql5648/data
-- MySQL 5.7.6 之后的版本初始化数据库不再使用 mysql_install_db(insecure为空密码)
/usr/local/mysql57/mysql5730/bin/mysqld --initialize-insecure --user=mysql \
--basedir=/usr/local/mysql57/mysql5730 --datadir=/usr/local/mysql57/mysql5730/data
/usr/local/mysql80/mysql8019/bin/mysqld --initialize-insecure --user=mysql \
--basedir=/usr/local/mysql80/mysql8019 --datadir=/usr/local/mysql80/mysql8019/data

🐴 2.4 环境变量创建


#环境变量创建

[root@mysqlhost02 ~]# echo “export PATH=$PATH:/usr/local/mysql80/mysql8019/bin” >> /root/.bashrc

[root@mysqlhost02 ~]# source /root/.bashrc

[root@mysqlhost02 ~]# mysqld_multi report


⛳️ 3.管理多实例


#/etc/my.cnf 管理多实例
[root@mysqlhost02 ~]# mkdir -p /usr/local/mysqlsoft/log/
[root@mysqlhost02 ~]# vi /etc/my.cnf
[mysqld_multi]
mysqld=/usr/local/mysql80/mysql8019/bin/mysqld_safe
mysqladmin=/usr/local/mysql80/mysql8019/bin/mysqladmin
log=/usr/local/mysqlsoft/log/mysqld_multi.log
user=root
password=root
[mysql]
default-character-set=utf8mb4
[mysqld55623506]
mysqld=/usr/local/mysql55/mysql5562/bin/mysqld_safe
mysqladmin=/usr/local/mysql55/mysql5562/bin/mysqladmin
port=3506
basedir=/usr/local/mysql55/mysql5562
datadir=/usr/local/mysql55/mysql5562/data
socket=/usr/local/mysql55/mysql5562/data/mysqls55623506.sock
server_id=55623506
log-bin
skip-name-resolve
character_set_server=utf8mb4
[mysqld56483507]
mysqld=/usr/local/mysql56/mysql5648/bin/mysqld_safe
mysqladmin=/usr/local/mysql56/mysql5648/bin/mysqladmin
port=3507
basedir=/usr/local/mysql56/mysql5648
datadir=/usr/local/mysql56/mysql5648/data
socket=/usr/local/mysql56/mysql5648/data/mysqls56483507.sock
server_id=56483507
log-bin
skip-name-resolve
character_set_server=utf8mb4
[mysqld57303508]
mysqld=/usr/local/mysql57/mysql5730/bin/mysqld_safe
mysqladmin=/usr/local/mysql57/mysql5730/bin/mysqladmin
port=3508
basedir=/usr/local/mysql57/mysql5730
datadir=/usr/local/mysql57/mysql5730/data
socket=/usr/local/mysql57/mysql5730/data/mysqls57303508.sock
server_id=57303508
log-bin
default-time-zone = '+8:00'
log_timestamps = SYSTEM
skip-name-resolve
character_set_server=utf8mb4
[mysqld80193509]
mysqld=/usr/local/mysql80/mysql8019/bin/mysqld_safe
mysqladmin=/usr/local/mysql80/mysql8019/bin/mysqladmin
port=3509
basedir=/usr/local/mysql80/mysql8019
datadir=/usr/local/mysql80/mysql8019/data
socket=/usr/local/mysql80/mysql8019/data/mysqls80193509.sock
default_authentication_plugin=mysql_native_password
server_id=80193509
log-bin
default-time-zone = '+8:00'
log_timestamps = SYSTEM
skip-name-resolve
character_set_server=utf8mb4


⛳️ 4.Mysql启动



[root@mysqlhost02 ~]# mysqld_multi report

ad2732aa1cf44c209b429091c5d31185.png

[root@mysqlhost02 ~]# mysqld_multi start 55623506
[root@mysqlhost02 ~]# mysqld_multi report
Reporting MySQL servers
MySQL server from group: mysqld55623506 is running
MySQL server from group: mysqld56483507 is not running
MySQL server from group: mysqld57303508 is not running
MySQL server from group: mysqld80193509 is not running
通过socket登陆
[root@mysqlhost02 ~]# ps -ef | grep mysql55
[root@mysqlhost02 ~]# mysql -uroot -p -S /usr/local/mysql55/mysql5562/data/mysqls55623506.sock
[root@mysqlhost02 ~]# ALTER USER 'root'@'localhost' IDENTIFIED WITH MYSQL_NATIVE_PASSWORD BY 'root';   --mysql8
注意:要设置密码,负责无法关闭
[root@mysqlhost02 ~]# mysqld_multi start 56483507,57303508
[root@mysqlhost02 ~]# mysqld_multi report                   
Reporting MySQL servers
MySQL server from group: mysqld55623506 is running
MySQL server from group: mysqld56483507 is running
MySQL server from group: mysqld57303508 is running
MySQL server from group: mysqld80193509 is not running
相关实践学习
自建数据库迁移到云数据库
本场景将引导您将网站的自建数据库平滑迁移至云数据库RDS。通过使用RDS,您可以获得稳定、可靠和安全的企业级数据库服务,可以更加专注于发展核心业务,无需过多担心数据库的管理和维护。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
7月前
|
存储 缓存 监控
MySQL服务器配置优化:my.cnf参数调优指南
本文深入解析了MySQL核心配置参数及性能优化技巧,涵盖内存结构、调优原则、存储引擎优化、查询性能优化等内容,通过实战案例帮助读者构建高性能MySQL服务器配置,解决常见的性能瓶颈问题。
|
6月前
|
存储 关系型数据库 MySQL
MySQL Docker 容器化部署全指南
MySQL是一款开源关系型数据库,广泛用于Web及企业应用。Docker容器化部署可解决环境不一致、依赖冲突问题,实现高效、隔离、轻量的MySQL服务运行,支持数据持久化与快速迁移,适用于开发、测试及生产环境。
898 4
|
11月前
|
Java 关系型数据库 MySQL
在Linux平台上进行JDK、Tomcat、MySQL的安装并部署后端项目
现在,你可以通过访问http://Your_IP:Tomcat_Port/Your_Project访问你的项目了。如果一切顺利,你将看到那绚烂的胜利之光照耀在你的项目之上!
532 41
|
8月前
|
关系型数据库 MySQL 数据库
为什么 MySQL 不推荐用 Docker 部署?
本文探讨了MySQL是否适合容器化的问题,分析了Docker容器在数据安全、性能瓶颈、状态管理及资源隔离等方面的挑战,并指出目前主流分布式数据库如TDSQL和OceanBase仍倾向于部署在物理机或KVM上。
410 0
|
8月前
|
Ubuntu 安全 小程序
服务器版本的CentOS和Ubuntu哪个更适合你?
但是以上的比较并不说明Ubuntu是不稳定的或者是不安全的,只是以上比较过程中,在稳定性方面Ubuntu稍微逊色了一点。由于Ubuntu在个人桌面电脑的使用率远远高于CentOS,用Ubuntu搭建服务器,如果遇到什么问题,寻找解决方案相对比较容易,这让Ubuntu在选择方面更优于CentOS。如果你是一个初学者,那么毫无疑问Ubuntu是更适合的选择。如果你正在经营自己的公司,在这两者之间,CentOS会更好一些。
|
10月前
|
Ubuntu Linux 数据中心
阿里云服务器纯净版系统解析:公共镜像版本特性与选择指南参考
当我们选购阿里云服务器时,系统镜像的选择至关重要。阿里云为用户提供了多种系统镜像,包括公共镜像、自定义镜像、共享镜像、云市场镜像和社区镜像。其中,公共镜像为纯净版系统,这些系统皆已正版授权,旨在为ECS实例上的应用程序提供安全、稳定的运行环境。本文将为大家详细汇总阿里云服务器纯净版系统及最新的系统版本,以供大家了解和选择。
|
11月前
|
开发框架 Java 关系型数据库
在Linux系统中安装JDK、Tomcat、MySQL以及部署J2EE后端接口
校验时,浏览器输入:http://[your_server_IP]:8080/myapp。如果你看到你的应用的欢迎页面,恭喜你,一切都已就绪。
661 17
|
11月前
|
Java 关系型数据库 MySQL
在Linux操作系统上设置JDK、Tomcat、MySQL以及J2EE后端接口的部署步骤
让我们总结一下,给你的Linux操作系统装备上最强的军队,需要先后装备好JDK的弓箭,布置好Tomcat的阵地,再把MySQL的物资原料准备好,最后部署好J2EE攻城车,那就准备好进军吧,你的Linux军团,无人可挡!
340 18
|
9月前
|
存储 Ubuntu 安全
如何在服务器上快速安装 ERPNext 最新版本?
ERPNext 是一款开源且功能全面的企业资源规划软件,在企业信息化管理中广泛应用。本文介绍如何通过 Websoft9 控制台安装其最新版本,以提升部署效率。内容涵盖安装前的服务器准备、Websoft9 控制台登录,到通过应用市场安装 ERPNext 的详细步骤,以及安装后的验证与基础配置。帮助企业快速搭建稳定高效的信息化管理平台,满足财务、采购、销售、库存等多方面业务需求,助力企业降本增效,实现可持续发展。
|
12月前
|
关系型数据库 MySQL Linux
在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾
以上就是在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾的步骤。这个过程就像是一场接力赛,数据从MySQL数据库中接力棒一样传递到备份文件,再从备份文件传递到其他服务器,最后再传递回MySQL数据库。这样,即使在灾难发生时,我们也可以快速恢复数据,保证业务的正常运行。
518 28

推荐镜像

更多