MySQL:运维管理-主从复制

目录

    • 一、主从复制的概述
    • 二、主从复制的工作原理
    • 三、搭建主从复制的结构
      • 3.1 环境准备
      • 3.2 搭建配置(主库配置)
      • 3.3 搭建配置(从库配置)
      • 3.4 测试


在这里插入图片描述

一、主从复制的概述

主从复制是指将主数据库中的DDL和DML操作的二进制文件保存到本地,然后将本地的二进制文件传递到从数据库中,从数据库重新执行二进制文件(重做),从而保证主库和从库的数据一致性。
MySQL支持一台主库向多台从库进行复制,从库也可以当做其他从数据库的主库,实现链状复制。

MySQL主从复制的优点:

  • 当主库出现问题时,可以快速的切换到从数据库。
  • 实现读写分离,主从负责DML,从库负责DDL,降低主库压力。
  • 可以在从库中进行数据备份,以避免在备份期间影响主库服务。

主库叫做Master,从库叫做Slave

二、主从复制的工作原理

在这里插入图片描述

  1. Master主库在提交事务时(DML),会把数据变更记录在二进制日志Binlog中。
  2. 从库通过IOthread读取主库中的二进制日志文件Binlog,写入到从库的中继日志Relay Log。
  3. Slave通过SQLthread读取中继日志并重做日志中的事件,将改变反应到自己的数据库中。

三、搭建主从复制的结构

3.1 环境准备

在这里插入图片描述

  1. 开放指定端口或者直接关闭防火墙
  2. 在两台电脑上都安装好MySQL数据库,并完成基础的初始化做准备工作。

3.2 搭建配置(主库配置)

  1. 修改配置文件/etc/my.cnf
[mysqld]
bind-address=0.0.0.0
port=3306
user=mysql
basedir=/soft/mysql
datadir=/data/mysql
socket=/tmp/mysql.sock
log-error=/data/mysql/mysql.err
pid-file=/data/mysql/mysql.pid
#character config
character_set_server=utf8mb4
symbolic-links=0
explicit_defaults_for_timestamp=true# mysql服务器ID,保证整个集群环境中的唯一性,默认为1
server-id=1
# 是否只读 1=只读 0=读写
read-only=0
# 忽略的数据,指不需要同步的数据库
# binlog-ignore-db=mysql
# 指定同步的数据库
# binlog-do-db=db01log-bin=mysql-bin # 开启二进制日志server-uuid=85dba00a-e0ef-11e9-b341-000c29812345
  1. 重启MySQL服务器
systemctl restart mysqld
  1. 查看MySQL服务状态
systemctl status mysqld
  1. 登录MySQL,创建远程连接的账号,并赋予主从复制的权限
# 创建itcast用户,并设置密码,该用户可以在任意主机连接该MySQL服务
CREATE USER 'itcast'@'%' IDENTIFIED WITH mysql_native_password BY 'root@123456';
# 为 'itcast'@'%' 分配主从复制的权限
GRANT REPLICATION SLAVE ON *.* TO 'itcast'@'%';
  1. 通过指令,查看二进制坐标
SHOW MASTER STATUS;

字段含义:

  • file:从哪个日志文件开始推送日志
  • position:从哪个位置开始推送日志
  • binlog_ignore_db:指定不需要同步的数据库

3.3 搭建配置(从库配置)

  1. 修改配置文件/etc/my.cnf
# 开启二进制日志
log-bin=mysql-bin 
# mysql服务器uuid
server-uuid=6cd3023d-6ec6-11ef-a4a6-000c29bb681a
# mysql服务器ID,保证整个集群环境中的唯一性,默认为1
server-id=2
# 是否只读 1=只读 0=读写
read-only=1
# 上面的只读只能针对普通用户,如果想要针对超级管理员的话需要设置一下内容
# super-read-only=1
  1. 重启MySQL服务器
systemctl restart mysqld
  1. 查看MySQL服务状态
systemctl status mysqld
  1. 登录MySQL关联主库信息
CHANGE REPLICATION SOURCE TO SOURCE_HOST='XXX.XXX', SOURCE_USER='XXX', SOURCE_PASSWORD='XXX',SOURCE_LOG_FILE='XXX', SOURCE_LOG_POS='XXX';

上述是8.0.23中的语法。如果MySQL的版本是8.0.23之前的版本:

