如何进行MySQL的主从复制(MySQL5.7)

  1. 背景:在一些Web服务器开发中,系统用户在进行数据访问时,基本都是直接操作数据库MySQL进行访问,而这种情况下,若只有一台MySQL服务器,可能会存在如下问题
            
    1. 数据的读和写的所有压力都会由一台数据库独立承担,压力太大
    2. 数据库服务器磁盘损坏等原因则会导致数据丢失,出现单点故障问题
  2. 那为了解决这两个问题,我们可以准备两台MySQL服务器,一台主(master)服务器,一台从(slave)服务器,若主库的数据存在变更时,需要同步到从库中,称为主从复制。而用户在访问我们的Web项目时,如果是写操作(insert、update、delete)则直接操作主库即可;如果是读(select)操作,则直接操作从库,同时在这种读写分离的结构中,从库我们是可以有多个的这种结构,这种方式我们可称为读写分离。     
  3. 因为MySQL数据库默认是支持主从复制的,所以我们并不需要借助于其他的技术,只要在数据库中进行简单的配置即可实现。那么接下来我们开始进行MySQL的主从复制的操作
  4. 主从复制的简单介绍
    1. MySQL主从复制是一个异步的复制过程,底层是基于MySQL的数据库自带的二进制日志功能。就是从一台或多台MySQL数据库(slave,从库)从另一台MySQL数据库(master,主库)进行日志的复制,然后再解析对应的日志并应用到自身,最终实现从库的数据和主库的数据保持一致。MySQL主从复制是MySQL数据库自带功能,无需借助第三方工具进行操作
  5. 本案例中仅通过一主一从来介绍主从复制的操作
    1. 首先我们先准备两台Linux服务器,并且在服务器上需要预先安装好MySQL数据库,同时我们已经将服务器的防火墙已经关闭,并将两台Linux系统的MySQL服务正常启动
      1. Linux操作系统:ubuntu-20.04-live-server-amd64
      2. MySQL数据库版本:5.7.40
    2. 首先进行主库配置
      1. 修改MySQL数据库的配置文件my.cnf文件,在文件最下面添加启用二进制日志功能
        1. # binlog日志
          server-id=101
          log-bin = /home/dev/dev-install/mysql-5.7.40/binlog/mysql-bin
          
        2. log-bin:[必须]启用二进制日志
          server-id:[必须]服务器唯一ID(唯一即可)
      2. 修改完配置文件需要重启MySQL服务
        1. ./mysql.server restart
    3. 主库中创建数据同步的用户并授权
      1. 登录MySQL,然后执行如下指令,创建用户并授权
        1. GRANT REPLICATION SLAVE ON *.* to 'syncdata'@'%' identified by 'Sync@Data123';
        2. 上面的指令是syncdata为用户,Sync@Data123为密码,从库在建立复制的时候需要用到用户授权,只有在有授权用户的前提下才能进行复制
    4. 登录MySQL的数据库,查看master主库的同步状态
      1. 执行如下指令,并将结果中的File和Position的信息记录下来
        1. show master status;
        2. 注意,查看上面的状态之后,不要再操作当前数据库了,也就是不要再执行任何指令,防止数据同步位置错误
    5. 开始进行从库的配置
      1. 修改MySQL数据库的配置文件my.cnf文件,在文件最下面添加设置服务器的唯一id
        1. server-id=102
        2. server-id:[必须]服务器唯一ID
      2. 重启MySQL服务
        1. ./mysql.server restart
    6. 登录从库的MySQL数据库,设置主库的地址以及对应的同步位置,依次执行下列指令
      1. change master to master_host='192.168.xxx.xxx',master_user='syncdata',master_password='Sync@Data123',master_log_file='mysql-bin.000009',master_log_pos=433;start slave;
      2. 上面的指令信息说明为:
        1. master_host :主库的IP地址,即需要根据实际情况的ip设定
        2. master_user :访问主库进行主从复制的用户名,也就是上面所在主库创建的
        3. master_password :访问主库进行主从复制的用户名对应的密码
        4. master_log_file : 从哪个日志文件开始同步,也就是上面查询master状态中展示的File
        5. master_log_pos : 从指定日志文件的哪个位置开始同步,也就是查询master状态中展示的Position
    7. 然后查看从库数据库的状态
      1. show slave status \G
      2. 可以通过状态信息中的 Slave_IO_Running 和Slave_SQL_Running 可以看出主从同步是否就绪,如果这两个参数全为Yes,则表示主从同步已经配置完成
    8. 若状态是Slave_IO_Running: No,Slave_SQL_Running: Yes,说明同步不成功,则需要前往MySQL的log错误日志查看报错信息
      1. 若出现文件[ERROR] Slave I/O for channel '': Fatal error: The slave I/O thread stops because master and slave have equal MySQL server UUIDs; these UUIDs must be different for replication to work. Error_code: 1593的解决方案
        1. 找到从数据库的该文件对应的 UUID,该文件为/home/dev/dev-install/mysql-5.7.40/data/auto.cnf,然后编辑auto.cnf,将里面uuid的值随便改一个即可,然后保存文件

        2. 保存完文件重新启动MySQL服务器即可
        3. 再次通过 show slave status \G 查看从数据库的状态
    9. 主从环境的测试
      1. 我们已经把主从复制的环境搭建好了,接下来我们可以通过Navicat连接上两台MySQL服务器进行测试,我们只需要在主库master上执行操作,然后再查看从库slave中是否将数据同步过去即可
        1. 主库创建数据库,刷新并查看从库是否可以正常同步过去
        2. 可以发现主库创建的数据库已经同步到从库,证明主从复制已经验证成功

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

