数据库进阶教学——主从复制(Ubuntu22.04主+Win10从)

目录

一、概述

二、原理

三、搭建

1、备份数据

2、主库配置Ubuntu22.04

2.1、设置阿里云服务器安全组

2.2、修改配置文件 /etc/my.cnf

2.3、重启MySQL服务

2.4、登录mysql,创建远程连接的账号,并授予主从复制权限

2.5、通过指令,查看二进制日志坐标

3、从库配置Win10

3.1、修改配置文件my.ini

3.2、重启mysql服务器

3.3、登录mysql,设置主库配置

3.4、开启同步操作

3.5、查看主从同步状态

4、测试

4.1、在主库上创建数据库、表,并插入数据 

4.2、查看从库的变化


一、概述

  • 主从复制是指将主数据库的 DDL 和 DML 操作通过二进制日志传到从库服务器中,然后在从库上对这些日志重新执行(重做),从而使得从库和主库的数据保持同步。
  • MySQL支持一台主库 (Master)同时向多台从库 (Slave)进行复制,从库同时也可以作为其他从服务器的主库,实现链状复制。
  • 主从复制的优势:
    • 主库出现问题,可以快速切换到从库提供服务。
    • 实现读写分离,降低主库的访问压力。(增删改操作主库,查询请求操作从库)
    • 可以在从库中执行备份,以避免备份期间影响主库服务。

二、原理

  • 数据库主要使用二进制日志实现主从复制。
  • Master主库在事务提交时,会把数据变更记录在二进制日志文件Binlog中。
  • 从库读取主库的二进制日志文件,写入到从库的中继日志Relay log中。
  • slave从库重做中继日志中的事件,改变它自己的数据。

三、搭建

  • 主机:阿里云服务器 Ubuntu22.04
    • 申请阿里云服务器,使用Xshell连接(SSH协议22号端口)。
  • 从机:本地电脑 Win10
    • 【注】我这的本地电脑没有公网,所以只能作为从机。
  • 数据库:Mysql8.0.34
    • 【注】主机和从机的数据库版本要一致。

1、备份数据

  • 因为我本地已经安装了mysql,并且有一些数据,而阿里云服务器上的mysql是新安装的。所以首先需要让本地主机和阿里云服务器上的mysql数据保持一致。 
  • 【注】如果主从服务器的mysql都是新安装的,这个一步就不需要。因为新安装的master和slave有相同的数据。
  • 在本地主机上,使用mysqldump将数据库所有信息导出到all.sql中。
    • mysqldump -u root -p --all-databases > D:\Desktop\all.sql
  • 登陆阿里云服务器的数据库导入all.sql数据。
    • 首先要把本地导出的.sql文件上传到服务器。具体看:服务器——Windows将本地文件上传到Linux服务器-CSDN博客
    • source /home/all.sql
    • 此时,主库和从库的数据就保持一致了。

2、主库配置Ubuntu22.04

2.1、设置阿里云服务器安全组
  • 首先需要设置阿里云服务器上的访问规则,这样本地主机才能连接上阿里云服务器的数据库。
  • 开放服务器的3306端口。
2.2、修改配置文件 /etc/my.cnf
  • 修改内容:
    • mysql服务ID,保证整个集群环境中唯一,取值范围:1\sim 2^{32}-1,默认为1。
      • server-id=1
2.3、重启MySQL服务
  • sudo service mysql restart
2.4、登录mysql,创建远程连接的账号,并授予主从复制权限
  • 创建master用户,并设置密码,该用户可在任意主机连接该MySOL服务,并分配主从复制权限。
    • CREATE USER 'master'@'%' IDENTIFIED WITH mysql_native_password BY '123456';  # 创建用户
      GRANT REPLICATION SLAVE ON *.* TO 'master'@'%';  # 分配主从复制权限
      flush privileges;  # 刷新权限
  • 查看用户是否创建成功。
    • select user,host from mysql.user;
  • 删除用户命令。
    • drop user 'master'@'%';
2.5、通过指令,查看二进制日志坐标
  • show master status;
  • 字段含义说明:
    • file:从哪个日志文件开始推送日志文件。
    • position:从哪个位置开始推送日志。
    • binlog_ignore_db:指定不需要同步的数据库。

3、从库配置Win10

