mysql配置主从

article/2025/9/21 4:41:27

一、部署mysql

1.1、先部署好两台mysql数据库,部署mysql可以查看我的文档

写文章-CSDN创作中心

二、开始配置mysql主从

2.1、主机配置

vim /etc/my.cnf 或者 vi /etc/my.cnf

#增加一下配置

log-bin=mysql-bin
server_id=101

#选择增加的参数

binlog-do-db= 数据库名  #需要同步的数据库

binlog-ignore-db = 数据库名  #不需要同步的数据库

 重启数据库:systemctl resatrt mysql

 2.2、主机上创建用于复制的数据库账号,可以使用已经创建好的,也可以新建,需要注意的是mysql8及之后版本,需要先创建好数据库账号

#mysql -uxxx   -pxxx  进入数据库

#mysql8以下使用

grant replication slave on *.* to '数据库用户'@'%'identified by '123';

grant replication client on *.* to '数据库用户'@'%'identified by '123';

#mysql8及以上使用

grant replication client,replication slave on *.* to '数据库用户'@'%';

#刷新

flush privileges;

 2.3、查看主库信息  show master status;

要记住file 和 position的值,也就是第一和第二列,后面用的上

2.4、配置从库

vim /etc/my.cnf 或者 vi /etc/my.cnf

#增加一下配置
server_id=202 #不能和主库的值一样

重启数据库:systemctl resatrt mysql 

2.5、从库关联配置

 #进入mysql数据库mysql -uxxx   -pxxx 

#停掉从的服务,这里一定要停掉服务再去执行下面的

stop slave;  #8以下的可以试试slave stop

#配置关联master,3306可以默认不写,master_log_file和master_log_pos参考之前主库show masterstatus;查询出来的信息。

change master to master_host='192.168.3.206', master_port=3306,master_user='root', master_password='root',master_log_file='binlog.000004',master_log_pos=156;

#启动服务

start slave; #8以下的可以试试slave start 

#查看是否成功

show slave status \G;

 需要保证框起来的都是yes

2.6、show slave status \G;常见问题,本人部署中发现Slave_IO_Running: No,如果这里不正确,可以查看下他的报错

 这里常见的有三种报错,一个是报server ids,一个是server UUIDs,还有一种是主库端口不通

#遇见UUIDs

找到data文件夹下的auto.cnf文件,修改里面的uuid值,保证各个主从的uuid不一样,重启数据库即可,可使用find / -name auto.cnf  查找

#遇见ids

找到/etc/my.cnf配置文件中的server_id,修改从库的server_id保证和复制结构中的其他db不一样,重启数据库即可,但是我这里试了依然不行,后面使用下面的方法

#查看server_id

 show variables like 'server_id';

#停止slave后,手动修改server_id

mysql> stop slave;

mysql> set global server_id=2;#此处的数值和my.cnf里设置的一样就行

mysql> start slave;

再次查看show slave status \G;

 这里需要注意的是我本地部署的时候,发现只要一重启数据库,server_id就会重置成1,然后和主库就一样了,所以这里不能重启数据库,如果知道这个是什么问题,可以留言给我补充。

三、如果主库已经存在数据库,创建好主从之后,如何把之前的数据库同步过来

3.1、使用mysqldump

#在从库使用mysqldump命令复制数据

[root@slave2 ~]# mysqldump --single-transaction --all-databases --master-data=1 --host=192.168.2.138 --user=root --password=root --apply-slave-statements | mysql -uroot -proot-hlocalhost

参数说明

–single-transaction参数可以对Innodb表执行非锁定导出。此选项将事务隔离模式设置为REPEATABLE READ,并在转储数据之前向服务器发送START TRANSACTION SQL语句。它仅适用于Innodb等事务表,因为它会在发出START TRANSACTION时转储数据库的一致状态,而不会阻塞任何应用程序。因此这里假定:1. 所有的应用数据表都使用Innodb引擎。2. 所有系统表数据在备份过程中不会发生变化。