CHANGE MASTER TO MASTER_HOST='XXX.XXX', MASTER_USER='XXX', MASTER_PASSWORD='XXX',MASTER_LOG_FILE='XXX', MASTER_LOG_POS='XXX';
参数名含义8.0.23之前
SOURCE_HOST主库IP地址MASTER_HOST
SOURCE_USER连接主库的用户名MASTER_USER
SOURCE_PASSWORD连接主库的密码MASTER_PASSWORD
SOURCE_LOG_FILEbinlog日志文件名MASTER_LOG_FILE
SOURCE_LOG_POSbinlog日志文件位置MASTER_LOG_POS
  1. 开启同步操作
start replica; # 8.0.22之后的版本
start slave; # 8.0.22之前的版本
  1. 查看主从同步状态
show replica status;  # 8.0.22之后的版本
show slave status;  # 8.0.22之前的版本

在这里插入图片描述

3.4 测试

  1. 在主库中创建数据库创建表
create database db01;
user 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(name, sex) values("Tom", "1"),("Trigger", "0"),("Dawn", "1");
  1. 在从库中查询数据,查看数据是否一致。

如果从库想要同步主库之前的数据,需要将主库中的数据导出为SQL脚本,在从库中执行。
注意:主从数据库一定要配置server-id和server-uuid,并且主从数据库的id、uuid要保持唯一性

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

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

相关文章

小间距LED显示屏的模组与箱体参数

随着显示技术的发展,小间距LED显示屏因其高清晰度和高亮度而越来越受到市场的欢迎。然而,对于许多用户来说,如何理解和选择小间距LED显示屏的参数可能是一个挑战。本文将详细介绍小间距LED显示屏的两大核心参数:模组参数和箱体参数…

Python画笔案例-045 绘制渐变圆盘

1、绘制 渐变圆盘 通过 python 的turtle 库绘制 渐变圆盘,如下图: 2、实现代码 绘制 渐变圆盘,以下为实现代码: """本程序需要coloradd模块支持,安装方法pip install coloradd """ import turtle …

2024年解锁高效项目管理的秘密:AI赋能的10款项目管理工具大比拼

在数字化转型的浪潮中,项目经理、产品经理、研发管理者以及企业管理者们正面临着前所未有的挑战。如何在快节奏的环境中保持高效,确保项目按时交付,同时保证质量,成为了每个团队都需要思考的问题。幸运的是,随着AI技术…

如何用python打开csv文件路径