3.1、修改配置文件my.ini
  • my.ini位置: 
  • 修改内容:
    • mysql服务ID,保证整个集群环境中唯一,取值范围:1\sim 2^{32}-1,和主库不一样即可。
      • server-id=2
  • 【注】原先文件中可能已经设置了server-id,找到修改即可。
3.2、重启mysql服务器
  • Win+R,输入services.msc,找到MySQL重启即可。
3.3、登录mysql,设置主库配置
  • CHANGE REPLICATION SOURCE TO SOURCE_HOST='123.56.xxx.xxx', SOURCE_USER='master', SOURCE_PASSWORD='123456', SOURCE_LOG_FILE='binlog.000006', SOURCE_LOG_POS=1033;
    #  SOURCE_HOST             主机IP地址
    #  SOURCE_USER             连接主库的用户名
    #  SOURCE_PASSWORD         连接主库的密码
    #  SOURCE_LOG_FILE         binlog日志文件名
    #  SOURCE_LOG_POS          binlog日志文件位置
3.4、开启同步操作
  • start replica;
3.5、查看主从同步状态
  • show replica status\G;
  • 主要看下面两个值,必须为yes。

4、测试

4.1、在主库上创建数据库、表,并插入数据 
  • create database db01;
    use db01;
    create table tb_user(
        id int(11) primary key not null auto_increment,
        name varchar(50) not null,
        sex varchar(1)
    )engine=innodb default charset=utf8mb4;
    insert into tb_user(id,name,sex) values(null,'Tom', '1'),(null,'Trigger','0'),(null,'Dawn','1');
  •  执行为上述命令后,查看主库的数据。
4.2、查看从库的变化
  • 从库的数据完全与主库保持一致。

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

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

相关文章

进程终结之道:kill与pskill的神奇战斗

欢迎来到我的博客,代码的世界里,每一行都是一个故事 进程终结之道:kill与pskill的神奇战斗 前言基本用法kill命令:基础语法:选项:示例: pskill命令:基础语法:选项&#x…

kbdnecnt.DLL文件缺失,软件或游戏无法启动运行,怎样快速修复?

不少人都在问“kbdnecnt.DLL文件”是什么?为什么电脑总是报错提示说“kbdnecnt.DLL文件缺失,软件无法启动”? 首先,先来了解“kbdnecnt.DLL文件”是什么? kbdnecnt.DLL是Windows操作系统中的一个动态链接库文件&#…

JOSEF约瑟 断电延时继电器 SRTD-220VDC-2H2D 导轨安装

系列型号: SRTD-24VDC-1H1D断电延时继电器;SRTD-110VDC-1H1D断电延时继电器; SRTD-220VDC-1H1D断电延时继电器;SRTD-110VAC-1H1D断电延时继电器; SRTD-220VAC-1H1D断电延时继电器;SRTD-24VDC-2H断电延时继电…

考PMP真的有用吗?看完立马不犹豫了!

其实我个人觉得在你考证之前,值得反思的是:为什么要考这个证书?是因为公司需要?个人职业发展?还是受到新闻报道或广告的影响,觉得PMP证书有价值,只是想了解一下。这样就会导致很多人会说&#x…

golang并发编程-channel

