当前位置: 首页 > news >正文

MySQL主从架构

1 主从架构解决了什么问题

随着业务的持续增长,单体数据库满足不了业务的需求,可能会出现负载过重,操作数据库速度变慢的情况。为了解决这个问题,数据库一般采用一主一从、一主多从的架构。

为了操作提高效率,减轻压力,采用读写分离:

• 主数据库只负责写

• 从数据库只负责读

2 主从复制的原理

  1. MySQL的主从复制基于主数据库的二进制日志(binlog)中记录所有对数据库的更改操作,所以主数据库需要开启二进制日志。

  2. 每个从数据库和主数据库进行配置连接。在主数据库上进行的任何更新操作都会同步给从数据库,从数据库接收主数据库的二进制日志。从数据库根据二进制日志进行数据操作。

  3. 从数据库执行的数据操作不会对主数据库造成干扰。即从数据库在备份数据过程中,主数据库可继续处理数据更新操作。

图片

3 主从复制配置实战

主数据库的搭建请参考之前的文章:【揭秘】Docker安装MySQL8.0大公开,你知道吗?

3.1 使用docker启动从数据库

docker run -p 3307:3306 -e MYSQL_ROOT_PSSWORD=123456 --name mysql-slaver -v /root/mysql2/conf/my.cnf:/etc/mysql/my.cnf -v /root/mysql2/logs:/var/log/mysql -v /root/mysql2/data:/var/lib/mysql -v /root/mysql2/mysql-files:/var/lib/mysql-files -d mysql:8.0

3.2 修改server_id

修改my.cnf配置文件,修改主数据库的server_id为1,从服的server_id为2,修改后重启数据库。

[root@VM-24-10-centos conf]# 
cat my.cnf 
[mysqld]
lower_case_table_names=1
server-id=1
#skip-grant-tables

使用MySQL命令查看是否设置成功,查询server_id是否可配置文件中一致

show variables like 'server_id';

3.3 修改server-uuid

修改data目录下的auto.cnf中的server-uuid,主从的server-uuid不能一致,否则会有报错(#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.)

[root@VM-24-10-centos data]# cat auto.cnf 
[auto]
server-uuid=60a0cb5e-1a2f-11ee-8244-0242ac110003

3.4 在主数据库上新增用户

在主数据库上新增用户用于从数据库同步数据时,连接使用

1、创建新用户

create user ‘slave’@‘%’ identified by ‘slave12345’;

2、刷新权限

flush privileges;

3、赋予权限,%标识不限制主机

grant replication slave on . to ‘slave’@‘%’;

4、刷新权限

flush privileges;

5、查看用户

select host,user,plugin,authentication_string from mysql.user;

3.5 在主数据库上查看Master状态

查询Master状态,并记录 File 和 Position 的值

show master status;

在这里插入图片描述

3.6 在从数据库上获取主数据库的密钥

否则会报错(# error connecting to master ‘slave@10.0.24.10:3306’ - retry-time: 60 retries: 51 message: Authentication plugin ‘caching_sha2_password’ reported error: Authentication requires secure connection.)

mysql -u slave -pslave12345 -h 10.0.24.10 -P 3306 --get-server-public-key

3.7 在从数据库上设置同步

设置主数据库参数

change master to master_host ='10.0.24.10', master_port =3306, master_user ='slave', master_password ='slave12345', master_log_file ='binlog.000007', master_log_pos =156;
  • master_host 为主数据库的ip
  • master_port为主数据库的端口号
  • master_user,master_password为主数据库新建的同步数据使用的用户名和密码
  • master_log_files为查询主数据库状态时的File
  • master_log_pos为查询主数据库状态时的Position

3.8 同步命令

开始同步

start slave;当出现问题时,停止同步# 停止同步
stop slave;
reset slave;

3.9 查看设置是否成功

在从数据库上使用show slave status查看同步状态:

show slave status;

在这里插入图片描述
如上显示即为主从数据库搭建成功。


关注我,我们一起学习
在这里插入图片描述

相关文章:

  • 并发编程(线程基础)
  • Qt 插件开发详解
  • linux 系统 安装vnc
  • gRPC源码剖析-Builder模式
  • 0基础学习PyFlink——事件时间和运行时间的窗口
  • 【二、http】go的http基本请求设置(设置查询参数、定制请求头)get和post类似
  • Java基础之类型(内涵面试题)
  • nodemon : 无法加载文件 C:\Users\XXX\\npm\nodemon.ps1,因为在此系统上禁止运行脚本。
  • 《研发效能(DevOps)工程师》课程简介(三)丨IDCF
  • WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED!
  • 单点登录。
  • 矢量图形设计软件:Illustrator 2024(AI)中文激活版
  • 【教3妹学编程-算法题】117. 填充每个节点的下一个右侧节点指针 II
  • 【LeetCode刷题-链表】--1290.二进制链表转整数
  • 在 Python 中创建奇数列表
  • @jsonView过滤属性
  • 《网管员必读——网络组建》(第2版)电子课件下载
  • 【挥舞JS】JS实现继承,封装一个extends方法
  • 【跃迁之路】【444天】程序员高效学习方法论探索系列(实验阶段201-2018.04.25)...
  • 2017 年终总结 —— 在路上
  • CSS相对定位
  • EOS是什么
  • es6要点
  • JAVA之继承和多态
  • Map集合、散列表、红黑树介绍
  • mysql 5.6 原生Online DDL解析
  • python学习笔记 - ThreadLocal
  • Shell编程
  • ubuntu 下nginx安装 并支持https协议
  • Vue2.x学习三:事件处理生命周期钩子
  • Webpack 4x 之路 ( 四 )
  • webpack4 一点通
  • 初识MongoDB分片
  • 近期前端发展计划
  • 吴恩达Deep Learning课程练习题参考答案——R语言版
  • 阿里云IoT边缘计算助力企业零改造实现远程运维 ...
  • ​configparser --- 配置文件解析器​
  • #我与Java虚拟机的故事#连载19:等我技术变强了,我会去看你的 ​
  • #预处理和函数的对比以及条件编译
  • $ git push -u origin master 推送到远程库出错
  • $forceUpdate()函数
  • $jQuery 重写Alert样式方法
  • (2020)Java后端开发----(面试题和笔试题)
  • (22)C#传智:复习,多态虚方法抽象类接口,静态类,String与StringBuilder,集合泛型List与Dictionary,文件类,结构与类的区别
  • (8)Linux使用C语言读取proc/stat等cpu使用数据
  • (c语言)strcpy函数用法
  • (PHP)设置修改 Apache 文件根目录 (Document Root)(转帖)
  • (笔试题)分解质因式
  • (二)fiber的基本认识
  • (附源码)springboot高校宿舍交电费系统 毕业设计031552
  • (附源码)springboot人体健康检测微信小程序 毕业设计 012142
  • (附源码)springboot助农电商系统 毕业设计 081919
  • (经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
  • (未解决)macOS matplotlib 中文是方框
  • (学习日记)2024.01.19