MySQL 5.5主從同步設定筆記分享_Mysql

來源:互聯網
上載者:User

先修改Master(10.1.123.197)的 my.cnf 配置

在 [mysqld] 中新增以下內容:

複製代碼 代碼如下:

log-bin=mysql-bin
log-bin-index=mysql-bin.index
server-id = 1
sync_binlog=1
binlog_format=mixed

然後指定要做同步的資料庫,並忽略掉不需要做同步的資料庫
複製代碼 代碼如下:

binlog-do-db = testdb
binlog-ignore-db = mysql
binlog-ignore-db = performance_schema
binlog-ignore-db = information_schema

在 [mysqldump] 中修改內容為    
複製代碼 代碼如下:
max_allowed_packet = 32M

注意:確保 max_allowed_packet 有比較大的值,比如 max_allowed_packet = 100M

重啟 mysql:

複製代碼 代碼如下:
service mysql restart

在Master上建立一個複製使用者

複製代碼 代碼如下:
CREATE USER funsion;
GRANT REPLICATION SLAVE ON *.* TO funsion IDENTIFIED BY 'jb51.net';
# 測試環境密碼是  xyzzy

+ ---------------------------------------------------------- +

再修改 Slave(10.1.123.160)的配置,修改 my.cnf

在 [mysqld] 中新增以下內容

複製代碼 代碼如下:

server-id=2
log-bin = mysql-bin
relay-log-index = slave-relay-bin.index
relay-log = slave-relay-bin

sync_master_info = 1
sync_relay_log = 1
sync_relay_log_info = 1

# 以上三行話只使用於MySQL 5.5

輸入 mysql -u root -p
進入mysql命令列,輸入

複製代碼 代碼如下:

CHANGE MASTER TO MASTER_HOST = '10.1.123.233', MASTER_USER = 'funsion', MASTER_PORT = 3306, MASTER_PASSWORD = 'ifunsion.com';

CHANGE MASTER TO MASTER_CONNECT_RETRY=30;

在輸入 START SLAVE;

+ ----------------------- 如果發生錯誤無法啟動 ------------------- +

進入Master 的資料庫
輸入 show master status\G
記錄下當前使用的 log-bin檔案,以及position (比如現在日誌是 mysql-bin.000001 ,位置是 107)

然後進入Slave 的資料庫
輸入 stop slave;

複製代碼 代碼如下:
change master to master_log_file='mysql-bin.000001',master_log_pos=107;

最後輸入  start slave;

最後在伺服器上執行

複製代碼 代碼如下:
yum -y install ntpdate
ntpdate cn.pool.ntp.org
clock -w

把幾台伺服器的時間同步

+ ---------------------------- 一些可能用到的命令 ------------------------- +

執行鎖表:

複製代碼 代碼如下:
flush tables with read lock;

這一步的目的是使我們在製作主從的過程中,主庫中不會有新的資料,否則會給我們的同步設定帶來麻煩

主庫執行解鎖:

複製代碼 代碼如下:
unlock tables;

reset master 命令刪除了所有的二進位記錄檔並清空了二進位日誌索引檔案。
reset slave  命令刪除了Slave複製所用的所有檔案,重新開始。


+ ----------------------- 其它參考文檔(未驗證)-------------------------- +

庫業務不能停的情況下為從庫製作鏡像:
案例:
伺服器1號:主
伺服器2號:從
現在由於負載問題需要上架伺服器3號同樣為1號的從伺服器。
但是1號庫不能停,2號也不能停,主從同步進程也不能停(要求苛刻)。
可以這樣做:
在主:

複製代碼 代碼如下:
mysqldump -uroot -pxxxx -h127.0.0.1 --databases db1 db2 db3 --master-data=1 > bak.sql

3號伺服器slave stop;
之後將bak.sql匯入3號從伺服器
複製代碼 代碼如下:
slave start;

3號伺服器會自動從匯出的那一刻的節點更新。
因為--master-data=1 這個參數在匯出sql檔案後會在最下方加上change語句。如果--master-data=0,則不會帶有。
非常的方便,但僅適合庫不是太大的情況,該案例匯出的庫一共6G。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.