mysql主主同步原理_MySQL主主数据同步浅析
MySQL主主同步和主从同步的原理⼀样,只是双⽅都是主从⾓⾊。
环境
操作系统版本:CentOS7 64位
MySQL版本:mysql5.6.33
节点1IP:192.168.1.205 主机名:edu-mysql-01
古尔邦节是几月几日2022节点2IP:192.168.1.206 主机名:edu-mysql-02
注意:
1> 主从服务器操作系统版本和位数要保持⼀致
2> Master和Slave数据库的版本要⼀致
3> Master和Slave数据库中的数据要⼀致
配置
配置之前安装好MySQL
梦见死人说话1、安全配置
1> 防⽕墙
添加mysql通信端⼝(默认为3306)shell> vim /etc/sysconfig/iptables-A INPUT -m state --state NEW -m tcp -p tcp --
dport 3306 -j ACCEPT
shell> service iptables restart
或关闭防⽕墙shell> service iptables stop
2> 关闭selinuxshell> vi /etc/selinux/config
SELINUX=disabled
将SELINUX的值修改为disabled
2. 节点1配置(192.168.1.205)
2.1 添加数据同步配置shell> vim /etc/myf
在[mysqld]中增加以下配置项:
# 服务器的ID,必须唯⼀,⼀般设置⾃⼰的IP
server_id=205# 复制过滤:不需要备份的数据库(MySQL库⼀般不同步)
binlog-ignore-db=mysql# 开启⼆进制⽇志功能,名字可以随便取,最好有含义(⽐如项⽬名)
log-bin=edu-mysql-bin# 为每个 session 分配的内存,在事务过程中⽤来存储⼆进制⽇志的缓存
大清朝皇帝列表binlog_cache_size=1M# 主从复制的格式(mixed,statement,row,默认格式是 statement)
binlog_format=mixed# ⼆进制⽇志⾃动删除/过期的天数。默认值为 0,表⽰不⾃动删除。
expire_logs_days=7## 跳过主从复制中遇到的所有错误或指定类型的错误,避免 slave 端复制中断。 ## 如:1062 错误是指⼀些主键重复,1032 错误是因为主从数据库数据不⼀致
slave_skip_errors=1062# 作为从服务器时的中继⽇志
relay_log=edu-mysql-relay-bin# log_slave_updates 表⽰ slave 将复制事件写进⾃⼰的⼆进制⽇志
log_slave_updates=1# 主键⾃增规则,避免主从同步ID重复的问题
auto_increment_increment=2 # ⾃增因⼦(每次加2)
auto_increment_offset=1 # ⾃增偏移(从1开始),单数
2.2 Master配置
# 先重启⼀下服务
shell> service mysqld restart
# 登录到mysql
shell> mysql -uroot -p
# 创建数据库同步⽤户,并授予相应的权限
mysql> grant replication slave, replication client on *.* to 'repl'@'192.168.1.206' identified by 'root123456';
手机字体大小怎么调# 刷新授权表信息
mysql> flush privileges;
# 查看binlog⽂件的position(偏移)和File(⽇志⽂件)的值,从机上需要⽤到mysql> show master status;
鸡的组词+----------------------+----------+--------------+------------------+-------------------
+| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+----------------------+----------+--------------+------------------+-------------------+| edu-mysql-
bin.000001 | 120 | | mysql | |
+----------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)
2.3 Slave配置
# master_user和master_password:在206上执⾏grant 创建的⽤户和密码# master_log_file和
master_log_pos:在206上运⾏show master status;命令执⾏结果对应File和Position字段的值
mysql> change master to master_host='192.168.1.206',master_user='repl', master_password='root123456', master_port=3306, m mysql-bin.000001', master_log_pos=439, master_connect_retry=30;# 查看作为从节点的状态信息
mysql> show slave status\G;*************************** 1. row *************************** Slave_IO_State: Master_Host: mysql-bin.000001 Read_Master_Log_Pos: 439 Relay_Log_File: edu-mysql-relay-
bin.000001 Relay_Log_Pos: 4 Relay_Master_Log_File: edu-mysql-
bin.000001 Slave_IO_Running: No Slave_SQL_Running: No # 省略其它配置。。。
由于此时从节点还没有启动,Slave_IO_State的值为空,Slave_IO_Running和Slave_SQL_Running线程为No表⽰也没有运⾏。
2.4 启动Slave
注意:要在节点2上创建同步帐户后再启动,否则会报连不上master错误
# 启动从节点,开始⼯作接收主节点发送事件(数据库数据变更的所有事件)mysql> start slave;# 此时再查看slave节点的状态
mysql> show slave status\G;*************************** 1. row *************************** Slave_IO_State: Waiting for master to se mysql-bin.000001 Read_Master_Log_Pos: 439 Relay_Log_File: edu-mysql-relay-
bin.000002 Relay_Log_Pos: 287 Relay_Master_Log_File: edu-mysql-
bin.000001 Slave_IO_Running: Yes Slave_SQL_Running: Yes Replicate_Do_DB: # ...省略其它配
置
3. 节点2配置(192.168.1.206)
3.1 添加数据同步配置shell> vim /etc/myf
· 1
在[mysqld]中增加以下配置项:
server_id=206
binlog-ignore-db=mysqllog-bin=edu-mysql-bin
binlog_cache_size=1M
binlog_format=mixed
expire_logs_days=7
slave_skip_errors=1062
relay_log=edu-mysql-relay-bin
log_slave_updates=1#ID⾃增从2开始,双数
auto_increment_increment=2
auto_increment_offset=2
3.2 Master配置# 先重启⼀下服务
shell> service mysqld restart
# 登录到mysql
shell> mysql -uroot -p
# 创建数据库同步⽤户,并授予相应的权限(只允许repl⽤户从192.168.1.205上登录)
mysql> grant replication slave, replication client on *.* to 'repl'@'192.168.1.205' identified by 'root123456';
# 刷新授权表信息
mysql> flush privileges;
# 查看binlog⽂件的position(偏移)和File(⽇志⽂件)的值,从机上需要⽤到mysql> show master status;
+----------------------+----------+--------------+------------------+-------------------
+| File | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
+----------------------+----------+--------------+------------------+-------------------+| edu-mysql-
bin.000001 | 439 | | mysql | |
+----------------------+----------+--------------+------------------+-------------------+
1 row in set (0.00 sec)
这时可以启动节点1(205)的slave服务
3.3 Slave配置# master_log_file和master_log_pos:205节点上执⾏show master status;对应File和position的值
mysql> change master to master_host='192.168.1.205',master_user='repl', master_password='root123456', master_port=330 mysql-bin.000001', master_log_pos=120, master_connect_retry=30;
Query OK, 0 rows affected, 2 warnings (0.02 sec)
mysql> show slave status\G;*************************** 1. row *************************** Slave_IO_State: Master_Host: mysql-bin.000001 Read_Master_Log_Pos: 120 Relay_Log_File: edu-mysql-relay-
bin.000001 Relay_Log_Pos: 4 Relay_Master_Log_File: edu-mysql-
bin.000001 Slave_IO_Running: No Slave_SQL_Running: No Replicate_Do_DB: #...省略其它配置
3.4、启动Slave
shell> start slave;
Query OK, 0 rows affected (0.01 sec)
2020国庆节放假安排mysql> show slave status\G;*************************** 1. row *************************** Slave_I
O_State: Waiting for master to send event Master_Host: 192.168.1.205 Master_User: repl Master_Port: 3306
Connect_Retry: 30 Master_Log_File: edu-mysql-bin.000001 Read_Master_Log_Pos: 439
Relay_Log_File: edu-mysql-relay-bin.000002 Relay_Log_Pos: 287 Relay_Master_Log_File: edu-mysql-bin.000001 Slave_IO_Running: Yes Slave_SQL_Running: Yes Replicate_Do_DB: ...省略其它配置
4、验证# 登录205创建⼀个数据库
shell> mysql -u root -p
mysql> create database if not exists mydb default character set utf8 collate utf8_general_ci;
mysql> create table user (id int, username varchar(30), password varchar(30));
mysql> insert into user values (1, 'yangxin', '123456');# 下⾯是在206节点上的操作#1、登录206查询所有库,是否包含mydb数据
库#2、切换到mydb库,是否包含user表,并有⼀条数据#3、在206的mydb.user表插⼊⼀条数据,查看205是否同步过去
mysql> insert into user values (2,'yangxin2','123456')
详细过程如下图所⽰:
本⽂由职坐标整理发布,欢迎关注职坐标MySQL频道,学习更多数据库知识!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论