mysql 主从复制 mysql版本5.7.35

文章目录

  • 1.注意要点
  • 2.环境
  • 3.MySQL 主从配置的步骤:
    • 主从库新增DB
    • 主服务配置my.cnf
    • 从服务配置my.cnf
    • 主服务器创建复制用户
    • 从服务器执行复制
  • 外传

MySQL 主从复制(Master-Slave Replication)是一个常用的高可用性和可扩展性解决方案。通过主从复制,可以将一个 MySQL 数据库服务器(主服务器)的数据复制到一个或多个从服务器上。这种架构可以提供以下优点:

高可用性:如果主服务器发生故障,可以从服务器继续提供服务,从而确保数据的可用性。
负载均衡:可以将读操作分散到多个从服务器上,以减轻主服务器的负载。
数据备份:从服务器可以用于数据的备份和恢复,提高系统的可靠性。

1.注意要点

  1. 从库只能同步主库配置之后的数据,不能同步之前的数据,之前的数据需要手动同步;

  2. 如果同步主库已有的数据库表,需在从库建好库表,字段可多余主库,不能少于主库;

  3. 从库额修改不会影响主库的数据;

  4. 主库从库的server-id 需保持不一致;

2.环境

docker
mysql:5.7.35

docker run -itd --name=xxx-mysql -p 3306:3306 --restart=always -v /home/docker_data/mysql_data/config:/etc/mysql -v /etc/localtime:/etc/localtime  -v /home/docker_data/mysql_data/log/:/var/log -v /home/docker_data/mysql_data/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=xxxx mysql:5.7.35docker cp xxx-mysql:/etc/mysql/my.cnf /home/docker_data/mysql_data/config/

如果没有my.cnf,请自行下载
我自己的福禄一个:

# For advice on how to change settings please see
# http://dev.mysql.com/doc/refman/5.7/en/server-configuration-defaults.html[mysqld]
#
# Remove leading # and set to the amount of RAM for the most important data
# cache in MySQL. Start at 70% of total RAM for dedicated server, else 10%.
# innodb_buffer_pool_size = 128M
#
# Remove leading # to turn on a very important data integrity option: logging
# changes to the binary log between backups.
# log_bin
#
# Remove leading # to set options mainly useful for reporting servers.
# The server defaults are faster for transactions and fast SELECTs.
# Adjust sizes as needed, experiment to find the optimal values.
# join_buffer_size = 128M
# sort_buffer_size = 2M
# read_rnd_buffer_size = 2M
datadir=/var/lib/mysql
#datadir=/home/mysql_data
socket=/var/lib/mysql/mysql.sock# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0log-error=/var/log/mysqld.log
pid-file=/var/run/mysqld/mysqld.pidcharacter-set-client-handshake = FALSE
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci
init_connect='SET NAMES utf8mb4'#slow query log
slow_query_log=1
slow_query_log_file=/var/log/mysql_slow.log
long_query_time=1
#sql mode
sql_mode = "STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"
lower_case_table_names=1
max_connections=10000

3.MySQL 主从配置的步骤:

主从库新增DB

确保从服务器上已经安装了 MySQL 数据库服务器,并且运行正常。
主从库的库和表建好
如果原有库有数据,那么备份到从库

主服务配置my.cnf

在主服务器上编辑 MySQL 配置文件(通常是 my.cnf 或 my.ini),添加以下配置:
MySQL默认采用基于语句的复制,效率比较高。mixed指的是默认采用基于语句的复制,一旦发现基于语句的无法精确的复制时,就会采用基于行的复制。
有row、statement、mixed三种格式,row指的是把改变的内容复制过去,而不是把命令在从服务器上执行一遍,statement指的是在主服务器上执行的SQL语句,在从服务器上执行同样的语句。
vim /etc/my.cnf