postgresql-shared_buffers参数详解

shared_buffers 是 PostgreSQL 中一个非常关键的参数,用于配置服务器使用的共享内存缓冲区的大小。这些缓冲区用于存储数据页,以便数据库可以更快地访问磁盘上的数据。 这个参数在 PostgreSQL 的性能方面有着重要的影响。增加 shared_buffers 可以提高数…

【网络奇缘】- 计算机网络|分层结构|ISO模型

🌈个人主页: Aileen_0v0🔥系列专栏: 一见倾心,再见倾城 --- 计算机网络~💫个人格言:"没有罗马,那就自己创造罗马~" 目录 计算机网络分层结构 OSI参考模型 OSI模型起源 失败原因: OSI模型组成 协议的作用 📝全文…

阿里入局鸿蒙!鸿蒙原生应用再添两员新丁

今日HarmonyOS微博称,阿里钉钉、蚂蚁集团旗下的移动开发平台mPaaS与华为达成合作,宣布启动鸿蒙原生应用的开发!相关应用将以原生方式适配#HarmonyOS NEXT#系统。 #HarmonyOS#市场或迎来爆发式增长! 阿里钉钉 阿里钉钉与华为达成合…

每日一题:LeetCode-103/107.二叉树的(层序/锯齿形层序)遍历

每日一题系列(day 04) 前言: 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 🌈 &#x1f50e…

成为AI产品经理——模型构建过程(上)

目录 一、背景 1.对内 2.对外 二、模型构建过程 1.模型设计 2.特征工程 ① 数据清洗 ② 特征提取 数值型数据 标签/描述类数据特征 非结构化数据(处理文本特征) 网络关系型数据 ③ 特征选择 ④ 训练集/测试集 一、背景 虽然产品经理不…

基于SSM的网络财务管理系统设计与实现

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

nuxt、vue实现PDF和视频文件的上传、下载、预览

上传 上传页面 <el-form-item :label"(form.ququ3 1 ? 参培 : form.ququ3 2 ? 授课 : ) 证明材料" prop"ququ6"><PdfUpload v-model"form.ququ6" :fileType"[pdf, mp4, avi, ts]"></PdfUpload> </el-form-i…

Java游戏制作——王者荣耀

一.准备工作 首先创建一个新的Java项目命名为“王者荣耀”&#xff0c;并在src下创建两个包分别命名为“com.sxt"、”com.stx.beast",在相应的包中创建所需的类。 创建一个名为“img”的文件夹来储存所需的图片素材。 二.代码呈现 package com.sxt;import javax.sw…

Android开源框架--Dagger2详解

功名只向马上取&#xff0c;真是英雄一丈夫 一&#xff0c;定义 我们知道在一个类中&#xff0c;通常会定义其他类型的变量&#xff0c;这个变量就是我们所说的“依赖“。 对一个类的变量进行初始化&#xff0c;有两种方式。第一种&#xff0c;这个类自己进行初始化&#xff…

