广告位联系
返回顶部
分享到

MySQL同步数据Replication的实现方法

Mysql 来源:互联网 作者:佚名 发布时间:2023-07-15 22:33:18 人浏览
摘要

MySQL提供了Replication功能,可以实现将一个数据库的数据同步到多台其他数据库。前者通常称之为主库(master),后者则被称从库(slave)。MySQL复制过程采用异步方式,但延时非常小,

MySQL提供了Replication功能,可以实现将一个数据库的数据同步到多台其他数据库。前者通常称之为主库(master),后者则被称从库(slave)。MySQL复制过程采用异步方式,但延时非常小,秒级同步。

一、同步复制数据基本原理

1.在主库上发生的数据变化记录到二进制日志Binlog
2.从库的IO线程将主库的Binlog复制到自己的中继日志Relay log
3.从库的SQL线程通过读取、重放中继日志实现数据复制

mysql

MySQL的复制有三种模式:Statement Level、Row Level、Mixed Level。复制级别的不同,会导致Master端二进制日志文件的生成形式的不同。

二、同步数据示例

操作系统:centos7
数据库:mysql8
主机(master):192.168.0.101
从机(slave):192.168.0.102

1、修改主从mysql配置文件

主机配置my.cnf

1

2

3

4

5

6

7

8

9

[mysqld]

# 服务器标识,每个服务器不能一样

server_id=101

# 开启日志文件

log_bin=binlog

# 普通用户只能读 OFF是关闭状态

read_only=off

# 超级用户只能读 OFF是关闭状态

super_read_only=off

从机配置

1

2

3

4

5

6

7

8

9

[mysqld]

# 服务器标识

server_id=102

# 启用binlog日志,并指定文件名前缀

log_bin=binlog

# 普通用户只能读 on是开启状态

read_only=on

# 超级用户只能读 on是开启状态

super_read_only=on

重启服务

1

systemctl restart mysqld

2、主机建立同步账号,并查看主库状态信息

登录数据库,并创建账号

1

2

3

create user repl identified with mysql_native_password by 'repl123';

grant replication slave on *.* to repl;

flush privileges;

查看主库master状态,获取日志文件名称和偏移量信息

show-master

3、从机同步配置

复制主机的二进制日志操作(部分数据通过查看主库master状态)
主机的同步账号:source_user
密码:source_password
端口:source_port
日志文件:source_log_file
偏移量:source_log_pos

1

change replication source to source_host='192.168.0.101', source_user='repl', source_password='repl123', source_port=3306,source_log_file='binlog.000001', source_log_pos=154;

从机启动同步

1

start replica;

4、查看同步配置效果

在主机上,查看是否存在从机的连接

1

show processlist;

查看从机同步复制的状态

1

show slave status\G

在主机上,向某表中插入数据,查看从机对应表中的数据情况,经测试效果很好(略)


版权声明 : 本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务和不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权, 违法违规的内容, 请发送邮件至2530232025#qq.cn(#换@)举报,一经查实,本站将立刻删除。
原文链接 :
相关文章
  • MySQL DQL语句的具体使用介绍
    DQL DQL英文全称是Data Query Language(数据查询语言),数据查询语言,用来查询数据库中表的记录。 基本语法 DQL 查询语句,语法结构如下: SE
  • MySQL同步数据Replication的实现方法
    MySQL提供了Replication功能,可以实现将一个数据库的数据同步到多台其他数据库。前者通常称之为主库(master),后者则被称从库(slave)。
  • MySQL索引失效十种场景与优化方案介绍
    1 数据准备 1.1 新建数据表 1 2 3 4 5 6 7 8 9 10 11 12 13 CREATE TABLE `player` ( `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT 主键, `player_id` varchar(256) NOT NULL CO
  • order by + limit分页时数据重复问题及解决方法

    order by + limit分页时数据重复问题及解决方法
    问题描述:MYSQL version 5.6.8command 表结构 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 CREATE TABLE command ( ID INT NOT NULL, NAME VARCHAR(16), DESCRIPTION VARCHAR(32), INDE
  • 高版本Mysql使用group by分组报错的解决方案

    高版本Mysql使用group by分组报错的解决方案
    Mysql5.7版本以上对group by 分组有了新需求,要求group by 后的字段要与select后查询的字段一致,否则就会报错,报错信息如下: #1055 - Expressi
  • 在SQL中修改数据的基础语句
    什么是修改? 在SQL中的基本操作就是增删改查,查询语句不会对数据库中的数据进行修改。 而其余的三种操作都会对数据库进行修改,不管
  • MySQL字符串前缀索引使用

    MySQL字符串前缀索引使用
    1. 前缀索引与全部索引概念 怎么给字符串字段加索引?现在,几乎所有的系统都支持邮箱登录,如何在邮箱这样的字段上建立合理的索引,
  • MySql深分页问题解决
    1. 问题描述 日常开发中经常会涉及到数据查询分页的问题,一般情况下都是根据前端传入页数与页码通过mysql的limit方式实现分页,对于数据
  • MySQL之xtrabackup备份恢复的实现

    MySQL之xtrabackup备份恢复的实现
    mysql版本:8.0.28 xtrabackup版本:8.0.28 1、安装xtrabackup 下载地址:Download Percona XtraBackup 8.0https://www.percona.com/downloads 1 2 [root@myoracle ~]# tar -zxvf
  • Mysql的SELECT语句与显示表结构介绍

    Mysql的SELECT语句与显示表结构介绍
    SELECT... 1 2 SELECT 1+1, 2+2;# 直接这样写相当于下面这句 SELECT 1+1, 2+2 FROM DUAL; # 这里DUAL:伪表 SELECT ... FROM 语法: SELECT 标识选择哪些字段(列)
  • 本站所有内容来源于互联网或用户自行发布,本站仅提供信息存储空间服务,不拥有版权,不承担法律责任。如有侵犯您的权益,请您联系站长处理!
  • Copyright © 2017-2022 F11.CN All Rights Reserved. F11站长开发者网 版权所有 | 苏ICP备2022031554号-1 | 51LA统计