百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

MySQL主从配置

wptr33 2025-05-30 17:53 26 浏览

主从原理

MySQL主从又叫做Replication、AB复制。简单讲就是A和B两台机器做主从后,在A上写数据,另外一台B也会跟着写数据,两者数据实时同步的。

MySQL主从是基于binlog的,主上须开启binlog才能进行主从。

主从过程大致有3个步骤:

1)主将更改操作记录到binlog里

2)从将主的binlog事件(sql语句)同步到从本机上并记录在relaylog里中继日志

3)从根据relaylog里面的sql语句按顺序执行

  • 主服务器上有一个log dump线程,用来和从的I/O线程传递binlog;
  • 从服务器上有两个线程,其中I/O线程用来同步主的binlog并生成relaylog,另外一个SQL线程用来把relaylog里面的sql语句落地。

使用场景

1、数据的备份。

单纯的读。当主服务器损坏,从服务器可以顶替

2、主从同时被使用

当主的服务器压力过大,从节点也被用来数据。

配置

准备

主机名

IP

MySQL版本

centos版本

server

192.168.200.41

mysql-5.6.47-linux-glibc2.12-x86_64.tar.gz

centos7.2-1511

client

192.168.200.42

两台虚拟机均安装完成二进制免编译MySQL,关闭防火墙

参考:https://www.yuque.com/docs/share/69df81ac-0829-4a63-add1-68331bfca715?# 《二进制免编译MySQL安装》

过程

主节点操作

# .err结尾的文件为错误日志

[root@server ~]# ls -a /data/mysql/

. auto.cnf ib_logfile0 mysql server.err test

.. ibdata1 ib_logfile1 performance_schema server.pid

# 修改配置文件 /etc/my.cnf 确定有log_bin 和server_id

[root@server ~]# vim /etc/my.cnf

log_bin=wsw

server_id = 41

[root@server ~]# service mysqld restart

Shutting down MySQL.. SUCCESS!

Starting MySQL. SUCCESS!

# 可以看到多出log_bin名为开头的两个文件,wsw.000001、wsw.index

# 这两个文件为bin_log文件和索引文件 可以参考流程图

[root@server ~]# ls -a /data/mysql/

. ibdata1 mysql server.pid wsw.index

.. ib_logfile0 performance_schema test

auto.cnf ib_logfile1 server.err wsw.000001

# 创建主从用户 权限

mysql> grant replication slave on *.* to 'repl'@192.168.200.42 identified by '000000';

Query OK, 0 rows affected (0.00 sec)

# 刷新权限

mysql> flush privileges;

Query OK, 0 rows affected (0.00 sec)

# 查看server节点状态

mysql> show master status ;

+------------+----------+--------------+------------------+-------------------+

| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |

+------------+----------+--------------+------------------+-------------------+

| wsw.000001 | 410 | | | |

+------------+----------+--------------+------------------+-------------------+

1 row in set (0.00 sec)

从节点配置

# 从节点修改配置文件,确保有server_id 这个字段,

# 字段id不要一样,一般以ip最后一位结尾

[root@client ~]# vim /etc/my.cnf

server_id = 42

mysql> stop slave;

Query OK, 0 rows affected, 1 warning (0.00 sec)

# 创建连接, 主节点信息,bin_log文件名及大小

mysql> change master to master_host='192.168.200.41',master_user='repl',master_password='000000',master_log_file='wsw.000001',master_log_pos=410;

Query OK, 0 rows affected, 2 warnings (0.04 sec)

mysql> start slave;

Query OK, 0 rows affected (0.00 sec)

mysql> show slave status\G;

*************************** 1. row ***************************

Slave_IO_State: Waiting for master to send event

Master_Host: 192.168.200.41

Master_User: repl

Master_Port: 3306

Connect_Retry: 60

Master_Log_File: wsw.000001

Read_Master_Log_Pos: 410

Relay_Log_File: client-relay-bin.000002

Relay_Log_Pos: 277

Relay_Master_Log_File: wsw.000001

Slave_IO_Running: Yes

Slave_SQL_Running: Yes

Replicate_Do_DB: # 同步那些库 这些配置都是可以写在著配置文件的my.cnf

Replicate_Ignore_DB: # 不同步哪些库

Replicate_Do_Table: # 同步哪些表

Replicate_Ignore_Table:

Replicate_Wild_Do_Table: # 同步哪个库.表 常用

Replicate_Wild_Ignore_Table: # 忽略哪个库的哪个表

Last_Errno: 0 # 错误信息

Last_Error:

Skip_Counter: 0

Exec_Master_Log_Pos: 410

Relay_Log_Space: 451

Until_Condition: None

Until_Log_File:

Until_Log_Pos: 0

Master_SSL_Allowed: No

Master_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: No

Last_IO_Errno: 0 # 线程错误信息

Last_IO_Error:

Last_SQL_Errno: 0

Last_SQL_Error:

Replicate_Ignore_Server_Ids:

Master_Server_Id: 41

Master_UUID: 197dfb61-1310-11ec-af29-000c29b5c42c

Master_Info_File: /data/mysql/master.info

SQL_Delay: 0

SQL_Remaining_Delay: NULL

Slave_SQL_Running_State: Slave has read all relay log; waiting for the slave I/O thread to update it

Master_Retry_Count: 86400

Master_Bind:

Last_IO_Error_Timestamp:

Last_SQL_Error_Timestamp:

Master_SSL_Crl:

Master_SSL_Crlpath:

Retrieved_Gtid_Set:

Executed_Gtid_Set:

Auto_Position: 0

1 row in set (0.00 sec)

ERROR:

No query specified


测试

# 主节点创建一个库,测试操作在这个库进行

mysql> create database wsw;

Query OK, 1 row affected (0.00 sec)

# 从节点查看同步信息

mysql> show databases;

+--------------------+

| Database |

+--------------------+

| information_schema |

| mysql |

| performance_schema |

| test |

| wsw |

+--------------------+

5 rows in set (0.00 sec)

# 000001文件大小为主节点操作命令组成

# 可以通过bin_log文件恢复数据

注意

1、不要在从节点对数据库进行写入删除操作

拓展

读写分离

分库分表

不停机进行主从

相关推荐

oracle数据导入导出_oracle数据导入导出工具

关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...

继续学习Python中的while true/break语句

上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个...

python continue和break的区别_python中break语句和continue语句的区别

python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...

简单学Python——关键字6——break和continue

Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...

2-1,0基础学Python之 break退出循环、 continue继续循环 多重循

用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...

Python 中 break 和 continue 傻傻分不清

大家好啊,我是大田。...

python中的流程控制语句:continue、break 和 return使用方法

Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...

L017:continue和break - 教程文案

continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...

作为前端开发者,你都经历过怎样的面试?

已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...

面试被问 const 是否不可变?这样回答才显功底

作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...

2023金九银十必看前端面试题!2w字精品!

导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。...

前端面试总结_前端面试题整理

记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...

由浅入深,66条JavaScript面试知识点(七)

作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录...

2024前端面试真题之—VUE篇_前端面试题vue2020及答案

添加图片注释,不超过140字(可选)...

今年最常见的前端面试题,你会做几道?

在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...