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

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 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
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
8天前
|
运维 Prometheus 监控
如何在测试环境中保持操作系统、浏览器版本和服务器配置的稳定性和一致性?
如何在测试环境中保持操作系统、浏览器版本和服务器配置的稳定性和一致性?
|
15天前
|
关系型数据库 MySQL
mysql 5.7.x版本查看某张表、库的大小 思路方案说明
mysql 5.7.x版本查看某张表、库的大小 思路方案说明
41 5
|
20天前
|
关系型数据库 MySQL
mysql 5.7.x版本查看某张表、库的大小 思路方案说明
mysql 5.7.x版本查看某张表、库的大小 思路方案说明
28 1
|
1月前
|
Java 关系型数据库 MySQL
【编程基础知识】Eclipse连接MySQL 8.0时的JDK版本和驱动问题全解析
本文详细解析了在使用Eclipse连接MySQL 8.0时常见的JDK版本不兼容、驱动类错误和时区设置问题,并提供了清晰的解决方案。通过正确配置JDK版本、选择合适的驱动类和设置时区,确保Java应用能够顺利连接MySQL 8.0。
142 1
|
1月前
|
IDE 网络安全 开发工具
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
本文介绍了如何在PyCharm专业版中连接远程服务器并配置远程Python环境解释器,以便在服务器上运行代码。
299 0
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
|
1月前
|
SQL JSON 关系型数据库
MySQL是一个广泛使用的开源关系型数据库管理系统,它有许多不同的版本
【10月更文挑战第3天】MySQL是一个广泛使用的开源关系型数据库管理系统,它有许多不同的版本
133 5
|
1月前
|
SQL 分布式计算 关系型数据库
Hadoop-21 Sqoop 数据迁移工具 简介与环境配置 云服务器 ETL工具 MySQL与Hive数据互相迁移 导入导出
Hadoop-21 Sqoop 数据迁移工具 简介与环境配置 云服务器 ETL工具 MySQL与Hive数据互相迁移 导入导出
51 3
|
20天前
|
SQL 关系型数据库 MySQL
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
MySql5.6版本开启慢SQL功能-本次采用永久生效方式
33 0
|
9天前
|
SQL 关系型数据库 MySQL
12 PHP配置数据库MySQL
路老师分享了PHP操作MySQL数据库的方法,包括安装并连接MySQL服务器、选择数据库、执行SQL语句(如插入、更新、删除和查询),以及将结果集返回到数组。通过具体示例代码,详细介绍了每一步的操作流程,帮助读者快速入门PHP与MySQL的交互。
24 1
|
11天前
|
SQL 关系型数据库 MySQL
go语言数据库中mysql驱动安装
【11月更文挑战第2天】
26 4