mysql主从复制如何实现?本篇文章小编给大家分享一下mysql主从复制实现代码,文章代码介绍的很详细,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
mysql主从复制的原理
1、Master将数据记录到二进制日志中,也就是mysql配置文件my.cnf的log-bin指定的文件,这些记录叫做二进制日志事件。
2、Slave有两个线程,一个I/O线程,一个SQL线程。I/O线程请求Master,将得到的binlog日志写到relay log(中继日志) 文件中。
3、SQL 线程,会读取relay log文件中的日志,并解析成具体操作,来实现主从的操作一致,而最终数据一致。
mysql的主从配置的具体实现方式
1、Master配置
(1)修改mysql的my.cnf配置文件,这里比较坑爹的是我用的mysql版本没有my.cnf 配置文件,连my-default.cnf都没有,一般来说my.cnf在/etc目录下, my-default.cnf在/usr/local/mysql/support-files中。最终我在网上复制了一份my.cnf文件放在了/etc中(朋友们可以自己去网上找,有很多的)。
(2)my.cnf中需要修改的配置主要有开启日志功能,设置server_id保证其唯一性(不能跟从库一样),过滤需备份的数据库。
bash-3.2# vim /etc/my.cnf # 设置server_id,不能重复,一般可以设置为主库的IP server_id=81 # 备份过滤:需要备份的数据库,输出binlog binlog-do-db=demo_ds_master # 备份过滤:不需要备份的数据库,不输出 binlog-ignore-db=mysql # 开启二进制日志,将主库数据记录到mysql-bin开头的日志文件中(可自定义) log-bin=mysql-bin # 配置每个session的内存,在事物过程中用来存储二进制日志的缓存 binlog_cache_size=1M # 主从复制的格式(mixed,statement,row 默认的是statement) binlog_format=mixed # 二进制日志自动删除/过期的天数,默认为0,不自动删除 expire_logs_days=7 # 用于跳过主从复制中遇到的所有错误或指定的错误类型,避免slave端的终端 # 1062:主键冲突(具体的参数可以去网上查询) slave_skip_errors=1062
(3)启动/重启Master数据库服务,登录数据库,创建数据同步用户,并授权
#授权这个机器可以备份主数据库的数据 mysql> GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'root'@'192.168.31.60' identified by 'password'; #然后刷新权限 mysql> flush privileges; #查看配置的主库信息 mysql> show master status;
(4)主库数据备份,确保主从库的数据一致性
# 临时锁住表,设置只读权限 mysql> flush tables with read lock; # 备份数据库 bash-3.2# mysqldump -uroot -p --add-drop-table demo_ds_master_1 > /tmp/demo_ds_master_1.sql; # 解锁表 mysql> unlock table;
2、 Slave配置
(1)修改从数据库mysql的my.cnf配置文件,添加从数据库的中继日志配置
[root@develop etc]# vim my.cnf # 设置server_id,不能重复,这里设置的是从库的IP server-id=60 # 开启从数据库中继日志,将主数据库的binlog写到relay log中,中继日志以hehe-mysql-relay-bin开头(可自定义) relay_log=hehe-mysql-relay-bin # 设置从数据库为只读权限,防止主从数据不一致 read_only=1
(2)如果从库需要作为另一个库的主库的话,需要加上Master上的配置信息,并且加上log_slave_updates=1将Master的binlog记录到自己的binlog日志中。
(3)重启从库数据库,同步主库数据
# 运行主数据库的备份数据库 [root@develop etc]# mysql -uroot -p demo_ds_master_1 < /tmp/demo_ds_master_1.sql # 登录从数据库 [root@develop etc]# mysql -uroot -p # 设置该从节点的主节点 mysql> change master to master_host='192.168.31.80', master_user='root',master_password='password', master_port=3306, master_log_file='mysql-bin.000001', master_log_pos=154; # 开启主从同步 mysql> start slave; # 查看主从同步状态 mysql> show slave statusG; # 查看主从线程状态 mysql> show processlistG;
图片中显示如下,说明主从复制已经配置好了,下面主库插入数据就可以实现从库自动复制主库数据了。
Slave_IO_State: Waiting for master to send event
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
忍者必须死34399账号登录版 最新版v1.0.138v2.0.72
下载勇者秘境oppo版 安卓版v1.0.5
下载忍者必须死3一加版 最新版v1.0.138v2.0.72
下载绝世仙王官方正版 最新安卓版v1.0.49
下载Goat Simulator 3手机版 安卓版v1.0.8.2
Goat Simulator 3手机版是一个非常有趣的模拟游
Goat Simulator 3国际服 安卓版v1.0.8.2
Goat Simulator 3国际版是一个非常有趣的山羊模
烟花燃放模拟器中文版 2025最新版v1.0
烟花燃放模拟器是款仿真的烟花绽放模拟器类型单机小游戏,全方位
我的世界动漫世界 手机版v友y整合
我的世界动漫世界模组整合包是一款加入了动漫元素的素材整合包,
我的世界贝爷生存整合包 最新版v隔壁老王
我的世界MITE贝爷生存整合包是一款根据原版MC制作的魔改整