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

相关推荐
科技小花2 小时前
全球化深水区,数据治理成为企业出海 “核心竞争力”
大数据·数据库·人工智能·数据治理·数据中台·全球化
X56614 小时前
如何在 Laravel 中正确保存嵌套动态表单数据(主服务与子服务)
jvm·数据库·python
虹科网络安全5 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
2301_771717215 小时前
解决mysql报错:1406, Data too long for column
android·数据库·mysql
绘梨衣5475 小时前
Docker+FastAPI+MySQL 项目部署报错汇总
mysql·docker·fastapi
小江的记录本5 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
dvjr cloi5 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
dFObBIMmai6 小时前
MySQL主从同步中大事务导致的延迟_如何拆分大事务优化同步
jvm·数据库·python
szccyw06 小时前
mysql如何限制特定存储过程执行权限_MySQL存储过程安全访问
jvm·数据库·python
czlczl200209256 小时前
利用“延迟关联”优化 MySQL 巨量数据的深分页查询
数据库·mysql