Mysql主从复制

介绍

MySQL主从复制是一个异步的复制过程,底层是基于Mysql数据库自带的二进制日志功能。就是一台或多台MySQL数据库(slave,即从库)从另一台MySQL数据库(master,即主库)进行日志的复制然后再解析日志并应用到自身,最终实现从库的数据和主库的数据保持一致。MySQL主从复制是MySQL数据库自带功能,无需借助第三方工具。

MySQL复制过程分成三步:
● master将改变记录到二进制日志(binary log)
● slave将master的binary log拷贝到它的中继日志(relay log)
● slave重做中继日志中的事件,将改变应用到自己的数据库中

何进行主从复制

首先要确保防火墙开放mysql的端口(3306或其他)

复制代码
# 检查防火墙
sudo firewall-cmd --list-ports
sudo firewall-cmd --permanent --add-port=3306/tcp
sudo firewall-cmd --reload

首先要准备两个服务器,一个用来管理主库(master);一个用来管理从库(slave)

1. 主服务器配置

修改主服务器配置文件(my.cnf):

mysqld

服务器ID,主从不能相同

server-id = 1

开启二进制日志

log_bin = mysql-bin

需要复制的数据库(可选)

binlog-do-db = test_db

不需要复制的数据库(可选)

binlog-ignore-db = mysql

binlog-ignore-db = information_schema

二进制日志格式(推荐ROW)

binlog_format = ROW

自动清理过期日志

expire_logs_days = 7

之后执行sql

-- 在主服务器执行

CREATE USER 'repl'@'192.168.1.11' IDENTIFIED BY 'repl_password';

GRANT REPLICATION SLAVE ON *.* TO 'repl'@'192.168.1.11';

FLUSH PRIVILEGES;

解释:

'repl' - 用户名,专门用于复制的用户,可以自定义

'@'192.168.1.11' - 指定允许连接的客户端IP,这里是从服务器的IP

'repl_password' - 用户密码,建议设置强密码

查看主服务器状态:

执行sql

SHOW MASTER STATUS;

记录下返回的 File 和 Position 值,从服务器配置时需要。

2. 从服务器配置

修改从服务器配置文件(my.cnf):

mysqld

server-id = 2#id要于主库不相同

开启中继日志

relay_log = mysql-relay-bin

可选:记录从服务器的二进制日志

log_bin = mysql-bin

防止从服务器写操作

read_only = 1

之后执行sql

-- 在从服务器执行

CHANGE MASTER TO

MASTER_HOST='192.168.1.10',

MASTER_USER='repl',

MASTER_PASSWORD='repl_password',

MASTER_LOG_FILE='mysql-bin.000001', -- 主服务器SHOW MASTER STATUS的File

MASTER_LOG_POS=107; -- 主服务器SHOW MASTER STATUS的Position

-- 启动复制

START SLAVE;

3. 验证复制状态

检查从服务器复制状态:

SHOW SLAVE STATUS\G;

满足:

Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Seconds_Behind_Master: 0

使用Mysql主从复制-------------Sharding-JDBC

主Mysql从从复制成功后在Java工程中用Sharding-JDBC来使用它。

Sharding-JDBC介绍

Sharding-JDBC定位为轻量级Java框架,在Java的JDBC层提供的额外服务。它使用客户端直连数据库,以jar包形式提供服务,无需额外部署和依赖,可理解为增强版的JDBC驱动,完全兼容JDBC和各种ORM框架。使用Sharding-JDBC可以在程序中轻松的实现数据库读写分离。

● 适用于任何基于JDBC的ORM框架,如:JPA,Hibernate,Mybatis,Spring JDBC Template或直接使用JDBC。

● 支持任何第三方的数据库连接池,如:DBCP,C3P0,BoneCP,Druid,HikariCP等。

● 支持任意实现JDBC规范的数据库。目前支持MySQL,Oracle,SQLServer,PostgreSQL以及任何遵循SQL92标准的数据库。

使用步骤
1 导入 maven 坐标( Sharding-JDBC 的)

<dependency>

<groupId>org.apache.shardingsphere</groupId>

<artifactId>sharding-jdbc-spring-boot-starter</artifactId>

<version>4.0.0-RC1</version>

</dependency>

2在配置文件中配置读写分离规则

3在配置文件中允许bean定义覆盖配置顶

spring:

shardingsphere:

datasource:

names:

master,slave

主数据源

master:

type: com.alibaba.druid.pool.DruidDataSource

driver-class-name: com.mysql.cj.jdbc.Driver

url: jdbc:mysql://192.168.217.100:3307/rw?characterEncoding=utf-8

username: root

password: abc123LQ

从数据源

slave:

type: com.alibaba.druid.pool.DruidDataSource

driver-class-name: com.mysql.cj.jdbc.Driver

url: jdbc:mysql://192.168.217.130:3307/rw?characterEncoding=utf-8

username: root

password: abc123LQ

masterslave:

读写分离配置

load-balance-algorithm-type: round_robin #轮询(按顺序来用从库,轮着使用)

最终的数据源名称

name: dataSource

主库数据源名称

master-data-source-name: master

从库数据源名称列表,多个逗号分隔

slave-data-source-names: slave

props:

sql:

show: true #开启SQL显示,默认false

#允许覆盖

main:

allow-bean-definition-overriding: true

相关推荐
懒羊羊不懒@3 分钟前
【MySQL | 基础】多表查询
数据库·sql·mysql
百***69712 分钟前
redis 使用
数据库·redis·缓存
mit6.82413 分钟前
[Column] 构建十亿/s级DB | 索引DB&RTDB | Kafka 为中心 | Rust 构建引擎
数据库
q***05632 分钟前
在Mysql环境下对数据进行增删改查
数据库·mysql
爬山算法33 分钟前
Redis(124)Redis在电商系统中的应用有哪些?
数据库·redis·缓存
武子康41 分钟前
Java-170 Neo4j 事务、索引与约束实战:语法、并发陷阱与速修清单
java·开发语言·数据库·sql·nosql·neo4j·索引
数据库学啊2 小时前
靠谱的时序数据库哪家技术强
数据库·时序数据库
Wang's Blog2 小时前
MySQL: 存储引擎深度解析:CSV与Archive的特性、应用与实战演示
数据库·mysql
q***07142 小时前
Spring Boot 从 2.7.x 升级到 3.3注意事项
数据库·hive·spring boot
秋天之落叶3 小时前
使用ADO将excel表内容加载到mssql表中的长度问题
数据库·sqlserver·excel