在Linux系统中搭建MySQL多实例作为数据备份服务器,实现多主到一从的多实例架构,能够有效整合服务器资源,让多个主库的数据集中同步到同一台从服务器的不同MySQL实例中,满足企业级数据容灾和集中备份的需求。

环境准备
首先需要准备一台Linux服务器,建议系统版本为CentOS 7及以上,确保服务器有足够的磁盘空间和内存资源。提前下载对应版本的MySQL二进制安装包,本文以MySQL 8.0为例进行说明。同时需要关闭服务器防火墙或者开放对应端口,避免主从同步时端口被拦截。
MySQL多实例安装
创建多实例目录
为不同的MySQL实例创建独立的数据目录、日志目录和配置文件目录,避免实例之间的文件冲突。假设我们创建两个从实例,分别对应两个主库的同步需求。
# 创建实例1的目录 mkdir -p /data/mysql/instance1/data mkdir -p /data/mysql/instance1/log mkdir -p /data/mysql/instance1/conf # 创建实例2的目录 mkdir -p /data/mysql/instance2/data mkdir -p /data/mysql/instance2/log mkdir -p /data/mysql/instance2/conf # 修改目录权限,确保mysql用户有操作权限 chown -R mysql:mysql /data/mysql
初始化实例
使用MySQL的初始化命令为每个实例生成初始数据文件,注意每个实例需要指定不同的数据目录和配置文件。
# 初始化实例1 mysqld --initialize-insecure --user=mysql --datadir=/data/mysql/instance1/data --basedir=/usr/local/mysql # 初始化实例2 mysqld --initialize-insecure --user=mysql --datadir=/data/mysql/instance2/data --basedir=/usr/local/mysql
配置多实例配置文件
每个实例需要独立的配置文件,重点配置不同的端口、数据目录、socket文件和server-id,server-id必须保证全局唯一,避免主从同步冲突。
实例1的配置文件/data/mysql/instance1/conf/my.cnf内容如下:
[mysqld] port=3307 datadir=/data/mysql/instance1/data socket=/data/mysql/instance1/mysql.sock log-error=/data/mysql/instance1/log/error.log pid-file=/data/mysql/instance1/mysql.pid server-id=100 log-bin=mysql-bin relay-log=relay-bin
实例2的配置文件/data/mysql/instance2/conf/my.cnf内容如下:
[mysqld] port=3308 datadir=/data/mysql/instance2/data socket=/data/mysql/instance2/mysql.sock log-error=/data/mysql/instance2/log/error.log pid-file=/data/mysql/instance2/mysql.pid server-id=101 log-bin=mysql-bin relay-log=relay-bin
启动多实例
使用mysqld_safe命令分别启动两个实例,启动后可以通过端口检查实例是否正常运行。
# 启动实例1 mysqld_safe --defaults-file=/data/mysql/instance1/conf/my.cnf --user=mysql & # 启动实例2 mysqld_safe --defaults-file=/data/mysql/instance2/conf/my.cnf --user=mysql & # 检查实例端口是否监听 netstat -tlnp | grep 3307 netstat -tlnp | grep 3308
主库配置
假设我们有两个主库,主库1的地址为192.168.0.10,主库2的地址为192.168.0.11,需要分别在两个主库上开启binlog日志,创建同步账号并授权。
主库开启binlog
修改主库的my.cnf配置文件,添加以下配置后重启MySQL服务:
[mysqld] log-bin=mysql-bin server-id=1 # 主库1的server-id设为1,主库2设为2,保证唯一 binlog_format=row
创建同步账号
在两个主库上分别创建用于从库同步的账号,并授予复制权限。
-- 主库1执行 CREATE USER 'repl'@'192.168.0.%' IDENTIFIED BY 'repl_password'; GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.0.%'; FLUSH PRIVILEGES; -- 主库2执行相同操作,密码可以保持一致
获取主库binlog信息
在主库上执行以下命令,记录当前的binlog文件名和位置,后续从库配置需要用到。
SHOW MASTER STATUS;
执行后会得到类似如下的结果,记录下File和Position的值:
| File | Position | Binlog_Do_DB | Binlog_Ignore_DB |
|---|---|---|---|
| mysql-bin.000001 | 156 |
从库多实例配置主从同步
实例1同步主库1
登录实例1的MySQL,配置主库1的同步信息,然后启动同步进程。
# 登录实例1,需要指定socket文件 mysql -S /data/mysql/instance1/mysql.sock -u root -p
在实例1的MySQL终端执行以下SQL:
-- 配置主库1的同步信息,替换为实际的主库地址、端口、账号密码和binlog信息 CHANGE MASTER TO MASTER_HOST='192.168.0.10', MASTER_PORT=3306, MASTER_USER='repl', MASTER_PASSWORD='repl_password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=156; -- 启动同步 START SLAVE; -- 查看同步状态 SHOW SLAVE STATUSG
查看同步状态时,确保Slave_IO_Running和Slave_SQL_Running两个值都为Yes,说明同步正常。
实例2同步主库2
登录实例2的MySQL,按照同样的步骤配置主库2的同步信息。
# 登录实例2 mysql -S /data/mysql/instance2/mysql.sock -u root -p
在实例2的MySQL终端执行以下SQL:
-- 配置主库2的同步信息 CHANGE MASTER TO MASTER_HOST='192.168.0.11', MASTER_PORT=3306, MASTER_USER='repl', MASTER_PASSWORD='repl_password', MASTER_LOG_FILE='mysql-bin.000001', MASTER_LOG_POS=156; -- 启动同步 START SLAVE; -- 查看同步状态 SHOW SLAVE STATUSG
验证与常见问题
验证架构是否生效的方法很简单,在主库1上创建测试表并插入数据,然后登录从库实例1查询,看数据是否同步过来;同样在主库2操作,检查实例2的数据同步情况。
常见问题主要有以下几种:
- 同步状态中
Slave_IO_Running为Connecting:通常是主库地址、端口、账号密码错误,或者网络不通,检查防火墙和主库权限配置。 - 同步状态中
Slave_SQL_Running为No:通常是主从数据不一致导致SQL执行失败,可以查看错误日志定位具体问题,必要时重新初始化从库实例。 - 多实例启动失败:检查配置文件中的目录权限是否正确,端口是否被占用。
日常维护
日常需要定期检查从库两个实例的同步状态,避免同步中断导致数据丢失。可以编写简单的脚本定时执行SHOW SLAVE STATUSG命令,监控两个运行指标的状态。同时定期备份从库实例的数据,实现数据的多重容灾,避免从库本身出现故障导致备份数据丢失。