先修改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
復制代碼 代碼如下:
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 'vevb.com';
# 測試環境密碼是 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;
最后在服務器上執行
復制代碼 代碼如下:
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
復制代碼 代碼如下:
slave start;
新聞熱點
疑難解答