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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 一台服务器部署多个版本的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 MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
5天前
|
关系型数据库 MySQL Linux
MySQL版本升级(8.0.31->8.0.37)
本次升级将MySQL从8.0.31升级到8.0.37,采用就地升级方式。具体步骤包括:停止MySQL服务、备份数据目录、下载并解压新版本的RPM包,使用`yum update`命令更新已安装的MySQL组件,最后启动MySQL服务并验证版本。整个过程需确保所有相关RPM包一同升级,避免部分包遗漏导致的问题。官方文档提供了详细指导,确保升级顺利进行。
46 16
|
9天前
|
SQL 存储 关系型数据库
MySQL/SqlServer跨服务器增删改查(CRUD)的一种方法
通过上述方法,MySQL和SQL Server均能够实现跨服务器的增删改查操作。MySQL通过联邦存储引擎提供了直接的跨服务器表访问,而SQL Server通过链接服务器和分布式查询实现了灵活的跨服务器数据操作。这些技术为分布式数据库管理提供了强大的支持,能够满足复杂的数据操作需求。
53 12
|
24天前
|
NoSQL Java 关系型数据库
Liunx部署java项目Tomcat、Redis、Mysql教程
本文详细介绍了如何在 Linux 服务器上安装和配置 Tomcat、MySQL 和 Redis,并部署 Java 项目。通过这些步骤,您可以搭建一个高效稳定的 Java 应用运行环境。希望本文能为您在实际操作中提供有价值的参考。
114 26
|
1月前
|
Java 关系型数据库 MySQL
如何将Spring Boot + MySQL应用程序部署到Pivotal Cloud Foundry (PCF)
如何将Spring Boot + MySQL应用程序部署到Pivotal Cloud Foundry (PCF)
57 5
|
2月前
|
关系型数据库 MySQL
mysql 5.7.x版本查看某张表、库的大小 思路方案说明
mysql 5.7.x版本查看某张表、库的大小 思路方案说明
76 5
|
2月前
|
关系型数据库 MySQL
mysql 5.7.x版本查看某张表、库的大小 思路方案说明
mysql 5.7.x版本查看某张表、库的大小 思路方案说明
48 1
|
3月前
|
Java 关系型数据库 MySQL
【编程基础知识】Eclipse连接MySQL 8.0时的JDK版本和驱动问题全解析
本文详细解析了在使用Eclipse连接MySQL 8.0时常见的JDK版本不兼容、驱动类错误和时区设置问题,并提供了清晰的解决方案。通过正确配置JDK版本、选择合适的驱动类和设置时区,确保Java应用能够顺利连接MySQL 8.0。
285 1
|
2月前
|
SQL 关系型数据库 MySQL
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
46 0
|
SQL 弹性计算 关系型数据库
把RDSmysql的数据上传到ECS部署的服务器,需要在ECS中安装mysql吗?还是可以在部署的服务器内部直接写rds数据库的地址进行连接
把RDSmysql的数据上传到ECS部署的服务器,需要在ECS中安装mysql吗?还是可以在部署的服务器内部直接写rds数据库的地址进行连接
162 0