在golang 并发编程里,经常会听到一句话:不要通过共享内存进行通信,通过通信来共享内存。下面我们会介绍下channel, 通过源码的方式去了解channel是怎么工作的。 基本结构 流程图 代码解读 type hchan struct {qcount uint // …

HubSpot邮件营销好用吗?

HubSpot的邮件营销工具通常被认为是非常强大和易用的,但用户的体验和满意度会因个人需求和经验而异。以下是一些通常与HubSpot邮件营销工具相关的优势: 全面的功能: HubSpot的邮件营销工具提供了丰富的功能,包括电子邮件自动化、…

西门子消防主机电源维修控制器BCB8005

火灾自动报警部分主要由各个部位的火灾探测器及手动报警按钮、消火栓按钮等设备组成。火灾探测器就如同火灾报警系统的“眼睛”,通过各自的火灾探测器采集现场的火警信号,实时传送给火灾报警控制器,火灾报警控制器进行各种智能的分析判断后发出火灾报警&…

【力扣题解】P700-二叉搜索树中的搜索-Java题解

👨‍💻博客主页:花无缺 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 本文由 花无缺 原创 收录于专栏 【力扣题解】 文章目录 【力扣题解】P700-二叉搜索树中的搜索-Java题解🌏题目描述💡题解&#x1f…

Python 从入门到精通之通俗易懂学闭包

系列 Python从入门到精通之安装与快速入门-CSDN博客 Python从入门到精通之基本数据类型和变量-CSDN博客 Python从入门到精通之集合(List列表、Tuple元组、Dict字典、Set)-CSDN博客 Python从入门到精通之条件语句、循环语句和函数-CSDN博客 Python从…

【双指针算法】-- 左右指针

左右指针 前言一、双指针算法二、左右指针1.用于在已排序数组中找到两个数使其和为特定值2.在字符串中判断是否为回文 总结 前言 今天在刷Leetcode的时候觉得自己双指针掌握的还是不错的记录一下,写个学习笔记,也方便以后翻阅,如果也帮助到你了,那真是太好啦! 本篇介绍的是左右…

八大算法排序@希尔排序(C语言版本)

目录 希尔排序概念算法思想示例分析结论算法步骤选择增量序列按增量分组逐步缩小增量 算法优势 代码实现核心算法希尔排序代码实现: 时间复杂度空间复杂度特性总结 该排序会关联到直接插入排序的知识点,如果对于直接插入排序还有所疑惑,可以跳…

Stable Diffusion模型概述

Stable Diffusion 1. Stable Diffusion能做什么?2. 扩散模型2.1 正向扩散2.2 反向扩散 3. 训练如何进行3.1 反向扩散3.2 Stable Diffusion模型3.3 潜在扩散模型3.4 变分自动编码器3.5 图像分辨率3.6 图像放大 4. 为什么潜在空间是可能的?4.1 在潜在空间中…

uniapp:签字版、绘画板 插件l-signature

官方网站:LimeUi - 多端uniapp组件库 使用步骤: 1、首先从插件市场将代码下载到项目 海报画板 - DCloud 插件市场 2、下载后,在项目中的uni_modules目录 3、最后 没有其它步骤,直接官网代码复制到vue文件中就可以了&#xff0c…

挑战 ChatGPT 和 Google Bard 的防御

到目前为止,科学家已经创建了基于人工智能的聊天机器人,可以帮助内容生成。我们还看到人工智能被用来创建像 WormGPT 这样的恶意软件,尽管地下社区对此并不满意。但现在正在创建聊天机器人,可以使用生成人工智能通过即时注入活动来…

stable diffusion 基础教程-文生图

置顶大模型插件资源链接 你如果没有魔法上网,请自取 百度云盘链接:链接:https://pan.baidu.com/s/1_xAu47XMdDNlA86ufXqAuQ?pwd=23wi 提取码:23wi 界面介绍 参数解释 参数解释Sampling method扩散去噪算法的采样模式,不同采样模式会带来不一样的效果steps模型生成图片的迭…

OpenCV-Python(24):模板匹配

原理及介绍 模板匹配是一种常用的图像处理技术,它用于在一幅图像中寻找与给定模板最匹配的区域(在一副大图中搜寻查找模版图像位置的方法)。模板匹配的基本思想是将模板图像在目标图像上滑动,并计算它们的相似度,找到相似度最高的位置即为匹配…

Docsify:一款便捷的文档生成工具

一、产品介绍 Docsify是一个简单、易用的文档生成工具。它允许用户使用Markdown编写文档,然后一键生成静态网站。这样,我可以方便地将我的知识库和项目文档分享给他人,同时还能保持文档的更新和完整性。 二、应用场景 非常适合个人知识库、…

Redis缓存与数据库如何保证一致性

数据库和缓存如何保证一致性? 目录 数据库和缓存如何保证一致性?背景方案先更新数据库,还是先更新缓存?先更新数据库,再更新缓存先更新缓存,再更新数据库 先更新数据库,还是先删除缓存&#xff…

代码随想录刷题笔记(DAY4)

今日总结:今天把中心放在前端学习上,最后一个题没有完全理解,明天早起补上吧。勉强算完成任务。(已补上) Day 4 01. 两两交换链表中的节点(No. 24) 题目链接 代码随想录题解 1.1 题目 给你…

Python高级用法:装饰器(decorator)

装饰器(decorator) Python装饰器的作用是使函数包装与方法包装(一个函数,接受函数并返回其增强函数)变得更容易阅读和理解。最初的使用场景是在方法定义的开头能够将其定义为类方法或静态方法。 不使用装饰器的代码如…