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

MySQL主从配置

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

主从原理

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、不要在从节点对数据库进行写入删除操作

拓展

读写分离

分库分表

不停机进行主从

相关推荐

数据库基础:mysql主从集群搭建

文章首发于微信公众号:java架构师进阶之路前言:Mysql数据库没有增量备份的机制,当数据量太大的时候备份是一个很大的问题。还好mysql数据库提供了一种主从备份的机制,其实就是把主数据库的所有的...

Mysql-cluster搭建

前期准备准备五台虚拟机:ip地址分别为:192.168.1.211管理节点192.168.1.64SQL节点192.168.1.65SQL节点192.168.1.70数据节点192.168.1...

mysql 主从数据库搭建

一、创建目录在dev/htb下面创建文件夹master01htb]#mkdirmysql/master01-p2)进入master01...

从零搭建高可用的 MySQL 主从复制架构(基于 Linux 实战指南)

背景在生产环境中,单点MySQL数据库容易成为性能瓶颈或单点故障源。搭建MySQL主从复制架构,可以实现读写分离、高可用,提升系统的整体稳定性与扩展性。...

「MySQL 8」MySQL 5.7都即将停只维护了,是时候学习一波MySQL 8了

MySQL8新特性选择MySQL8的背景:MySQL5.6已经停止版本更新了,对于MySQL5.7版本,其将于2023年10月31日停止支持。后续官方将不再进行后续的代码维护。另外,...

Mysql启动选项和配置文件

Mysql启动选项和配置文件Mysql启动方式下面的启动命令都需要依赖在Linux环境下配置的Mysql环境变量...

centos安装mysql操作手册

1.下载Mysql首先去Mysql官网下载安装包,网址https://dev.mysql.com/downloads/mysql/推荐大家下载Linux通用版本的,便于管理安装位置,也方便一台服务器...

MySQL安装

MySQL的安装过程因操作系统的不同而有所差异。以下是在几种常见操作系统上安装MySQL的基本步骤:Windows下载MySQL:访问MySQL官方网站下载页面:MySQLDownloads...

MySQL数据库安装教程

前言今天就带各位小伙伴学习数据库技术。数据库技术是Java开发中必不可少的一部分知识内容。也是非常重要的技术。...

MySQL学到什么程度?才有可以在简历上写精通

前言如今互联网行业用的最多就是MySQL,然而对于高级Web面试者,尤其对于寻找30k下工作的求职者,很多MySQL相关知识点基本都会涉及,如果面试中,你的相关知识答的模糊和不切要点,基...

一起免费考 MySQL OCP 认证啦

前言:在1995年,首个MySQL版本发布,为庆祝MySQL诞辰30周年,OracleUniversity在限定期间内推出了多个MySQL的免费培训课程与认证,其中也包括My...

教程2 | 制作用户管理系统

一、项目简介用户管理系统是一个基于C/S模式的小型管理系统,使用了GUI技术来实现管理系统的页面效果,该管理系统可以对用户的信息,比如姓名、年龄、密码和地址等进行增删改查操作。用户管理系统通过JDBC...

红帽Linux中安装mysql8详细步骤

注意:我写的解压路径和截图路径不一致,仅供参考先前往官网下载mysql8下载地址:https://dev.mysql.com/downloads/选择指定版本和系统下载命令...

MySQL主从配置

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

mysql的主从搭建以及实现主从切换方法

主从搭建的方法:a.准备两台服务器...