MySQL主從復制原理
主服務器數(shù)據(jù)庫的每次操作都會記錄在其二進制文件mysql-bin.xxx(該文件可以在mysql目錄下的data目錄中看到)中,從服務器的I/O線程使用專用賬號登錄到主服務器中讀取該二進制文件,并將文件內容寫入到自己本地的中繼日志relay-log文件中骑科,然后從服務器的SQL線程會根據(jù)中繼日志中的內容執(zhí)行SQL語句
MySQL主從同步的作用
1镣奋、可以作為備份機制武氓,相當于熱備份
2倍阐、可以用來做讀寫分離檐晕,均衡數(shù)據(jù)庫負載
項目場景
1暑诸、主服務器10.10.20.111,其中已經(jīng)有數(shù)據(jù)庫且?guī)熘杏斜肀倩摇⒑瘮?shù)以及存儲過程
2个榕、從服務器10.10.20.116,空的啥也沒有
準備工作
主從服務器需要有相同的初態(tài)
1芥喇、將主服務器要同步的數(shù)據(jù)庫枷鎖西采,避免同步時數(shù)據(jù)發(fā)生改變
mysql>use db;
mysql>flush tables with read lock;
2、將主服務器數(shù)據(jù)庫中數(shù)據(jù)導出
mysql>mysqldump -uroot -pxxxx db > db.sql;
這個命令是導出數(shù)據(jù)庫中所有表結構和數(shù)據(jù)继控,如果要導出函數(shù)和存儲過程的話使用
mysql>mysqldump -R -ndt db -uroot -pxxxx > db.sql
其他關于mysql導入導出命令的戳這里
3械馆、備份完成后,解鎖主服務器數(shù)據(jù)庫
mysql>unlock tables;
4武通、將初始數(shù)據(jù)導入從服務器數(shù)據(jù)庫
mysql>create database db;
mysql>use db;
mysql>source db.sql;
好了霹崎,現(xiàn)在主從服務器擁有一樣的初態(tài)了
主服務器配置
1、修改MySQL配置
vi /etc/my.cnf
在[mysqld]中添加
#主數(shù)據(jù)庫端ID號
server_id = 1
#開啟二進制日志
log-bin = mysql-bin
#需要復制的數(shù)據(jù)庫名冶忱,如果復制多個數(shù)據(jù)庫尾菇,重復設置這個選項即可
binlog-do-db = db
#將從服務器從主服務器收到的更新記入到從服務器自己的二進制日志文件中
log-slave-updates
#控制binlog的寫入頻率。每執(zhí)行多少次事務寫入一次(這個參數(shù)性能消耗很大囚枪,但可減小MySQL崩潰造成的損失)
sync_binlog = 1
#這個參數(shù)一般用在主主同步中派诬,用來錯開自增值, 防止鍵值沖突
auto_increment_offset = 1
#這個參數(shù)一般用在主主同步中,用來錯開自增值, 防止鍵值沖突
auto_increment_increment = 1
#二進制日志自動刪除的天數(shù)链沼,默認值為0,表示“沒有自動刪除”千埃,啟動時和二進制日志循環(huán)時可能刪除
expire_logs_days = 7
#將函數(shù)復制到slave
log_bin_trust_function_creators = 1
2、重啟MySQL忆植,創(chuàng)建允許從服務器同步數(shù)據(jù)的賬戶
#創(chuàng)建slave賬號account放可,密碼123456
mysql>grant replication slave on *.* to 'account'@'10.10.20.116' identified by '123456';
#更新數(shù)據(jù)庫權限
mysql>flush privileges;
3谒臼、查看主服務器狀態(tài)
mysql>show master status\G;
***************** 1. row ****************
File: mysql-bin.000033 #當前記錄的日志
Position: 337523 #日志中記錄的位置
Binlog_Do_DB:
Binlog_Ignore_DB:
執(zhí)行完這個步驟后不要再操作主服務器數(shù)據(jù)庫了,防止其狀態(tài)值發(fā)生變化
從服務器配置
1耀里、修改MySQL配置
vi /etc/my.cnf
在[mysqld]中添加
server_id = 2
log-bin = mysql-bin
log-slave-updates
sync_binlog = 0
#log buffer將每秒一次地寫入log file中蜈缤,并且log file的flush(刷到磁盤)操作同時進行。該模式下在事務提交的時候冯挎,不會主動觸發(fā)寫入磁盤的操作
innodb_flush_log_at_trx_commit = 0
#指定slave要復制哪個庫
replicate-do-db = db
#MySQL主從復制的時候底哥,當Master和Slave之間的網(wǎng)絡中斷,但是Master和Slave無法察覺的情況下(比如防火墻或者路由問題)房官。Slave會等待slave_net_timeout設置的秒數(shù)后趾徽,才能認為網(wǎng)絡出現(xiàn)故障,然后才會重連并且追趕這段時間主庫的數(shù)據(jù)
slave-net-timeout = 60
log_bin_trust_function_creators = 1
2翰守、執(zhí)行同步命令
#執(zhí)行同步命令孵奶,設置主服務器ip,同步賬號密碼蜡峰,同步位置
mysql>change master to master_host='10.10.20.111',master_user='account',master_password='123456',master_log_file='mysql-bin.000033',master_log_pos=337523;
#開啟同步功能
mysql>start slave;
3了袁、查看從服務器狀態(tài)
mysql>show slave status\G;
*************************** 1. row ***************************
Slave_IO_State: Waiting for master to send event
Master_Host: 10.10.20.111
Master_User: account
Master_Port: 3306
Connect_Retry: 60
Master_Log_File: mysql-bin.000033
Read_Master_Log_Pos: 337523
Relay_Log_File: db2-relay-bin.000002
Relay_Log_Pos: 337686
Relay_Master_Log_File: mysql-bin.000033
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
Replicate_Do_DB:
Replicate_Ignore_DB:
...
Slave_IO_Running及Slave_SQL_Running進程必須正常運行,即Yes狀態(tài)湿颅,否則說明同步失敗
若失敗查看mysql錯誤日志中具體報錯詳情來進行問題定位
最后可以去主服務器上的數(shù)據(jù)庫中創(chuàng)建表或者更新表數(shù)據(jù)來測試同步