–master-data参数会导致转储输出包含类似 CHANGE MASTER TO MASTER_LOG_FILE=‘binlog.000004’, MASTER_LOG_POS=1480; 的SQL语句,该语句指示主库的二进制日志坐标(文件名和位置)。如果选项值为2,则CHANGE MASTER TO语句将写为SQL注释,因此仅提供信息,不会执行。如果参数值为1,则该语句不会写为注释,并在重新加载转储文件时执行。如果未指定选项值,则默认值为1。

–apply-slave-statements参数会在CHANGE MASTER TO语句之前添加STOP SLAVE语句,并在输出结尾处添加START SLAVE语句,用来自动开启复制。

mysqldump方式的优点是可以进行部分复制,如在配置文件中定义replicate-do-table=db1.*,则用这种方法可以只复制db1库而忽略其它复制事件。缺点是由于mysqldump会生成主库转储数据的SQL语句,实际是一种逻辑备份方式所以速度较慢,不适用于大库。

3.2、如果可以脱机复制直接的数据,可以使用下面的方法

#1、停止复制的所有实例,在主从分别执行

ln -s /usr/local/mysql/bin/mysqladmin /usr/bin/mysqladmin

mysqladmin -hlocalhost -uroot -pwwwwww shutdown

#2、主库复制数据到从库

cd /data 

