MySQL多实例部署

来源:这里教程网 时间:2026-03-01 15:22:57 作者:

一 MySQL多实例介绍

1.1 什么是MySQL多实例

MySQL多实例,简单理解就是在一台服务器 上, MySQL 服务开启多个不同的端口(如3306、3307,3308),运行多个服务进程。这些 mysql 服务进程通过不同的 socket 来监听不同的数据端口,进而互不干涉的提供各自的服务。

1.2 MySQL应用场景

1)在测试环境中,公司会需要多个数据库环境来测试业务,当使用强度又不是很高,在单机上部署多个实例是个不错选择。2)公司业务访问量不是太大的时候,服务器的资源基本都是过剩状态。此时也适合 mysql 多实例的应用。

1.3 多实例实现的方式

mysql 多实例常规方法有两种 方法一:使用多个 my.cnf 配置文件启动不同的进程来实现多实例,这种方法逻辑简单,配置不容易出错。方法二:使用官方自带的 mysqld_multi 来控制 my.cnf 配置文件,来实现多实例,配置相对复杂。(本文未涵盖)

1.4 在同一主机下安装多个 mysql 实例,需要处理以下问题

1)配置文件安装路径不能相同2)数据库目录不能相同3)启动脚本不能同名4)端口不能相同5)socket 文件生成路径不能相同

二 MySQL安装准备

2.1 二进制包下载

https://cdn.mysql.com/archives/mysql-5.7/mysql-5.7.30-linux-glibc2.12-x86_64.tar.gz

2.2 创建软件目录,解压迁移软件

[root@db03 tmp]# mkdir -p /opt/
[root@db03 tmp]# tar -zxvf mysql-5.7.30-linux-glibc2.12-x86_64.tar.gz -C /opt/
[root@db03 tmp]# cd /opt
[root@db03 opt]# ls
mysql-5.7.30-linux-glibc2.12-x86_64
[root@db03 opt]# mv mysql-5.7.30-linux-glibc2.12-x86_64/ mysql
[root@db03 opt]# ls
mysql

2.3 处理原始环境中的 mysql,并安装依赖库

如果以前安装过 mysql 需要停止服务,并关闭开机自启动,移走 /etc/my.cnf 配置文件。系统自带的 mariadb,也建议删除

[root@db03 ~]# killall mysqld
[root@db03 ~]# mv /etc/my.cnf /etc/my.cnf.bak
[root@db03 opt]# rpm -qa | grep mariadb
mariadb-libs-5.5.64-1.el7.x86_64
[root@db03 opt]# yum remove mariadb-libs.x86_64 -y
yum install -y libaio

2.4 创建 mysql 用户

[root@db03 opt]# groupadd -g 1002 mysql
[root@db03 opt]# useradd -u 1002 -g 1002 -M -s /sbin/nologin mysql
[root@db03 opt]# id mysql
uid=1002(mysql) gid=1002(mysql) groups=1002(mysql)

2.5 添加环境变量

echo 'export PATH=$PATH:/opt/mysql/bin' >>  /etc/profile 
source /etc/profile

三 MySQL多实例部署

3.1 准备多实例目录

[root@db03 ~]# mkdir -p /data/330{7,8,9}/data

3.2 准备多配置文件

cat > /data/3307/my.cnf <<EOF
[mysqld]
basedir=/opt/mysql
datadir=/data/3307/data
socket=/data/3307/mysql.sock
log_error=/data/3307/mysql.log
port=3307
server_id=7
log_bin=/data/3307/mysql-bin
EOF
cat > /data/3308/my.cnf <<EOF
[mysqld]
basedir=/opt/mysql
datadir=/data/3308/data
socket=/data/3308/mysql.sock
log_error=/data/3308/mysql.log
port=3308
server_id=8
log_bin=/data/3308/mysql-bin
EOF
cat > /data/3309/my.cnf <<EOF
[mysqld]
basedir=/opt/mysql
datadir=/data/3309/data
socket=/data/3309/mysql.sock
log_error=/data/3309/mysql.log
port=3309
server_id=9
log_bin=/data/3309/mysql-bin
EOF

3.3 初始化三套数据字典

mysqld --initialize-insecure  --user=mysql --datadir=/data/3307/data --basedir=/opt/mysql
mysqld --initialize-insecure  --user=mysql --datadir=/data/3308/data --basedir=/opt/mysql
mysqld --initialize-insecure  --user=mysql --datadir=/data/3309/data --basedir=/opt/mysql

3.4 systemd管理多实例,准备三个启动文件

cat >/etc/systemd/system/mysqld3307.service <<EOF
[Unit]
Description=MySQL Server
Documentation=man:mysqld(8)
Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
After=network.target
After=syslog.target
[Install]
WantedBy=multi-user.target
[Service]
User=mysql
Group=mysql
ExecStart=/opt/mysql/bin/mysqld --defaults-file=/data/3307/my.cnf
LimitNOFILE = 5000
EOF
[root@db03 ~]# cd /etc/systemd/system/
[root@db03 system]# cp mysqld3307.service mysqld3308.service 
[root@db03 system]# cp mysqld3307.service mysqld3309.service
vim mysqld3308.service
# 修改为:
ExecStart=/application/mysql/bin/mysqld  --defaults-file=/data/3308/my.cnf
vim mysqld3309.service
# 修改为:
ExecStart=/application/mysql/bin/mysqld  --defaults-file=/data/3309/my.cnf
修改后的结果
[root@db03 system]# grep 'ExecStart' mysqld3307.service
ExecStart=/opt/mysql/bin/mysqld --defaults-file=/data/3307/my.cnf
[root@db03 system]# grep 'ExecStart' mysqld3308.service
ExecStart=/opt/mysql/bin/mysqld --defaults-file=/data/3308/my.cnf
[root@db03 system]# grep 'ExecStart' mysqld3309.service
ExecStart=/opt/mysql/bin/mysqld --defaults-file=/data/3309/my.cnf

3.5 授权目录权限

[root@db03 ~]# chown -R mysql.mysql /opt/mysql
[root@db03 ~]# chown -R mysql.mysql /data/330*

3.6 启动多实例

[root@db03 ~]# systemctl start mysqld3307.service
[root@db03 ~]# systemctl start mysqld3308.service
[root@db03 ~]# systemctl start mysqld3309.service

3.7 验证多实例

[root@db03 ~]# netstat -lnp|grep 330
tcp6       0      0 :::3307                 :::*                    LISTEN      70516/mysqld        
tcp6       0      0 :::3308                 :::*                    LISTEN      70557/mysqld        
tcp6       0      0 :::3309                 :::*                    LISTEN      70594/mysqld        
unix  2      [ ACC ]     STREAM     LISTENING     194532   70516/mysqld         /data/3307/mysql.sock
unix  2      [ ACC ]     STREAM     LISTENING     198752   70594/mysqld         /data/3309/mysql.sock
unix  2      [ ACC ]     STREAM     LISTENING     198669   70557/mysqld         /data/3308/mysql.sock
[root@db03 ~]# mysql -S /data/3307/mysql.sock -e "select @@server_id"
+-------------+
| @@server_id |
+-------------+
|           7 |
+-------------+
[root@db03 ~]# mysql -S /data/3308/mysql.sock -e "select @@server_id"
+-------------+
| @@server_id |
+-------------+
|           8 |
+-------------+
[root@db03 ~]# mysql -S /data/3309/mysql.sock -e "select @@server_id"
+-------------+
| @@server_id |
+-------------+
|           9 |
+-------------+

相关推荐