导读:本期聚焦于小伙伴创作的《Linux下如何安装MySQL多实例作为数据备份服务器实现多主到一从多实例》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《Linux下如何安装MySQL多实例作为数据备份服务器实现多主到一从多实例》有用,将其分享出去将是对创作者最好的鼓励。

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

Linux下如何安装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;

执行后会得到类似如下的结果,记录下FilePosition的值:

FilePositionBinlog_Do_DBBinlog_Ignore_DB
mysql-bin.000001156

从库多实例配置主从同步

实例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_RunningSlave_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_RunningConnecting:通常是主库地址、端口、账号密码错误,或者网络不通,检查防火墙和主库权限配置。
  • 同步状态中Slave_SQL_RunningNo:通常是主从数据不一致导致SQL执行失败,可以查看错误日志定位具体问题,必要时重新初始化从库实例。
  • 多实例启动失败:检查配置文件中的目录权限是否正确,端口是否被占用。

日常维护

日常需要定期检查从库两个实例的同步状态,避免同步中断导致数据丢失。可以编写简单的脚本定时执行SHOW SLAVE STATUSG命令,监控两个运行指标的状态。同时定期备份从库实例的数据,实现数据的多重容灾,避免从库本身出现故障导致备份数据丢失。

MySQL多实例Linux数据备份多主一从修改时间:2026-06-21 00:21:47

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。