百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

从零搭建高可用的 MySQL 主从复制架构(基于 Linux 实战指南)

ahcoder 2025-06-18 10:30 1 浏览

背景

在生产环境中,单点 MySQL 数据库容易成为性能瓶颈或单点故障源。搭建 MySQL 主从复制架构,可以实现读写分离、高可用,提升系统的整体稳定性与扩展性。





二、架构设计


  • 主库(Master):负责处理写请求
  • 从库(Slave):负责处理读请求
  • 同步方式:异步复制(Asynchronous Replication)



后续可根据需求扩展为半同步(Semi-Sync)或 MGR(Group Replication)。





三、环境准备



  • 系统环境:CentOS 8 / Rocky Linux 8
  • MySQL 版本:MySQL 8.0
  • 主服务器 IP:192.168.1.10
  • 从服务器 IP:192.168.1.20



两台服务器均已关闭防火墙并设置 SELinux 为 permissive 模式。





四、主服务器配置(Master)




1. 安装 MySQL


dnf install -y @mysql

systemctl enable mysqld

systemctl start mysqld


2. 配置 MySQL 主库参数



编辑 /etc/my.cnf 文件:

[mysqld]

server-id=1

log-bin=mysql-bin

binlog-do-db=testdb


  • server-id:每台服务器唯一 ID
  • log-bin:启用二进制日志,必要条件
  • binlog-do-db:指定需要复制的数据库



重启服务:

systemctl restart mysqld


3. 创建复制用户


CREATE USER 'repl'@'%' IDENTIFIED BY 'repl_password';

GRANT REPLICATION SLAVE ON *.* TO 'repl'@'%';

FLUSH PRIVILEGES;






五、从服务器配置(Slave)




1. 安装 MySQL


dnf install -y @mysql

systemctl enable mysqld

systemctl start mysqld


2. 配置从库参数



编辑 /etc/my.cnf 文件:

[mysqld]

server-id=2

relay-log=relay-log

read-only=1

重启服务:

systemctl restart mysqld






六、配置主从同步




1. 在主库查看当前二进制日志信息


SHOW MASTER STATUS;

记录 File 和 Position。



2. 在从库设置主服务器信息


CHANGE MASTER TO

MASTER_HOST='192.168.1.10',

MASTER_USER='repl',

MASTER_PASSWORD='repl_password',

MASTER_LOG_FILE='mysql-bin.000001',

MASTER_LOG_POS=154;


3. 启动同步


START SLAVE;

查看同步状态:

SHOW SLAVE STATUS\G

确认 Slave_IO_Running: Yes 和 Slave_SQL_Running: Yes。





七、测试主从同步


在主库创建新表或插入数据,从库应能实时同步数据:

CREATE DATABASE testdb;

USE testdb;

CREATE TABLE t1 (id INT PRIMARY KEY, name VARCHAR(50));

INSERT INTO t1 VALUES (1, 'hello replication');

在从库查询:

SELECT * FROM testdb.t1;

能看到同步的数据即为成功。





八、总结


本篇实战搭建了一个基础的 MySQL 主从复制环境,具备可读写分离能力。

后续可以在此基础上继续扩展:


  • 半同步复制
  • 多源复制
  • MySQL Router
  • MGR 集群高可用方案


为大规模业务系统提供更稳定可靠的数据库支撑。

相关推荐

Java程序员必备的Linux命令速查表

Java程序员必备的Linux命令速查表在Java开发的世界里,Linux就像一位默默支持的幕后英雄。作为一名Java开发者,掌握一些基本的Linux命令,不仅能提高工作效率,还能让你在团队中显得格外...

Linux 命令速查手册:这 30 个高频指令,拯救 90% 的运维小白!

在Linux系统的世界里,命令行是强大的武器。对于运维小白而言,掌握一些高频使用的Linux命令,能极大提升工作效率,轻松应对各种系统管理任务。今天,就为大家奉上精心整理的30个Linu...

linux磁盘管理相关命令(linux磁盘管理常用命令)

磁盘的使用情况会直接影响系统的性能,因此我们经常会用到以下命令,主要围绕:fdisk:磁盘分区df:文件系统的磁盘空间占用情况du:文件目录的磁盘空间占用情况查看磁盘关系lsblk查看磁盘分区情况fd...

第四章 Linux常用shell命令-4.5.磁盘管理

主要介绍一下跟磁盘管理相关命令,有比较多的内容摘抄自网络,如有侵权,请及时联系我删除:显示目前在Linux系统上的文件系统磁盘使用情况统计:df创建和维护分区表的程序:fdisk将磁盘分区或镜像挂...

Linux新手必备:20个高效命令轻松掌握!

Linux基本命令使用指南在现代计算机操作系统中,Linux因其开放性、灵活性和强大的功能,广泛应用于服务器和开发环境中。作为技术人员,掌握Linux的基本命令是非常重要的。在本文中,我们将重点介绍2...

每日必学Linux命令:ls命令(linux命令详解之ls命令)

ls命令是linux下最常用的命令。ls命令就是list的缩写缺省下ls用来打印出当前目录的清单如果ls指定其他目录那么就会显示指定目录里的文件及文件夹清单。通过ls命令不仅可以查看linux文件...

Linux系统dev和proc目录详解(linux dev/sr0)

简介:Linux系统里的/dev和/proc目录那可是相当重要的系统文件。在Linux系统中,/dev目录专门用来存放设备文件。不光有设备文件,系统里还有好多特殊功能也是通过设备的形式...

Linux切换目录之cd命令(linux切换指定目录)

1.基本概念1.1命令作用当我们在Linux系统上工作时,做得相当多的一项任务就是在不同的目录之间进行切换,这时就需要用到cd命令了。cd是"changedirectory"的首...

Linux切换目录(cd命令)(linux如何切换到目录)

cd命令,是ChangeDirectory的缩写,用来切换工作目录。Linux命令按照来源方式,可分为两种,分别是Shell内置命令和外部命令。所谓Shell内置命令,就是Shel...

MongoDB数据库的快速部署和启动(mongodb的使用教程)

一、Mongodb介绍常见数据库介绍关系数据库RDBMS设计表结构,通过SQL语句进行操作。连表关系常见的关系型数据库:mysqloracle(商业)DB2(IBM)sqlserver(微软...

5分钟学会网络服务搭建,飞凌i.MX9352 + Linux 6.1实战示例

在“万物互联”的技术浪潮下,网络服务已成为连接物理世界与数字世界的核心纽带,它不仅赋予了终端设备“开口说话”的能力,更构建了智能设备的开发范式。本文就将以飞凌嵌入式OK-MX9352-C开发板(搭载了...

centos安装geoserver并配置开机启动

前提条件:服务器已经安装了java环境一、下载下载地址:http://geoserver.org/release/maintain/下载后文件名为:geoserver-2.19.3-bin.zip二、...

开机启动流程(开机流程图)

grubandbootCentos5,6的开机启动流程grubCentos7的开机启动流程Centos5,6的开机启动流程initrd/initramfs一般存储在/boot目录下,以.img...

Linux cron服务概述(crontab服务)

cron是Linux/Unix系统中一个非常重要的后台服务(守护进程),用于在预定的时间间隔自动执行命令或脚本。它使得自动化重复性任务成为可能,例如日志清理、数据备份、系统维护等。1.cron...

CentOS 8利用rc.local进行开机自启动的配置

CentOS8利用rc.local进行开机自启动的配置CentOS8linux系统是不建议使用rc.local进行开机自启动的,建议创建systemdservice。我们为了方便以后多一个配置...