[mysqld]
#在mysqld模块中添加如下配置信息
log-bin=master-bin #二进制文件名称
binlog-format=ROW  #二进制日志格式,
server-id=232      #要求各个服务器的id必须不一样
binlog-do-db=saas_test   #同步的数据库名称

重启主服务器上的 MySQL 服务。

从服务配置my.cnf

在从服务器上编辑 MySQL 配置文件,添加以下配置:

[mysqld]
server-id = 231  # 从服务器的唯一标识
log-bin=master-bin #二进制文件名称
binlog-format=ROW  #二进制日志格式
replicate-do-db = saas_test  # 指定需要复制的数据库名称

重启从服务器上的 MySQL 服务。

主服务器创建复制用户

在主服务器上创建一个用于复制的用户,并为该用户授予适当的权限。例如,可以使用以下命令创建一个具有复制权限的用户:

CREATE USER 'repli_test'@'%' IDENTIFIED BY 'Nrepli_test8';
GRANT REPLICATION SLAVE ON *.* TO 'repli_test'@'%' IDENTIFIED BY 'Nrepli_test8';FLUSH PRIVILEGES;
mysql> show master status;
+-------------------+----------+----------------------+------------------+-------------------+
| File              | Position | Binlog_Do_DB         | Binlog_Ignore_DB | Executed_Gtid_Set |
+-------------------+----------+----------------------+------------------+-------------------+
| master-bin.000009 |      154 | saas_test |                  |                   |
+-------------------+----------+----------------------+------------------+-------------------+
1 row in set (0.00 sec)

从服务器执行复制

在从服务器上执行以下命令,配置从服务器连接到主服务器并开始复制:

CHANGE MASTER TO MASTER_HOST='10.255.20.232', MASTER_USER='repli_test', MASTER_PASSWORD='Nrepli_test8', MASTER_LOG_FILE='master-bin.000009', MASTER_LOG_POS=1788;
START SLAVE;

MASTER_HOST 是主服务器的 IP MASTER_USER 和 MASTER_PASSWORD 是上一步创建的复制用户的用户名和密码,MASTER_LOG_FILE 是主服务器当前的二进制日志文件名,MASTER_LOG_POS 是主服务器当前二进制日志的位置。

在从服务器上执行以下命令,检查复制状态,确保状态为 “Slave_IO_Running: Yes” 和 “Slave_SQL_Running: Yes”:

SHOW SLAVE STATUS\G
*************************** 1. row ***************************Slave_IO_State: Waiting for master to send eventMaster_Host: 10.255.20.232Master_User: repli_testMaster_Port: 3306Connect_Retry: 60Master_Log_File: master-bin.000009Read_Master_Log_Pos: 1788Relay_Log_File: 6ecc83692550-relay-bin.000006Relay_Log_Pos: 2003Relay_Master_Log_File: master-bin.000009Slave_IO_Running: YesSlave_SQL_Running: YesReplicate_Do_DB: saas_mana_ncore_testReplicate_Ignore_DB: Replicate_Do_Table: Replicate_Ignore_Table: Replicate_Wild_Do_Table: Replicate_Wild_Ignore_Table: Last_Errno: 0Last_Error: Skip_Counter: 0Exec_Master_Log_Pos: 1788Relay_Log_Space: 2384Until_Condition: NoneUntil_Log_File: Until_Log_Pos: 0Master_SSL_Allowed: NoMaster_SSL_CA_File: Master_SSL_CA_Path: Master_SSL_Cert: Master_SSL_Cipher: Master_SSL_Key: Seconds_Behind_Master: 0
Master_SSL_Verify_Server_Cert: NoLast_IO_Errno: 0Last_IO_Error: Last_SQL_Errno: 0Last_SQL_Error: Replicate_Ignore_Server_Ids: Master_Server_Id: 232Master_UUID: a114aeb6-538b-11ee-bf44-0242ac110004Master_Info_File: /var/lib/mysql/master.infoSQL_Delay: 0SQL_Remaining_Delay: NULLSlave_SQL_Running_State: Slave has read all relay log; waiting for more updatesMaster_Retry_Count: 86400Master_Bind: Last_IO_Error_Timestamp: Last_SQL_Error_Timestamp: Master_SSL_Crl: Master_SSL_Crlpath: Retrieved_Gtid_Set: Executed_Gtid_Set: Auto_Position: 0Replicate_Rewrite_DB: Channel_Name: Master_TLS_Version: 

