MySQL同步数据Replication如何实现

网友投稿 655 2023-07-08

MySQL同步数据Replication如何实现

MySQL同步数据Replication如何实现

MySQL的Replication功能可以将一个数据库数据同步到多个其他数据库。一般把第一个称为主数据库(master),第二个称为从数据库(slave)。MySQL复制过程采用异步方式,但延时非常小,秒级同步。

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

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

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

二、同步数据示例

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

1、修改主从mysql配置文件

主机配置my.cnf

[mysqld] # 服务器标识,每个服务器不能一样server_id=101# 开启日志文件log_bin=binlog # 普通用户只能读 OFF是关闭状态read_only=off # 超级用户只能读 OFF是关闭状态super_read_only=off登录后复制

从机配置

[mysqld]# 服务器标识server_id=102# 启用binlog日志,并指定文件名前缀log_bin=binlog# 普通用户只能读 on是开启状态 read_only=on # 超级用户只能读 on是开启状态 super_read_only=on登录后复制

重启服务

systemctl restart mysqld登录后复制

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

登录数据库,并创建账号

create user repl identified with mysql_native_password by 'repl123';grant replication slave on *.* to repl;flush privileges;登录后复制

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

3、从机同步配置

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

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;登录后复制

从机启动同步

start replica;登录后复制

4、查看同步配置效果

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

show processlist;登录后复制

查看从机同步复制的状态

show slave status\G登录后复制

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

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:centos如何安装jdk及mysql
下一篇:Mac系统中忘记MySQL密码怎么解决
相关文章