【Vue】Vue3 配置全局 scss 变量

variables.scss $color: #0c8ce9;vite.config.ts // 全局css变量css: {preprocessorOptions: {scss: {additionalData: import "/styles/variables.scss";,},},},.vue 文件使用

血的教训------入侵redis之利用python来破解redis密码

血的教训------入侵redis之利用python来破解redis密码 利用强大的python来进行redis的密码破解&#xff0c;过程不亦乐乎&#xff0c;当然也可以用shell脚本 本篇文章只供学习交流&#xff0c;请勿他用&#xff0c;谢谢。 其他相关联的文章 [1]VMware安装部署kail镜像服务器【…

Spring Boot创建和使用(重要)

Spring的诞生是为了简化Java程序开发的&#xff01; Spring Boot的诞生是为了简化Spring程序开发的&#xff01; Spring Boot就是Spring框架的脚手架&#xff0c;为了快速开发Spring框架而诞生的&#xff01;&#xff01; Spring Boot的优点&#xff1a; 快速集成框架&#x…

git的用法

目录 一、为什么需要git 二、git基本操作 2.1、初始化git仓库 2.2、配置本地仓库的name和email 2.3、认识工作区、暂存区、版本库 三、git的实际操作 3.1 提交文件 3.2 查看git状态以及具体的修改 3.3 git版本回退 git reset 3.1 撤销修改 四、git分支管理 4.…

fastjson和jackson序列化的使用案例

简单记录一下一个fastjson框架和jackson进行序列化的使用案例&#xff1a; 原json字符串&#xff1a; “{“lockCount”:”{1:790,113:1,2:0,211:0,101:1328,118:8,137:0,301:0,302:0}“,“inventoryCount”:”{1:25062,113:2,2:10000,211:2,101:11034,118:9,137:40,301:903914…

【数据库】聊聊一颗B+树 可以存储多少数据

我们知道数据库使用的数据结构是B树&#xff0c;但是B树可以存储多少数据呢&#xff0c;在面试中也是经常会问的问题&#xff0c;所以我们从根上理解这个问题。 操作系统层面 数据都是存储在磁盘中的&#xff0c;而磁盘中的数据都是以最新单位扇区进行分割。一个扇区的大小是…

大数据平台/大数据技术与原理-实验报告--MapReduce编程

实验名称 MapReduce编程 实验性质 &#xff08;必修、选修&#xff09; 必修 实验类型&#xff08;验证、设计、创新、综合&#xff09; 综合 实验课时 2 实验日期 2023.10.30-2023.11.03 实验仪器设备以及实验软硬件要求 专业实验室&#xff08;配有centos7.5系统…

Cortex-M与RISC-V区别

环境 Cortex-M以STM32H750为代表&#xff0c;RISC-V以芯来为代表 RTOS版本为RT-Thread 4.1.1 寄存器 RISC-V 常用汇编 RISC-V 关于STORE x4, 4(sp)这种寄存器前面带数字的写法&#xff0c;其意思为将x4的值存入sp4这个地址&#xff0c;即前面的数字表示偏移的意思 反之LOA…

论文阅读:“Model-based teeth reconstruction”

文章目录 AbstractIntroductionTeeth Prior ModelData PreparationParametric Teeth Model Teeth FittingTeeth Boundary Extraction Reference Abstract 近年来&#xff0c;基于图像的人脸重建方法日趋成熟。这些方法可以捕捉整个面部或面部特定区域&#xff08;如头发、眼睛…

探索H5的神秘世界:测试点解析

Html5 app实际上是Web app的一种&#xff0c;在测试过程中可以延续Web App测试的部分方法&#xff0c;同时兼顾手机端的一些特性即可&#xff0c;下面帮大家总结下Html5 app 相关测试方法&#xff01; app内部H5测试点总结 1、业务逻辑 除基本功能测试外&#xff0c;需要关注的…

【微服务专题】微服务架构演进

目录 前言阅读对象阅读导航前置知识笔记正文一、系统架构的演变1.1 单体架构1.2 单体水平架构1.3 垂直架构1.4 SOA架构1.5 微服务架构 二、如何实现微服务架构2.1 微服务架构下的技术挑战2.2 微服务技术栈选型2.3 什么是Spring Cloud全家桶2.4 Spring Cloud Alibaba版本选择 学…