mysql 主从复制原理及基于事务的 Replication

原理

主服务器上面的任何修改都会通过自己的 I/O tread (I/O 线程) 保存在二进制日志 Binary log 里面;

从服务器 I/O 线程去请求主库的 Binary log,并将得到的 Binary log日志写到realy log(中继日志) 文件中;

从服务器 SQL 线程,读取 relay log 文件中的日志,并解析成具体操作,来实现主从的操作一致,而最终数据一致。

操作步骤

1.配置主库

// 修改配置文件
[root@master ~]# vim /etc/my.cnf
[mysqld]
log-bin=/var/log/mysql/mysql-bin
server-id=1
gtid_mode=ON
enforce_gtid_consistency=1
[root@master ~]#  systemctl restart mysqld

2.配置从服务器

// 修改配置文件
[root@slave ~]# vim /etc/my.cnf
[mysqld]
server-id=2
gtid_mode=ON
enforce_gtid_consistency=1
[root@slave ~]#  systemctl restart mysqld
  1. 将主库中的库表导入从库中
// 主库备份
[root@master]# mysqldump -uroot  -pmiacis --all-databases --master-data=1 > ./all.sql   
[root@master]# scp ./all.sql 192.168.223.201:/root

// 从库恢复
[root@slave ~]# mysql -uroot -pmiacis < ./all.sql 
[root@slave ~]# mysql -uroot -pmiacis         //确定主从的数据一致
mysql> show databases;
  1. 主库给从库授权
// 主库授权
mysql> create user 'repl'@'%' identified by '123';
mysql> grant replication slave on  *.* to 'repl'@'%';

// 从库登录测试
[root@slave ~]# mysql -urepl -p123 -h 192.168.223.101

5.配置主从同步

[root@slave ~]# mysql -uroot -pmiacis
mysql> change master to
master_host='172.16.153.10',
master_user='repl',
master_password='123',
master_auto_position=1;

mysql> start slave;

6.查看状态

mysql> show slave status\G
*************************** 1. row ***************************
               Slave_IO_State: Waiting for master to send event
                  Master_Host: 192.168.223.101
                  Master_User: repl
                  Master_Port: 3306
                Connect_Retry: 60
              Master_Log_File: mysql-bin.000002
          Read_Master_Log_Pos: 194
               Relay_Log_File: compute1-relay-bin.000002
                Relay_Log_Pos: 367
        Relay_Master_Log_File: mysql-bin.000002
             Slave_IO_Running: Yes
            Slave_SQL_Running: Yes
             ......

你可能感兴趣的:(mysql 主从复制原理及基于事务的 Replication)