python读取CSV文件方法: 方法1:可先用以下代码查看当前工作路径,然后将CSV文件放在该路径下。 import os os.getcwd() 方法2:(绝对路径) import pandas as pd iris_trainpd.read_csv(E:\Study\DataSets\ir…

武汉传媒学院联合创龙教仪建设DSP教学实验箱,基于DSP C6000平台搭建

1、院校简介 武汉传媒学院是中南地区唯一一所传媒类本科高校,也是湖北省“转型发展”首批试点高校 前身是2004年成立的华中师范大学武汉影视工程学院,2007年经教育部批准更名为华中师范大学武汉传媒学院,2016年,经教育部批准&…

BizDevOps落地实践

我理解BizDevOps就是端到端,从战略业务机会到开发上线 参考资料 十六年所思所感,聊聊这些年我所经历的 DevOps 系统 必致(BizDevOps)白皮书2022免费下载_在线阅读_藏经阁-阿里云开发者社区 具体落地实践 战略规划 战略&…

【网络安全】服务基础第二阶段——第五节:Linux系统管理基础----Linux常见应用服务(Apache、数据库)

在Linux系统中,有许多常见的应用服务,它们用于执行各种任务,如网页托管、数据库管理、文件传输等。 Apache HTTP Server:用于托管网站和Web应用程序的Web服务器。Nginx:高性能的Web服务器和反向代理服务器&#xff0c…

使用CUBE_MX实现STM32 DMA 功能(存储器到存储器)

目录 一、使用DMA实现从存储器1发送数据到存储器2中 1.CUBE_MX配置 2.KEIL5配置 一、使用DMA实现从存储器1发送数据到存储器2中 1.CUBE_MX配置 1.在DMA选项中添加MEMORY TO MEMORY 选择数据宽度,并确保地址递增功能打开。 2.系统时钟72MHz 3.生成代码 2.KEIL5配…

echarts饼图内容循环播放实现

echarts饼图内容循环播放实现 效果展示思路难点代码实现 效果展示 思路 先实现普通的饼图&#xff0c;再处理数据内容&#xff1a;使用for循环延时器实现数据分割&#xff0c;数据处理好后再进行渲染。 难点 数据分割 代码实现 <template><div :class"classN…

vue3 使用swiper制作带缩略图的轮播图

效果图 实现代码 <template><div class"wrap"><!-- 主轮播图 --><swiper :style"{--swiper-navigation-color: #fff,--swiper-pagination-color: #fff,}" :modules"modules" :navigation"true" :thumbs"{ …

基于微信小程序的高校实验室管理系统的设计与实现

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、SSM项目源码 系统展示 基于微信小程序JavaSpringBootVueMySQL的高…

“他人笑我太疯癫,我笑他人看不穿“,关于因回复慢后,被骂事件,做知识分享,不是你理所应当的索要

原文链接&#xff1a;“他人笑我太疯癫&#xff0c;我笑他人看不穿" 引言 他人笑我太疯癫&#xff0c;我笑他人看不穿 大家好&#xff0c;这里是小杜本杜&#xff0c;今天又是一篇情绪篇&#xff0c;虽然这样的事情在我这里并不是时常发生。 然而&#xff0c;这样的事…

COCOS:(飞机大战09)敌机注册碰撞事件,控制敌机的销毁

先区分要监听谁&#xff0c;子弹打到飞机上&#xff0c;飞机去播放动画&#xff0c;并完成销毁操作&#xff0c;注册碰撞事件就写在飞机上。 飞机预制体都绑定了Enemy.ts,注册事件就写到这个文件内 import { _decorator, Animation, Collider2D, Component, Contact2DType, …

postman互转 json报文变为表单报文bulk

{"age":0"username":"chengyaojin""password":"944621""createDate":"2021-01-06" }age:0 username:chengyaojin password:944621 createDate:2021-01-06json转postman的bulk工具推荐在线json与postman…

Benvista PhotoZoom Pro / Classic 9.0.2 Win/mac + Plug-in中文破解版

对数码照片放大的质量不满意&#xff1f; 使用 BenVista PhotoZoom Classic9 调整图像大小&#xff0c;并通过我们屡获殊荣的独特 S-Spline 技术获得出色的效果&#xff01; 更高质量&#xff1a;PhotoZoom Classic9 专门用于在保持质量的同时放大照片。 该软件配备了 BenVista…

C++ 在项目中使用Linux命令

一: 选择shell Linux 命令是由shell解析并转发给操作系统执行的&#xff0c;所有的shell都是从 Bourne shell&#xff08;/bin/sh&#xff09;派生的&#xff0c;Bourne shell是贝尔实验室为早期版本的Unix开发的标准shell。 每个Unix系统都需要一个版本的Bourne shell才能正…

你还在手动重复工作吗?用PowerShell让电脑为你跑腿!

嘿,朋友,你有没有遇到过这种情况?每天都要做一些重复、无聊的工作,觉得自己简直像个机器人。比如整理文件、备份数据、批量重命名……说实话,干这些事可真浪费时间!但你有没有想过,让电脑自己去搞定这些烦人的任务?这就是今天我们要聊的——PowerShell,一个能帮你轻松…

论文翻译:ICLR-2024 PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS

PROVING TEST SET CONTAMINATION IN BLACK BOX LANGUAGE MODELS https://openreview.net/forum?idKS8mIvetg2 验证测试集污染在黑盒语言模型中 文章目录 验证测试集污染在黑盒语言模型中摘要1 引言 摘要 大型语言模型是在大量互联网数据上训练的&#xff0c;这引发了人们的…

LabVIEW回转马达试验系统

基于LabVIEW的回转马达试验台通过高度集成的硬件与软件配合&#xff0c;实现对回转马达的各项性能测试&#xff0c;包括空载排量、跑合试验和冲击试验等&#xff0c;以满足出厂测试的严格标准和要求。 项目背景 回转马达作为多种机械设备的核心动力源&#xff0c;其性能的可靠…

干货分享丨智造底座——AI算力池化的必要与实践

为了帮助工业企业更好地了解数据存储及管理的应用趋势&#xff0c;e-works在线学院于2022年9月23日14:00举办了以“工业数据存储及管理”为主题的线上研讨会。 趋动科技售前工程师Johny Hong受邀作主题分享&#xff0c;并与线上几千观众共同探讨了建设智造底座——AI算力池化的…