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
茶杯头甜蜜终章dlc 官方手机版v1.0.0.3
下载火柴人传说暗影格斗内置菜单 最新版v3.0.1
下载荒野乱斗测试服 安卓版v61.10.3
下载荒野乱斗彩虹服 安卓版v61.10.3
下载寒霜启示录 安卓版v1.25.10
寒霜启示录是一款生存模拟游戏,不少玩家可能对于末日都有着自己
末日城堡免广告版 安卓最新版v0.7.1
末日城堡免广告版是一款非常好玩的模拟经营类游戏,内部可以不看
甜蜜人生模拟器 最新版v1.4.5
甜蜜人生模拟器是一款非常好玩的模拟恋爱手游,玩家在这里能够对
武器锻造师内置功能菜单 v10.4
武器锻造师内置菜单版是游戏的破解版本,在该版本中为玩家提供了
开放空间overfield 安卓版v1.0.5
开放空间Overfield是一款箱庭养成经营手游,让你在广阔