mysql数据库的主从复制

  • MySQL主从复制的应用场景

    • 当只有一台MySQL服务器要负责读写时,对于安全性,高可用,高并发等需求就不能满足,因此就要建立集群,集群的基础就是主从复制。

    • 原理(过程)

      • MySQL支持的复制类型

        • 基于语句的复制,基于二进制文件,效率高,有概率出错

          • binlog-fromat=STATMENT

        • 基于行的复制,复制内容,效率低,不容易出错

          • binlog-fromat=ROW

        • 混合模式,综上两种,效率与容错都折中 先语句,出错再行。

          • binlog-fromat=MIXED

      • 过程

        • 流程图

        • 首先主节点数据库要开启二进制日志功能

          • 进行相关数据库的修改之后,更新二进制文件,通知存储引擎提交事务。

        • 然后,当二进制日志文件添加新数据后,slave的I/O线程就会检测到,并将相关数据复制到slave的中继日志中,复制完毕后进行休眠。等待新的事件。

        • 最后,slave中的sql进程就会将中继日志中的事件进行重放(重做),

          • 需要注意的是slave的重放操作时串行的,当并行操作出现时,也是按串行来处理。

    • 实验操作

      • 准备前奏

        • 三台安装mysql的主机

          • 将内核与防火墙都关闭

        • 进行时间同步

          • 主节点服务器安装ntp

            • yum -y install ntp

            • 配置文件中添加如下语句

              • server 127.127.1.0

                • 主节点数据库作为权威时间的ntp服务器

              • fudge 127.127.1.0 stratum 8

                • 一种调整层级越小越接近权威时间

          • 从服务器安装ntp

            • 执行命令

              • ntptate 权威时间主机的IP地址

      • 过程

        • 要对主从服务器进行配置

          • 修改配置文件【mysqld】添加如下语句

            • server-id=11

              • 在这群集里面该服务的标识id,同一集群内id不能重复。

            • log-bin=master-bin

              • 二进制日志文件的前缀名称

            • binlog-format=MIXED

              • 进行主从复制时采用的模式:混合模式

            • replicate-ignore-db=test

              • 如果不想同步某个库就要把该参数写到从服务器的配置文件中

            • binlog-cache-size=1M

              • 缓存日志的大小,建立缓存降低磁盘的I/O压力

            • expire-logs-days=3

              • 自动清理日志的时间,合理设置,避免无法进行增量备份。

            • log-slave-updates=true

              • 进行主主复制需要

            • 修改后重启

          • 进入主节点服务器

            • 对从节点服务器创建授权账号

              • grant replication slave on *.* to ‘slave’@‘192.168.10.%’ identified by ‘123456’;

                • 从服务器将通过该账号进行混合模式的复制

              • flush privileges

            • 查看当前二进制日志文件的名称与位置

              • show master status;

                • 该项是从服务器建立主从复制连接的重要依据,要确保该项不会变动
                  • 为了确保不会变动,可以有两种方式

                    • 方法一

                      • 关闭前端的服务,这样对mysql数据库便不会有数据被修改。

                    • 方法二

                      • 人性化的设定,将要导出的表进行锁定,或全局锁定,这样只能进行读,并不会断开连接。

                        • 锁定所有表

                          • global lock

                        • 锁定单个表

                          • lock tables 表名 write

                            • write:表示该表不能读但能写

                            • read:表示该表不能写只能读

                        • 解锁

                          • unlock tables

              • 当用了一段时间的数据库要进行主从复制时,不能通过修改起始位置来进行偷懒。

          • 从服务器的配置

            • 在配置文件[mysqld]中添加如下语句

              • server-id=22

                • 确保server-id在群集中唯一即可

              • relay-log=relay-log-bin

                • 给中继日志文件起前缀名

              • relay-log-index=slave-relay-bin.index

                • 从服务器启动时需要检查中继日志文件中的中继日志信息1,这里在该处定义了名字。

            • 修改后重启服务器

            • 进入从服务器

              • 建立主从连接

                • change master to master_host='192.168.10.101' 主服务器地址 master_user='myslave' 要用哪个账号连接 master_password='123456' 连接的账号密码是什么 master_log_file='master-bin.000002' 要读取的日志文件名叫什么 master_log_pos=154 要从那个位置开始进行复制

              • 开始连接

                • start slave;

              • 查看连接

                • show slave status\G

                  • 划红线部分必须要为yes状态 可以查看其他信息是否正确,如果建立主从连接的参数出错,那么需要停止slave的I/O进程才能再次提交。
          • 需要注意的是,从服务器的重启对主从建立的连接影响较小很快就能重建连接,而主服务器上的重启会造成较长时间的连接时间。

