09-MySQL主从复制

01-主从复制原理

MySQL主从复制是一种用于实现数据备份、读写分离和扩展性的技术。它基于二进制日志(Binary Log)来将主数据库上的更改操作同步到一个或多个从数据库。
MySQL主从复制的基本原理如下:

  1. 主服务器(Master)记录二进制日志:主服务器记录所有对数据库的修改操作,包括更新、插入和删除等,并将这些操作记录在二进制日志中。
  2. 从服务器(Slave)连接到主服务器:从服务器通过配置文件指定主服务器的地址和认证信息,然后与主服务器建立连接。
  3. 从服务器请求复制数据:从服务器向主服务器发送复制请求,请求成为主服务器的一个从服务器。
  4. 主服务器接受复制请求:主服务器接受从服务器的复制请求,并将相关的复制信息记录到主服务器的二进制日志中。
  5. 从服务器获取并应用复制数据:从服务器连接到主服务器后,开始从主服务器的二进制日志中获取复制数据,并将这些数据应用到自己的数据库中,实现数据的同步。
  6. 周期性地重复复制过程:从服务器会周期性地检查主服务器的二进制日志,获取新的复制数据并应用到自己的数据库中,以保持与主服务器的数据同步。

主从复制可以实现以下功能:

  1. 数据备份和恢复:通过主从复制,从服务器作为备份,可以随时恢复到主服务器的数据状态。
  2. 读写分离:主服务器负责处理写操作,从服务器负责处理读操作,从而分担了主服务器的负载。
  3. 高可用性:如果主服务器发生故障,可以快速切换到从服务器,保证系统的高可用性。

02-主从复制实战

2-1 主服务器设置

主服务容器的部署工作大体分为以下 5 步 :

  1. 新建主服务器容器实例 3307
  2. 进入/root/mysql/conf 目录下新建my.cnf
  3. 修改完配置重启主容器实例,进入主容器
  4. 主容器实例内创建数据同步用户

首先依旧得部署数据卷,具体流程工作如下:

mkdir -p /root/mysql/conf
mkdir -p /root/mysql/log
mkdir -p /root/mysql/data
docker run -d -p 3307:3306 --privileged=true -v /root/mysql/log:/var/log/mysql -v /root/mysql/data:/var/lib/mysql -v /root/mysql/conf:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=8888  --name mysql mysql:5.7

然后在/root/mysql/conf下编辑文件my.cnf,将如下内容写入后重启主容器

[mysqld]
## 设置serverid,同一局域网中需要唯一
server_id=101
## 指定不需要同步的数据库名称
binlog-ignore-db=mysql
##开启二进制日志功能
log-bin=mall-mysql-bin
##设置二进制日志使用内存大小(事务)
binlog_cache_size=1M
##设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed
## 二进制日志过期清理时间按,默认为0,表示不自动清理
expire_logs_days=7
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免从slave端复制中断
## 1062错误是指一些主键重复,1032错误是因为主从数据库不一致
slave_skip_errors=1062

然后我们需要在主容器内创建数据同步用户,创作用户代码如下:

#首先链接mysql服务器
mysql -uroot -p
# 代码将创建一个名为replication_user的用户,并授予其在所有数据库和表上进行复制操作的权限。
CREATE USER 'replication_user'@'%' IDENTIFIED BY 'password';
GRANT REPLICATION SLAVE ON *.* TO 'replication_user'@'%';
# 执行以上SQL语句后,刷新MySQL权限以使更改生效:
FLUSH PRIVILEGES;
  • 将password替换为实际的密码。建议使用强密码来保护用户账号。
  • '%'表示该用户可以从任意主机连接到MySQL服务器。如果您只希望特定IP地址或主机名可以连接,请相应地修改连接限制。

2-3 从服务器设置

从服务容器的部署工作大体分为以下 5 步 :

  1. 新建从服务器容器实例 3307
  2. 进入/root/mysql-salve/conf 目录下新建my.cnf
  3. 修改完配置重启从容器实例,进入从容器
  4. 在主数据库中查看主从数据同步状态

首先依旧得部署数据卷,具体流程工作如下:

mkdir -p /root/mysql-slave/cnf
mkdir -p /root/mysql-slave/log
mkdir -p /root/mysql-slave/data
docker run -d -p 3308:3306 --privileged=true -v /root/mysql-slave/log:/var/log/mysql -v /root/mysql-slave/data:/var/lib/mysql -v /root/mysql-slave/conf:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=8888  --name mysql-2 mysql:5.7

然后在/root/mysql-slave/conf下编辑文件my.cnf,将如下内容写入后重启从 容器

