星途物语 星途物语
首页
  • 随手记录
  • 故障处理
  • Nginx
  • MySQL
  • Ansible
  • Nexus
  • Tomcat
  • Docker
  • Zabbix
  • Prometheus
  • Git
  • GitLab
  • Jenkins
  • Kubernetes
  • Shell
  • Python
  • 圈圈空间
  • 做饭这件事
收藏站点
留言板
归档
GitHub (opens new window)

星途物语

尚记时,记之
首页
  • 随手记录
  • 故障处理
  • Nginx
  • MySQL
  • Ansible
  • Nexus
  • Tomcat
  • Docker
  • Zabbix
  • Prometheus
  • Git
  • GitLab
  • Jenkins
  • Kubernetes
  • Shell
  • Python
  • 圈圈空间
  • 做饭这件事
收藏站点
留言板
归档
GitHub (opens new window)
  • 随手记录

    • QPS优化记录
    • 阿里云SLB演示
    • DDOS预防
    • Linux内核优化
    • rsync同步守护进程
    • NFS文件同步
    • Tomcat升级
    • 编译安装mysql后添加到systemd管理
    • 防火墙笔记
    • python自动化巡检服务器
  • 故障处理

    • 处理防MIME攻击后出现的问题解决
  • MySQL学习笔记

    • MySQL5.7安装
    • MySQL常用操作语句
    • MySQL主从架构实施
    • MySQL主主架构实施
    • MySQL MHA高可用实施
    • MyCat读写分离
    • MySQL创建用户时的授权
    • MySQL备份
    • MySQL通配符
  • Nginx学习笔记

    • 状态码含义
    • 匹配优先级
    • Nginx常用操作
    • 添加第三方模块
    • 关于路径匹配
    • 转发和重写
    • 内置变量
    • Nginx配置文件结构
  • Tomcat学习笔记

    • 部署Tomcat
    • 修改发布目录
    • Tomcat调优
  • Redis学习笔记

    • 通过 tar.gz 包安装部署 redis
    • redis 配置文件
    • 哨兵集群
    • redis常用命令
    • 虚拟机安装 redis.tar.gz 遇到的问题
  • Ansible学习笔记

    • 部署和使用 ansible
    • ansible 自带的密码认证参数
    • 批量免密操作:批量分发公钥
    • 配置主机清单
    • ansible 小知识
    • 模块介绍
    • 剧本
    • 一键部署 rsync 环境
    • 批量安装一个tomcat
    • 批量安装一个nginx
    • 批量安装 zabbix-agent
  • Zabbix学习笔记

    • 部署 zabbix 服务端、客户端
    • 自定义监控
    • 触发器
    • 监控项类型
    • 简单检查模式
    • zabbix web 界面结构信息
    • 邮件报警
    • 微信报警
    • snmp 监控网络设备
    • 部署 zabbix 服务端、客户端
    • jmx 监控 java 应用
    • ipmi 监控硬件
    • 自动化注册
    • 监控项的主要项和相关项
    • percona 监控 mysql
  • Git学习笔记

    • 配置 git
    • 常用命令
  • GitLab学习笔记

    • 环境准备
    • 安装 gitlab
    • gitlab 忘记 root 管理员密码的处理办法
  • Jenkins学习笔记

    • 安装部署
    • jenkins 使用脚本完成项目构建
    • jenkins 自动构建最新项目
    • 将 jenkins 自动部署的结果返回给 gitlab
    • jenkins 上线 java 项目
    • jenkins pipeline
  • Docker学习笔记

    • 安装 docker
    • 配置 docker 源
    • docker 中的常见名词
    • 镜像管理命令
    • 容器管理命令
    • 创建容器
    • 数据卷
    • docker network
    • 搭建 LNMP
    • Dockerfile
    • Dockerfile 搭建 tomcat
    • docker 镜像磁盘扩容
    • docker composer
    • Harbor 私有镜像仓库
    • docker 面试题
    • docker desktop 运行时与虚拟机冲突
    • docker离线安装
  • Nexus学习笔记
  • Prometheus学习笔记

    • 核心组件
    • 工作原理
    • 安装和配置
    • 启动 Prometheus
    • PromQL 使用
    • 数据模型
    • Exporter
    • 演示服务
    • Grafana 数据可视化
    • Prometheus 告警
  • Kubernetes学习笔记

    • K8S的介绍
    • K8S集群环境的搭建
    • K8S资源管理
    • K8S的实战入门
  • 运维
  • MySQL学习笔记