如果状态显示为 “No”,则需要检查日志和配置文件以解决可能的问题。
现在,你的 MySQL 主从复制配置已经完成。主服务器上的数据将自动复制到从服务器上,并且从服务器可以用于读取数据。如果主服务器发生故障,可以手动切换到从服务器以保持服务的可用性。

外传

😜 原创不易,如若本文能够帮助到您的同学
🎉 支持我:关注我+点赞👍+收藏⭐️
📝 留言:探讨问题,看到立马回复
💬 格言:己所不欲勿施于人 扬帆起航、游历人生、永不言弃!🔥

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

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

相关文章

分享一个基于uniapp+springboot技术开发的校园失物招领小程序(源码、lw、调试)

💕💕作者:计算机源码社 💕💕个人简介:本人七年开发经验,擅长Java、Python、PHP、.NET、微信小程序、爬虫、大数据等,大家有这一块的问题可以一起交流! 💕&…

TPU-MLIR——实现Chatglm2-6B大模型移植部署

TPU-MLIR——实现Chatglm2-6B大模型移植部署 本项目实现BM1684X部署语言大模型ChatGLM2-6B。通过TPU-MLIR编译器将模型转换成bmodel,并采用c代码将其部署到BM1684X的PCIE环境,或者SoC环境。 编译chatglm2-6B模型 1. 下载‘Chat-GLM2-6B’ 2. 对该模型…

Python 合并/拆分Excel

python对于合并excel本篇文章给出合并xlsx文件的方法,xls的方法不在本文介绍 拆分数据可以适用于xlsx或xls 合并excel 先读取所有的excel,得到df列表,在将这个df列表 按行进行合并 import pandas as pd# 读取所有xlsx def read_xlsx(xlsx_l…

9月18日,每日信息差

今天是2023年09月19日,以下是为您准备的11条信息差 第一、江苏无锡首次获得6000年前古人类DNA 第二、全球天然钻石价格暴跌。数据显示,国际钻石交易所钻石价格指数在2022年3月达到158的历史峰值,之后一路下跌到目前的110左右,创…

Glide - Android的图像加载和缓存库,专注于平滑滚动

官网 GitHub - bumptech/glide: An image loading and caching library for Android focused on smooth scrolling 项目介绍 An image loading and caching library for Android focused on smooth scrolling Glide is a fast and efficient open source media management a…

谷歌版ChatGPT与旗下邮箱、视频、地图等,实现全面集成!

9月20日,谷歌在官网宣布推出Bard Extensions。借助该扩展用户可在谷歌的Gmail、谷歌文档、网盘、Google 地图、视频等产品中使用Bard。 Bard是谷歌基于PaLM 2大模型,打造的一款类ChatGPT产品,可自动生成文本、代码、实时查询信息等。新的集成…

数据结构与算法(C语言版)P5---栈

1、栈 1.1、栈的概念及结构 栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。__进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。__栈中的数据元素遵守__后进先出(先进后出)__LIFO&#xf…

iOS 蓝牙连接 connectionSupervisionTimeout 是720ms 还是 2~6s

对比 HCI可以看到iPhone作为主设连接外设时,可以看到: connection Event Interval 30ms; connection Slave Latency 0; connection Supervision Timeout 720ms;但苹果官方文档《 Accessory Design Guidelines for …

FPGA原理与结构(12)——FIFO IP核原理学习