[mysqld]
## 设置serverid,同一局域网中需要唯一,主机101,从机202
server_id=102
## 指定不需要同步的数据库名称
binlog-ignore-db=mysql
##开启二进制日志功能
log-bin=mall-mysql-bin
##设置二进制日志使用内存大小(事务)
binlog_cache_size=1M
##设置使用的二进制日志格式(mixed,statement,row)
binlog_format=mixed
## 二进制日志过期清理时间按,默认为0,表示不自动清理
expire_logs_days=7
## 跳过主从复制中遇到的所有错误或指定类型的错误,避免从slave端复制中断
## 1062错误是指一些主键重复,1032错误是因为主从数据库不一致
slave_skip_errors=1062
## relay_log配置中继日志
relay_log=mall-mysql-relay-bin
##log_slave_updates表示slave讲复制时间写进自己的二进制日志
log_slave_updates=1
## slave设置为只读(具有super用户权限除外)
read_only=1

然后我们可以在主数据库中查看目前的主从同步状态:
在这里插入图片描述

继而进入mysql-slave容器中,开始在从数据库中配置主从复制。

CHANGE MASTER TO MASTER_HOST='<主服务器IP地址>',
                   MASTER_USER='<主服务器复制用户>',
                   MASTER_PASSWORD='<主服务器复制用户密码>',
                   MASTER_PORT=<主服务器端口>,
                   MASTER_LOG_FILE='<主服务器二进制日志文件>',
                   MASTER_LOG_POS=<主服务器日志位置>;

实际操作中需要注意更多的东西,比如我的实际操作内容是:

CHANGE MASTER TO MASTER_HOST='192.168.254.128',MASTER_USER='slave',MASTER_PASSWORD='king1977',MASTER_PORT=3307,MASTER_LOG_FILE='mall-mysgl-bin.000001',MASTER_LOG_POS=749,MASTER_CONNECT_RETRY=30;

然后我们需要在从数据中查看主从同步状态:**show slave status \G;**,此时可以看到主从状态并未开启,我们需要开启主从同步状态。
在这里插入图片描述

在从数据库中开启主从数据同步命令如下:

start slave;
# 然后重新检查主从同步状态,如果两个状态未同时为YES,可以执行以下内容
# 在备库执行 
stop slave; 
reset slave; 
start slave;

03-主从复制测试

主服务器上创建新的数据库和数据表,输入内容如下:

create database db_01;
use db_01;
crate table tb_01(id int,name varchar(20));

此时主服务器和从服务器数据库内容如下:
主服务器数据库
image.png
从服务器数据库
image.png
至此一主一从的主从复制顺利完成,在后续的学习实战中,我想要实现一主多从的自动化部署,这点后续可以作为学习的重点。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/123221.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

数据结构-栈和队列力扣题

目录 有效的括号 用队列实现栈 用栈实现队列 设计循环队列 有效的括号 题目链接&#xff1a;力扣&#xff08;LeetCode&#xff09; 思路&#xff1a; 这道题可以用栈来解决&#xff0c;先让字符串中的左括号 ( &#xff0c; [ &#xff0c; { 入栈&#xff0c;s指向字符串下…

U-Mail信创邮件系统解决方案

近年来&#xff0c;在国家政策的大力引导和自身数字化转型需求驱动下&#xff0c;国产化成为国内数字化发展道路上的关键词&#xff0c;企业不断加强自主创新能力&#xff0c;进行信创建设&#xff0c;实现软硬件系统国产化替代&#xff0c;已成为大势所趋。邮件系统作为企业管…

代码随想录训练营Day1:二分查找与移除元素

本专栏内容为&#xff1a;代码随想录训练营学习专栏&#xff0c;用于记录训练营的学习经验分享与总结。 文档讲解&#xff1a;代码随想录 视频讲解&#xff1a;二分查找与移除元素 &#x1f493;博主csdn个人主页&#xff1a;小小unicorn ⏩专栏分类&#xff1a;C &#x1f69a…

某卢小说网站登录密码逆向

js逆向&#xff0c;今晚找了一个小说网站&#xff0c;分析一下登录密码的解密逆向过程&#xff0c;过程不是很难&#xff0c;分享下 学习网站aHR0cHM6Ly91LmZhbG9vLmNvbS9yZWdpc3QvbG9naW4uYXNweA 这个就是加密后的密码&#xff0c;今晚就逆向它&#xff0c;其他参数暂时不研究…

python+pytorch人脸表情识别

概述 基于深度学习的人脸表情识别&#xff0c;数据集采用公开数据集fer2013&#xff0c;可直接运行&#xff0c;效果良好&#xff0c;可根据需求修改训练代码&#xff0c;自己训练模型。 详细 一、概述 本项目以PyTorch为框架&#xff0c;搭建卷积神经网络模型&#xff0c;训…

【中间件篇-Redis缓存数据库02】Redis高级特性和应用(慢查询、Pipeline、事务、Lua)

Redis高级特性和应用(慢查询、Pipeline、事务、Lua) Redis的慢查询 许多存储系统&#xff08;例如 MySQL)提供慢查询日志帮助开发和运维人员定位系统存在的慢操作。所谓慢查询日志就是系统在命令执行前后计算每条命令的执行时间&#xff0c;当超过预设阀值,就将这条命令的相关…

腾讯云双11优惠活动有哪些?详细攻略来了!