scp -r mysql/* root@192.168.3.208:/usr/local/mysql/data/  #从库的数据文件路径

#3、在从库执行命令,删除auto.cnf文件

cd /data/mysql

rm -rf auto.cnf

#4、重启 实例,主从都需要执行

systemctl start mysql


http://chatgpt.dhexx.cn/article/xhPfsoXO.shtml

相关文章

mysql数据库主从配置

1、主从原理 主从原理大致有三个步骤: 在主库上把数据更改记录到二进制日志中(Binary Log)中,这些记录称为二进制日志事件。从库通过IO线程将主库上的日志复制到自己的中继日志(Relay Log)中。从库通过SQL线…

Mysql主从配置,亲手搭建,保证可用!

配置前准备 1、准备2个mysql环境 2、两个mysql网络互通 第一步 配置mysql配置文件【my.cnf】|【my.ini】 【master】配置如下 [mysqld] server-id 1 # 节点ID,确保唯一 log config log-bin mysql-bin #开启mysql的binlog日志功能,binlo…

REPL是什么?

“读取-求值-输出”循环(英语:Read-Eval-Print Loop,简称REPL)是一个简单的,交互式的编程环境 看图理解:

repr()

转:https://www.cnblogs.com/itdyb/p/5046415.html Python 有办法将任意值转为字符串:将它传入repr() 或str() 函数。 函数str() 用于将值转化为适于人阅读的形式,而repr() 转化为供解释器读取的形式。

python replace函数

replace()是一个替换函数 其使用格式为 变量 .replace(要替换的值,替换后的值) 例如:替换空格(给字符串删除空格) 输出结果

python——replace函数

replace就像它的中文翻译,替换的意思,可以输入help(replace)看一下它的用法 replace(self, old, new, count-1, /),这个就是replace的基本用法,old就是指要替换的字符串,,new就是产…

正则表达式--replace

MDN解释: 返回一个由替换值替换一些或所有匹配的模式后的新字符串。 使用以下值作为替换参数 序列变量名代表的值1$$插入一个 “$”2$&插入匹配的子串3$插入当前匹配的子串左边的内容4$’插入当前匹配的子串右边的内容5$n假如第一个参数是 RegExp对象&#xff…

SublimeREPL无法运行,输出:“***Repl Closed***“

我的python3用的是python3.7.8,在Sublime上安装SublimeREPL后发现我的sublimeREPL打开后仅仅是输出了一行***Repl Closed***,对比其他人运行REPL的结果后,发现这个插件还没有运行程序就结束了。 解决方法 在sublime文件目录下Sublime Text …

replace/replaceAll

replace/replaceAll 在leetcode刷到替换空格的问题,一通反复比较,发现String对象中的replace和replaceAll虽然实现效果相同,但是执行用时和内存消耗略有差异;Be Like: 难道说底层实现有哪里不一样?让我来…

如何使用Node.js REPL

目录 1、Nodejs REPL 2、_特殊变量 3、向上箭头键 4、点命令 5、从JavaScript文件运行REPL 1、Nodejs REPL REPL代表Read-Evaluate-Print-Loop,是交互式解释器。 node命令是我们用来运行Node.js脚本的命令: node script.js 如果我们运行node命令…

Node.js的交互式解释器(REPL)

什么是交互式解释器 交互式解释器,就是交互的解释器,即每输入一行然后回车都会有所反应。 必要时可以拿node当计算器来使用。 REPL(Read Eval Print Loop:交互式解释器)表示一个电脑的环境,类似于电脑的cmd命令行,我们可以在其…

简单说说USB协议(三)四种传输方式

数据传输的大致步骤: 配置传输方法——选择事务——发送各种令牌、数据、握手包 传输方法 既然USB是用来进行数据传输的,那么必然会涉及到配置传输方法: 批量传输、中断传输、同步传输、控制传输。 1、批量传输 适用于数据量大&#xf…

USB协议详解第12讲(USB传输-初探)

目录 1.USB传输、事务、包的关系 2.USB传输类型 2.1控制传输 2.2同步传输 2.3批量传输 2.4中断传输 3.传输总结及后期内容 1.USB传输、事务、包的关系 USB传输、事务、包是从不同层次上去说明一次数据交互的三个概念。 举个例子可能更好些,"某领导和一…

USB 协议的科普

旧名称 新名称 最新名称 最大速度 2000.04 USB 2.0 480 Mbps 2008.11 USB 3.0 USB 3.1 Gen1 USB 3.2 Gen1 5 Gbps 2013.12 USB 3.1 USB 3.1 Gen2 USB 3.2 Gen2 10 Gbps 2017.09 USB 3.2 USB 3.2 Gen2x2 20 Gbps 英特尔 雷电 3 USB-C Thunder…

USB协议详解第1讲(核心概念通俗理解)

目录 0.概括 1.USB传输(Transfer) 2.事务(Transaction) 3.包(Pack)的概念 4.USB 主机(Host) 5.设备(Device) 6.配置(Configuration&#x…

USB协议基本知识

USB 基本知识 USB的重要关键概念: 1、 端点:位于USB设备或主机上的一个数据缓冲区,用来存放和发送USB的各种数据,每一个端点都有惟一的确定地址,有不同的传输特性(如输入端点、输出端点、配置端点、批量传输端点&…

USB协议分析仪

1 ULPI PHY passive sniffing mode 概念: non driving, no pull-up, no pull-down Function Control.opMode 1; // non-Driving OTG Control.DpPulldown 0; // no pull-down OTG Control.DmPulldown 0; // no pull-down USB IO.ChargerPullupEnDP 0; // no pull-up USB IO.…

usb协议栈概述

usb协议栈概述 usb协议栈的信息源头是www.usb.org usb协议栈的所有者是usb联盟。它有七个美国公司为它的成员 这些公司包括苹果,惠普,英特尔,微软,瑞萨科技,ST微电子,德州仪器 usb的版本发展 从1.0&#…

USB协议-描述符篇(一)

USB协议-描述符篇(一) 1.USB描述符简介2.USB标准描述符2.1 设备描述符2.2 配置描述符2.3 接口描述符2.4 端点描述符2.5 字符串描述符 3.特殊类描述符4.USB类定义5.USBDescriptorType 1.USB描述符简介 USB描述符,即使用描述符报告它们的属性。…

USB协议 - UVC标准协议规范(二)

USB协议-UVC标准协议规范(二) 1.概述2.UVC功能特征2.1 Video Interface Class2.2 Video Interface subclass and Protocol2.3 UVC功能拓扑2.3.1 Unit单元2.3.1.1 SU(选择器单元)2.3.1.2 PU(处理单元)2.3.1.3 EU(编码单元)2.3.1.4 …