系列文章目录:FPGA原理与结构(0)——目录与传送门 一、FIFO概述 1、FIFO的定义 FIFO是英文First-In-First-Out的缩写,是一种先入先出的数据缓冲器,与一般的存储器的区别在于没有地址线, 使用起来简单&…

C/C++算法入门 | 简单模拟

不爱生姜不吃醋⭐️ 如果本文有什么错误的话欢迎在评论区中指正 与其明天开始,不如现在行动! 文章目录 🌴前言🌴一、害死人不偿命的(3n1)猜想1.题目(PAT B1001)2.思路3.代码实现 &am…

BD就业复习第一天

hive 1.分区分桶 在Hive中,分区(Partition)和分桶(Bucketing)都是用于数据管理和查询性能优化的技术。它们有不同的用途和特点。 分区(Partition): 定义:分区是将数据…

Hexo在多台电脑上提交和更新

文章目录 1.博客搭建2.创建一个新文件夹new,用于上传hexo博客目录3.github上创建hexo分支并设置为默认分支创建hexo分支将hexo分支设置为默认分支 4.进入新建的文件夹中git clone,再上传相关文件至hexo分支1.clone下来的文件夹内应该有个.gitignore文件&…

Springboot部署服务器项目上线

第一步,项目打包,有两种方式 第一种、直接在项目根目录打开终端,输入以下语句即可。如下图: mvn clean package -DskipTests 第二种、在右侧点击 Maven选项,选择鼠标左键双击package选项即可。如下图: 两…

Python 搭建编程环境

一、搭建编程环境 1、下载python 官网:https://www.python.org 2、开始安装 下载安装版本,双击下载的安装包,如下: 步骤一: 步骤二: 步骤三: 安装完成后执行下面的操作,判断是否…

高教杯数学建模A题程序设计要点与思路

2023 年是我最后一次参加 高教杯大学生数学建模竞赛 以后不会再参加了(大四参加意义不太,研究生有研究生的数学建模大赛) 很遗憾 由于各种原因 我们没有能够完成赛题2022 年 美赛 2022年 Mathor Cup 2022 年国赛 2022 亚太杯 2023年 美赛 202…

面试官:说说Vue 3.0中Treeshaking特性?举例说明一下?

🎬 岸边的风:个人主页 🔥 个人专栏 :《 VUE 》 《 javaScript 》 ⛺️ 生活的理想,就是为了理想的生活 ! 目录 一、是什么 二、如何做 Vue2 项目 Vue3 项目 三、作用 一、是什么 Tree shaking 是一种通过清除多余代码方式来…

974. 和可被 K 整除的子数组

974. 和可被 K 整除的子数组 C代码:哈希表前缀和 typedef struct{int val;int cnt;UT_hash_handle hh; } HashTable;int subarraysDivByK(int* nums, int numsSize, int k){HashTable* head NULL;HashTable* out NULL;int sum 0;int cnt 0;out (HashTable*)ma…

Nginx 的优化思路有哪些?网站的防盗链如何做?附图文说明和完整代码步骤

Nginx 的优化思路有哪些?网站的防盗链如何做?实际工作中有哪些类似的安全经验?通过代码实践一步一步实现,附图文说明和完整代码步骤 实验拓扑图: 实验步骤 1、在Centos01上安装Nginx,设置网站根目录/www使用域名www.huhu.com访问 2、在Centos02上安装DNS使用域名访问Ce…

嵌入式Linux--进程间通讯--消息队列

1.需要知道的问题: 1、如何创建消息队列(A\B使用同一个队列通信) 2、如何加消息到队列(队列是链表) 3、如何从队列拿到消息 消息队列: 消息队列,是消息的链接表,存放在内核中。一个…

C#不通过byte[],直接对内存映射文件复制内存

背景 多个进程直接需要传递大量图片,所以对性能要求较高。支付复制内存显然比转成byte[]再复制优越。 命名空间 using System; using System.Diagnostics; using System.Runtime.InteropServices; 代码 public CMainTestForm() { InitializeCo…