MySQL主從配置詳解

MySQL主從復(fù)制原理

主服務(wù)器數(shù)據(jù)庫的每次操作都會記錄在其二進(jìn)制文件mysql-bin.xxx(該文件可以在mysql目錄下的data目錄中看到)中,從服務(wù)器的I/O線程使用專用賬號登錄到主服務(wù)器中讀取該二進(jìn)制文件,并將文件內(nèi)容寫入到自己本地的中繼日志relay-log文件中,然后從服務(wù)器的SQL線程會根據(jù)中繼日志中的內(nèi)容執(zhí)行SQL語句

MySQL主從同步的作用

1、可以作為備份機(jī)制,相當(dāng)于熱備份
2、可以用來做讀寫分離,均衡數(shù)據(jù)庫負(fù)載

項目場景

1、主服務(wù)器10.10.20.111,其中已經(jīng)有數(shù)據(jù)庫且?guī)熘杏斜怼⒑瘮?shù)以及存儲過程

2、從服務(wù)器10.10.20.116,空的啥也沒有

準(zhǔn)備工作

主從服務(wù)器需要有相同的初態(tài)
1、將主服務(wù)器要同步的數(shù)據(jù)庫枷鎖,避免同步時數(shù)據(jù)發(fā)生改變

mysql>use db;
mysql>flush tables with read lock;  

2、將主服務(wù)器數(shù)據(jù)庫中數(shù)據(jù)導(dǎo)出

mysql>mysqldump -uroot -pxxxx db > db.sql;

這個命令是導(dǎo)出數(shù)據(jù)庫中所有表結(jié)構(gòu)和數(shù)據(jù),如果要導(dǎo)出函數(shù)和存儲過程的話使用

mysql>mysqldump -R -ndt db -uroot -pxxxx > db.sql

其他關(guān)于mysql導(dǎo)入導(dǎo)出命令的戳這里
3、備份完成后,解鎖主服務(wù)器數(shù)據(jù)庫

mysql>unlock tables;

4、將初始數(shù)據(jù)導(dǎo)入從服務(wù)器數(shù)據(jù)庫

mysql>create database db;
mysql>use db;
mysql>source db.sql;

好了,現(xiàn)在主從服務(wù)器擁有一樣的初態(tài)了

主服務(wù)器配置

1、修改MySQL配置

vi /etc/my.cnf

在[mysqld]中添加

#主數(shù)據(jù)庫端ID號
server_id = 1           
 #開啟二進(jìn)制日志                  
log-bin = mysql-bin    
#需要復(fù)制的數(shù)據(jù)庫名,如果復(fù)制多個數(shù)據(jù)庫,重復(fù)設(shè)置這個選項即可                  
binlog-do-db = db        
#將從服務(wù)器從主服務(wù)器收到的更新記入到從服務(wù)器自己的二進(jìn)制日志文件中                 
log-slave-updates                        
#控制binlog的寫入頻率。每執(zhí)行多少次事務(wù)寫入一次(這個參數(shù)性能消耗很大,但可減小MySQL崩潰造成的損失) 
sync_binlog = 1                    
#這個參數(shù)一般用在主主同步中,用來錯開自增值, 防止鍵值沖突
auto_increment_offset = 1           
#這個參數(shù)一般用在主主同步中,用來錯開自增值, 防止鍵值沖突
auto_increment_increment = 1            
#二進(jìn)制日志自動刪除的天數(shù),默認(rèn)值為0,表示“沒有自動刪除”,啟動時和二進(jìn)制日志循環(huán)時可能刪除  
expire_logs_days = 7                    
#將函數(shù)復(fù)制到slave  
log_bin_trust_function_creators = 1       

2、重啟MySQL,創(chuàng)建允許從服務(wù)器同步數(shù)據(jù)的賬戶

#創(chuàng)建slave賬號account,密碼123456
mysql>grant replication slave on *.* to 'account'@'10.10.20.116' identified by '123456';
#更新數(shù)據(jù)庫權(quán)限
mysql>flush privileges;

3、查看主服務(wù)器狀態(tài)

mysql>show master status\G;
***************** 1. row ****************
            File: mysql-bin.000033 #當(dāng)前記錄的日志
        Position: 337523 #日志中記錄的位置  
    Binlog_Do_DB: 
Binlog_Ignore_DB: 

執(zhí)行完這個步驟后不要再操作主服務(wù)器數(shù)據(jù)庫了,防止其狀態(tài)值發(fā)生變化

從服務(wù)器配置

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(刷到磁盤)操作同時進(jìn)行。該模式下在事務(wù)提交的時候,不會主動觸發(fā)寫入磁盤的操作
innodb_flush_log_at_trx_commit = 0        
#指定slave要復(fù)制哪個庫
replicate-do-db = db         
#MySQL主從復(fù)制的時候,當(dāng)Master和Slave之間的網(wǎng)絡(luò)中斷,但是Master和Slave無法察覺的情況下(比如防火墻或者路由問題)。Slave會等待slave_net_timeout設(shè)置的秒數(shù)后,才能認(rèn)為網(wǎng)絡(luò)出現(xiàn)故障,然后才會重連并且追趕這段時間主庫的數(shù)據(jù)
slave-net-timeout = 60                    
log_bin_trust_function_creators = 1

2、執(zhí)行同步命令

#執(zhí)行同步命令,設(shè)置主服務(wù)器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、查看從服務(wù)器狀態(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進(jìn)程必須正常運行,即Yes狀態(tài),否則說明同步失敗
若失敗查看mysql錯誤日志中具體報錯詳情來進(jìn)行問題定位
最后可以去主服務(wù)器上的數(shù)據(jù)庫中創(chuàng)建表或者更新表數(shù)據(jù)來測試同步

參考1:MySQL配置主主及主從備份
參考2:MySQL數(shù)據(jù)庫設(shè)置主從同步

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容