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

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

wptr33 2025-05-30 17:53 6 浏览

背景

在生产环境中,单点 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 集群高可用方案


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

相关推荐

数据库基础:mysql主从集群搭建

文章首发于微信公众号:java架构师进阶之路前言:Mysql数据库没有增量备份的机制,当数据量太大的时候备份是一个很大的问题。还好mysql数据库提供了一种主从备份的机制,其实就是把主数据库的所有的...

Mysql-cluster搭建

前期准备准备五台虚拟机:ip地址分别为:192.168.1.211管理节点192.168.1.64SQL节点192.168.1.65SQL节点192.168.1.70数据节点192.168.1...

mysql 主从数据库搭建

一、创建目录在dev/htb下面创建文件夹master01htb]#mkdirmysql/master01-p2)进入master01...

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

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

「MySQL 8」MySQL 5.7都即将停只维护了,是时候学习一波MySQL 8了

MySQL8新特性选择MySQL8的背景:MySQL5.6已经停止版本更新了,对于MySQL5.7版本,其将于2023年10月31日停止支持。后续官方将不再进行后续的代码维护。另外,...

Mysql启动选项和配置文件

Mysql启动选项和配置文件Mysql启动方式下面的启动命令都需要依赖在Linux环境下配置的Mysql环境变量...

centos安装mysql操作手册

1.下载Mysql首先去Mysql官网下载安装包,网址https://dev.mysql.com/downloads/mysql/推荐大家下载Linux通用版本的,便于管理安装位置,也方便一台服务器...

MySQL安装

MySQL的安装过程因操作系统的不同而有所差异。以下是在几种常见操作系统上安装MySQL的基本步骤:Windows下载MySQL:访问MySQL官方网站下载页面:MySQLDownloads...

MySQL数据库安装教程

前言今天就带各位小伙伴学习数据库技术。数据库技术是Java开发中必不可少的一部分知识内容。也是非常重要的技术。...

MySQL学到什么程度?才有可以在简历上写精通

前言如今互联网行业用的最多就是MySQL,然而对于高级Web面试者,尤其对于寻找30k下工作的求职者,很多MySQL相关知识点基本都会涉及,如果面试中,你的相关知识答的模糊和不切要点,基...

一起免费考 MySQL OCP 认证啦

前言:在1995年,首个MySQL版本发布,为庆祝MySQL诞辰30周年,OracleUniversity在限定期间内推出了多个MySQL的免费培训课程与认证,其中也包括My...

教程2 | 制作用户管理系统

一、项目简介用户管理系统是一个基于C/S模式的小型管理系统,使用了GUI技术来实现管理系统的页面效果,该管理系统可以对用户的信息,比如姓名、年龄、密码和地址等进行增删改查操作。用户管理系统通过JDBC...

红帽Linux中安装mysql8详细步骤

注意:我写的解压路径和截图路径不一致,仅供参考先前往官网下载mysql8下载地址:https://dev.mysql.com/downloads/选择指定版本和系统下载命令...

MySQL主从配置

主从原理MySQL主从又叫做Replication、AB复制。简单讲就是A和B两台机器做主从后,在A上写数据,另外一台B也会跟着写数据,两者数据实时同步的。...

mysql的主从搭建以及实现主从切换方法

主从搭建的方法:a.准备两台服务器...