以上所有内容全选复制后粘贴到xmind上便可形成条理性笔记!!! 

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

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

相关文章

有关主流编程语言的几个问题及对比

参考:编程语言的历史(https://blog.csdn.net/david_lv/article/details/104765347) 静态与动态语言的优缺点分析 什么是强类型,什么是弱类型?哪种更好些?为什么? 强类型和弱类型的区别 几种常见的开发语言…

VMWare workstation虚拟机 转kvm qemu 的Qcow2格式

准备软件:VMWare Workstation软件,QEMU软件,for Windows的 https://qemu.weilnetz.de/w64/qemu-w64-setup-20240423.exe set path"C:\Program Files (x86)\VMware\VMware Workstation";%path% set diskwin2019 set diskdisk02 s…

【Kubernetes学习】

K8S基础概念一 一、k8s是什么?二、k8s功能三、k8s组件四、k8s概念总结 一、k8s是什么? kubernetes,简称k8s,是一个全新的基于容器技术的分布式架构领先方案,是谷歌严格保密十几年的秘密武器----Borg系统的一个开源版本…

kicad第三方插件安装问题

在使用KICAD时想安装扩展内容,但是遇到下载失败,因为SSL connect error。 因为是公司网络,我也不是很懂,只能另寻他法。找到如下方法可以曲线救国。 第三方插件包目录 打开存放第三方插件存放目录,用于存放下载插件包…

电子电路学习笔记(3)三极管

部分内容参考链接: 电子电路学习笔记(5)——三极管_三极管 箭头-CSDN博客 模拟电子技术基础笔记(4)——晶体三极管_集电结的单向导电性-CSDN博客 硬件基本功-36-三极管Ib电流如何控制Ic电流_哔哩哔哩_bilibili 部分…

隔离级别如何选用?

在 MySQL 中选择合适的隔离级别取决于你的应用程序对数据一致性和性能的需求。下面是 MySQL 支持的隔离级别及其适用场景: 1. 未提交读(Read Uncommitted) 描述:允许读取未提交的数据。适用场景:几乎不使用&#xff…

【JS逆向-export导出语句】将ES6模块导出语法(浏览器中)转成CommonJS格式(Node.js中)

ES6模块导出语法(浏览器中执行) // 导出 export {Jt as K, $t as a, Xt as h};// 导入 import {K as x, a as K, h as q} from "./module.js";转成CommonJS格式(Node.js中执行) // 导出 module.exports {K: Jt, a: $…

【面试系列】数据工程师高频面试题及详细解答

欢迎来到我的博客,很高兴能够在这里和您见面!欢迎订阅相关专栏: ⭐️ 全网最全IT互联网公司面试宝典:收集整理全网各大IT互联网公司技术、项目、HR面试真题. ⭐️ AIGC时代的创新与未来:详细讲解AIGC的概念、核心技术、…

LIDAR360MLS V7.2.0 雷达点云数据处理软件功能介绍

LiDAR360MLS 是三维要素智能提取及分析软件,可灵活衔接市面上主流的多型号车载、背包或手持等移动测量设备采集的激光雷达点云与影像数据。软件基于高效的海量点云数据索引结构和人工智能算法,进行点云数据编辑、提取、分析等处理及道路要素目标的三维矢…

Yarn:现代JavaScript包管理器

目录 定义与起源Yarn与NPM的比较Yarn的安装与配置安装步骤配置选项 Yarn的使用场景1. 项目初始化2. 依赖管理3. 脚本运行4. 命令总结 Yarn与其他包管理器的比较与npm的比较与pnpm的比较 结论 定义与起源 Yarn是一个现代的包管理工具,旨在提供快速、可靠和安全的依赖…

使用新H5标签dialog,实现点击按钮显示分享链接弹出层交互功能

使用新H5标签&#xff0c;实现点击按钮显示分享链接弹出层交互功能 在现代网页开发中&#xff0c;使用新技术和标签来提升用户体验是非常重要的。今天&#xff0c;我们就来聊聊如何利用HTML5的<dialog>标签来实现一个简洁实用的分享链接功能。 在过去&#xff0c;我们通常…

SpringBoot:集成机器学习模型进行预测和分析

引言 机器学习在现代应用程序中扮演着越来越重要的角色。通过集成机器学习模型&#xff0c;开发者可以实现智能预测和数据分析&#xff0c;从而提高应用程序的智能化水平。SpringBoot作为一个强大的框架&#xff0c;能够方便地集成机器学习模型&#xff0c;并提供灵活的部署和…

递推算法计算信号特征

在线算法&#xff08;在线计算或递推计算&#xff09;能够在不存储全部数据的情况下逐步更新信号的特征信息&#xff0c;非常适合资源受限的单片机应用场景。 用途&#xff1a;单片机边采集&#xff21;&#xff24;&#xff23;边计算&#xff0c;最终将采集的信号特征计算结果…

RT-Thread ENV-Windows v2.0.0安装教程

前言 前几天RT-Thread官方更新了env工具&#xff0c;开源仓库的Kconfig的写法都不大一样了&#xff1b;如果继续用原来的env工具&#xff0c;拉新代码之后很多示例都编译不了 在最新的env工具中menuconfig全面采用kconfiglib&#xff0c;升级env脚本和python版本&#xff0c;改…

Pascal 函数入门示例,及其汇编语言分析

1&#xff0c; Pascal 函数的定义格式 pascal 函数的定义语法格式: FUNCTION 函数名(形式参数表):函数类型; VAR 函数的变量说明; BEGIN 函数体; END; 2&#xff0c;Pascal 函数定义调用示例 order_self.pas 代码&#xff1a; PROGRAM example01;va…

Oracle数据库基础教程:从安装到基本操作的全面介绍

Oracle数据库基础教程&#xff1a;从安装到基本操作的全面介绍 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01; Oracle数据库是全球广泛使用的关系数据库管理系…

PyTorch之nn.Module、nn.Sequential、nn.ModuleList使用详解

文章目录 1. nn.Module1.1 基本使用1.2 常用函数1.2.1 核心函数1.2.2 查看函数1.2.3 设置函数1.2.4 注册函数1.2.5 转换函数1.2.6 加载函数 2. nn.Sequential()2.1 基本定义2.2 Sequential类不同的实现2.3 nn.Sequential()的本质作用 3. nn.ModuleList参考资料 本篇文章主要介绍…

操作系统精选题(二)(综合模拟题一)

&#x1f308; 个人主页&#xff1a;十二月的猫-CSDN博客 &#x1f525; 系列专栏&#xff1a; &#x1f3c0;操作系统 &#x1f4aa;&#x1f3fb; 十二月的寒冬阻挡不了春天的脚步&#xff0c;十二点的黑夜遮蔽不住黎明的曙光 目录 前言 简答题 一、进程由计算和IO操作组…

Leica Cyclone 3DR2024 一款功能强大的点云建模软件下载License获取

Leica Cyclone 3DR 2024 是一款功能强大的点云建模软件&#xff0c;使用旨在为用户提供全面的点云管理、自动化的点云分析&#xff0c;结合强大的建模&#xff0c;在一个直观友好的环境中&#xff0c;专注的完成挑战&#xff0c;提高生产力&#xff0c;轻松创建并交付专业的成果…

基于PHP技术的校园论坛设计的设计与实现-计算机毕业设计源码08586

摘 要 本项目旨在基于PHP技术设计与实现一个校园论坛系统&#xff0c;以提供一个功能丰富、用户友好的交流平台。该论坛系统将包括用户注册与登录、帖子发布与回复、个人信息管理等基本功能&#xff0c;并结合社交化特点&#xff0c;增强用户之间的互动性。通过利用PHP语言及其…