星途物语
2025-01-01

MySQL主从架构实施

  1. 主服务器记录更改**:
    • 在主服务器(Master)上,所有对数据库的写操作(INSERT、UPDATE、DELETE 等)都会被记录到二进制日志文件中。二进制日志不仅记录了每一个操作,还记录了操作发生的顺序和时间。
  2. 从服务器读取二进制日志:
    • 从服务器(Slave)会连接到主服务器,并通过 I/O 线程不断读取主服务器的二进制日志,然后将这些日志复制到本地的中继日志(Relay Log)中。
  3. 从服务器重放二进制日志:
    • 从服务器的 SQL 线程读取中继日志中的内容,并依次执行日志中的每一条语句。这些语句在从服务器上重放,从而使从服务器的数据与主服务器保持同步。

这个过程是异步进行的,从服务器通常会有一定的延迟,这个延迟取决于网络状况、服务器负载等因素。

首先准备两个虚拟机,最好都安装相同版本的 mysql

保证两台 PC 可以互相通讯

image-20240813140739721

配置主数据库

1.修改主数据库的配置文件,一般在 /etc/my.cnf

[mysqld]
server-id=1
log-bin=mysql-bin
#server-id=1:指定主服务器的 ID,确保每个服务器的 ID 唯一
#log-bin=mysql-bin:启用二进制日志,这是实现复制的基础
1
2
3
4
5

2.修改完配置文件后重启 mysql

3.创建复制用户,登录 mysql,并创建复制用户

CREATE USER 'zzl'@'10.0.0.21' IDENTIFIED BY '123456zzlZZL!';
#授予用户 zzl 在所有数据库和所有表上的复制权限,允许它作为从服务器(slave)进行复制
GRANT REPLICATION SLAVE ON *.* TO 'zzl'@'10.0.0.21';
FLUSH PRIVILEGES;
1
2
3
4
image-20240813141743576

4.锁定主数据库表并获取二进制日志信息

FLUSH TABLES WITH READ LOCK;

SHOW MASTER STATUS;

#该命令将所有表刷新到磁盘,并且对整个数据库实例加上全局读锁(全局只读锁)
#通过执行这个命令,可以确保在备份数据或记录主服务器状态(例如二进制日志位置)时,没有其他写操作改变数据库的数据状态,从而获得一个一致性快照
#该锁禁止所有写操作(INSERT、UPDATE、DELETE、CREATE、DROP 等),但允许读操作(SELECT)
#这个锁会阻塞所有写入操作,因此需要尽量缩短锁定时间
FLUSH TABLES WITH READ LOCK;
#显示主服务器当前的二进制日志文件名称和位置等信息。这些信息对于配置从服务器非常重要,因为从服务器需要知道从哪个日志文件和位置开始复制数据
SHOW MASTER STATUS;
1
2
3
4
5
6
7

记下 File 和 Position,稍后在从服务器中使用

image-20240813142600263

mysql-bin.000001,761

5.开放 mysql 端口

从数据库配置

修改从数据库配置文件 my.cnf,添加 server-id=2,确保唯一性

重启 MySQL 服务

设置从服务器与主服务器同步,登录 mysql,执行以下命令,根据实际情况执行

CHANGE MASTER TO
MASTER_HOST='10.0.0.20',
MASTER_USER='zzl',
MASTER_PASSWORD='123456zzlZZL!',
MASTER_LOG_FILE='mysql-bin.000001',  -- 使用在主服务器中获取的日志文件名
MASTER_LOG_POS=761;  -- 使用在主服务器中获取的位置
1
2
3
4
5
6

启动复制进程:START SLAVE;

检测从数据库状态:SHOW SLAVE STATUS\G;

确保 Slave_IO_Running 和 Slave_SQL_Running 都显示为 Yes

image-20240813144535828

解锁主数据库:UNLOCK TABLES;

如果在复制进程启动后,Slave_IO_Running 和 Slave_SQL_Running 没有都为 Yes,在修改完相关配置,需要再重新启动复制进程

可能是因为主节点端口没有开放

STOP SLAVE,START SLAVE

#MySQL
MySQL常用操作语句
MySQL主主架构实施

← MySQL常用操作语句 MySQL主主架构实施→

Theme by Vdoing | Copyright © 2025-2025 | 鄂ICP备2024086820号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式