mysql主从配置_MySQL主从配置详解
主服務器數據庫的每次操作都會記錄在其二進制文件mysql-bin.xxx(該文件可以在mysql目錄下的data目錄中看到)中,從服務器的I/O線程使用專用賬號登錄到主服務器中讀取該二進制文件,并將文件內容寫入到自己本地的中繼日志relay-log文件中,然后從服務器的SQL線程會根據中繼日志中的內容執行SQL語句
MySQL主從同步的作用
1、可以作為備份機制,相當于熱備份
2、可以用來做讀寫分離,均衡數據庫負載
項目場景
1、主服務器10.10.20.111,其中已經有數據庫且庫中有表、函數以及存儲過程
2、從服務器10.10.20.116,空的啥也沒有
準備工作
主從服務器需要有相同的初態
1、將主服務器要同步的數據庫枷鎖,避免同步時數據發生改變
mysql>use?db;
mysql>flush?tables?with?read?lock;
2、將主服務器數據庫中數據導出
mysql>mysqldump?-uroot?-pxxxx?db?>?db.sql;
這個命令是導出數據庫中所有表結構和數據,如果要導出函數和存儲過程的話使用
mysql>mysqldump?-R?-ndt?db?-uroot?-pxxxx?>?db.sql
其他關于mysql導入導出命令的戳這里
3、備份完成后,解鎖主服務器數據庫
mysql>unlock?tables;
4、將初始數據導入從服務器數據庫
mysql>create?database?db;
mysql>use?db;
mysql>source?db.sql;
好了,現在主從服務器擁有一樣的初態了
主服務器配置
1、修改MySQL配置
vi?/etc/my.cnf
在[mysqld]中添加
#主數據庫端ID號
server_id?=?1
#開啟二進制日志
log-bin?=?mysql-bin
#需要復制的數據庫名,如果復制多個數據庫,重復設置這個選項即可
binlog-do-db?=?db
#將從服務器從主服務器收到的更新記入到從服務器自己的二進制日志文件中
log-slave-updates
#控制binlog的寫入頻率。每執行多少次事務寫入一次(這個參數性能消耗很大,但可減小MySQL崩潰造成的損失)
sync_binlog?=?1
#這個參數一般用在主主同步中,用來錯開自增值,?防止鍵值沖突
auto_increment_offset?=?1
#這個參數一般用在主主同步中,用來錯開自增值,?防止鍵值沖突
auto_increment_increment?=?1
#二進制日志自動刪除的天數,默認值為0,表示“沒有自動刪除”,啟動時和二進制日志循環時可能刪除
expire_logs_days?=?7
#將函數復制到slave
log_bin_trust_function_creators?=?1
2、重啟MySQL,創建允許從服務器同步數據的賬戶
#創建slave賬號account,密碼123456
mysql>grant?replication?slave?on?*.*?to?'account'@'10.10.20.116'?identified?by?'123456';
#更新數據庫權限
mysql>flush?privileges;
3、查看主服務器狀態
mysql>show?master?status\G;
*****************?1.?row?****************
File:?mysql-bin.000033?#當前記錄的日志
Position:?337523?#日志中記錄的位置
Binlog_Do_DB:
Binlog_Ignore_DB:
執行完這個步驟后不要再操作主服務器數據庫了,防止其狀態值發生變化
從服務器配置
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(刷到磁盤)操作同時進行。該模式下在事務提交的時候,不會主動觸發寫入磁盤的操作
innodb_flush_log_at_trx_commit?=?0
#指定slave要復制哪個庫
replicate-do-db?=?db
#MySQL主從復制的時候,當Master和Slave之間的網絡中斷,但是Master和Slave無法察覺的情況下(比如防火墻或者路由問題)。Slave會等待slave_net_timeout設置的秒數后,才能認為網絡出現故障,然后才會重連并且追趕這段時間主庫的數據
slave-net-timeout?=?60
log_bin_trust_function_creators?=?1
2、執行同步命令
#執行同步命令,設置主服務器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、查看從服務器狀態
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狀態,否則說明同步失敗
若失敗查看mysql錯誤日志中具體報錯詳情來進行問題定位
最后可以去主服務器上的數據庫中創建表或者更新表數據來測試同步
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的mysql主从配置_MySQL主从配置详解的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Win10显示此应用无法在你的电脑上运行
- 下一篇: thinkphp v5.0.11漏洞_T