2023年腾讯云双11大促活动正在火热进行中&#xff0c;百款热门云产品11.11云上盛惠&#xff0c;领折上折代金券最高再省9999元&#xff0c;助力开发者轻松上云&#xff01; 一、腾讯云双11活动入口 活动地址&#xff1a;点此直达 二、腾讯云双11活动时间 即日起至2023-11-30…

基于SSM的电动车上牌管理系统设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;采用JSP技术开发 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#x…

2012年计网408

第33题 在 TCP/IP 体系结构中, 直接为 ICMP 提供服务的协议是()A. PPPB. IPC. UDPD. TCP 本题考察TCP/IP体系结构中直接为ICMP协议提供服务的协议。如图所示。这是TCP/IP的四层体系结构。网际层的IP协议是整个体系结构中的核心协议&#xff0c;用于网络互联。网际控制报文协议…

MongoDB副本集特点验证

MongoDB副本集特点验证 mogodb副本集概述副本集搭建副本集结构验证结果源码地址 mogodb副本集概述 MongoDB副本集是将数据同步在多个服务器的过程。 复制提供了数据的冗余备份&#xff0c;并在多个服务器上存储数据副本&#xff0c;提高了数据的可用性&#xff0c; 并可以保证…

To create the 45th Olympic logo by using CSS

You are required to create the 45th Olympic logo by using CSS. The logo is composed of five rings and three rectangles with rounded corners. The HTML code has been given. It is not allowed to add, edit, or delete any HTML elements. 私信完整源码 <!DOCT…

MFC-TCP网络编程服务端-Socket

目录 1、通过Socket建立服务端&#xff1a; 2、UI设计&#xff1a; 3、代码的实现&#xff1a; &#xff08;1&#xff09;、CListenSocket类 &#xff08;2&#xff09;、CConnectSocket类 &#xff08;3&#xff09;、CTcpServerDlg类 1、通过Socket建立服务端&#xff…

分享一本让你真正理解深度学习的书

关注微信公众号&#xff1a;人工智能大讲堂&#xff0c;后台回复udl获取pdf文档。 今天要分享的书是Understanding Deep Learning&#xff0c;作者是西蒙普林斯&#xff0c;英国巴斯大学的荣誉教授&#xff0c;其个人学术能力相当强大&#xff0c;在AI领域有着深厚的学术造诣。…

网络唤醒(Wake-on-LAN, WOL)

远程唤醒最简单的方法&#xff1a;DDNSTOOpenwrt网络唤醒&#xff0c;完美实现。 原帖-远程唤醒_超详细windows设置远程唤醒wol远程连接&#xff08;远程开机&#xff09; WOL Web# 访问 Wake on Lan Over The Interweb by Depicus 可以无需借助软件很方便的从网页前端唤醒远…

MATLAB / Simulink HDL 快速入门

MATLAB / Simulink HDL 快速入门 我们将使用实例讲解MATLAB / Simulink HDL 使用入门。 开始这个项目&#xff0c;首先需要创建一个包含 Stateflow 的新 Simulink 。只需单击画布中的任意位置并开始输入 Stateflow。 此时应该能在画布上看到 Stateflow 图标。双击图标进行编辑。…

使用xlwings获取excel表的行和列以及指定单元格的值

import xlwings as xw app xw.App(visibleFalse) # 隐藏Excel wb app.books.open(文档1.xlsx) # 打开工作簿sht wb.sheets[Sheet1] # 实例化工作表1#获取行数和列数 rows_countsht.range(1, 1).expand().shape[0] cols_countsht.range(1, 1).expand().shape[1] print(row…

Unity 利用UGUI制作圆形进度条

在Unity中使用Image和Text组件就可以制作简单的进度条。 1、首先准备好一张环状的PNG图&#xff0c;如下图。 2、把该图导入Unity中并转换成精灵。 3、在场景中创建Image和Text组件&#xff0c;并把上图中的精灵拖到Image的Source Image中&#xff0c;其中Image组件中的Image …

数据采集中的基本参数

分辨率(resolution) 分度数量越多则分辨率越高&#xff0c;测量精度也越高 区间(range) 模数转换所能处理模拟信号电平的极限 应尽量使输入与此区间匹配&#xff0c;物尽其用 信号极限幅度集合 所测信号的最大值和最小值 应与输入信号的最大值和最小值相接近 LSB 最低有效…

[云原生案例2.2 ] Kubernetes的部署安装 【单master集群架构 ---- (二进制安装部署)】网络插件部分

文章目录 1. Kubernetes的网络类别2. Kubernetes的接口类型3. CNI网络插件 ---- Flannel的介绍及部署3.1 简介3.2 flannel的三种模式3.3 flannel的UDP模式工作原理3.4 flannel的VXLAN模式工作原理3.5 Flannel CNI 网络插件部署3.5.1 上传flannel镜像文件和插件包到node节点3.5.…

springboot内容协商

1.基于请求头 Accept: application/json Accept: application/xml Accept: application/xxx 自定义数据 发的请求头的数据类型 期望返回的数据类型 2.通过请求参数 例如 /football?formatjson 一般respondbody 默认以json方式进行返回 如何请求同一个接口&#xff0c;可以…