MySQL同步數據Replication的實現步驟

MySQL提供瞭Replication功能,可以實現將一個數據庫的數據同步到多臺其他數據庫。前者通常稱之為主庫(master),後者則被稱從庫(slave)。MySQL復制過程采用異步方式,但延時非常小,秒級同步。

一、同步復制數據基本原理

1.在主庫上發生的數據變化記錄到二進制日志Binlog
2.從庫的IO線程將主庫的Binlog復制到自己的中繼日志Relay log
3.從庫的SQL線程通過讀取、重放中繼日志實現數據復制

mysql

MySQL的復制有三種模式:Statement Level、Row Level、Mixed Level。復制級別的不同,會導致Master端二進制日志文件的生成形式的不同。

二、同步數據示例

操作系統: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狀態,獲取日志文件名稱和偏移量信息

show-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

在主機上,向某表中插入數據,查看從機對應表中的數據情況,經測試效果很好(略)

到此這篇關於MySQL同步數據Replication的實現步驟的文章就介紹到這瞭,更多相關MySQL同步數據Replication內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: