mysql cluster 设置单向复制_mysql单向主从配置
1.環(huán)境要求
操作系統(tǒng):centOS6.5或以上
Mysql版本:mysql5.5
主機配置:4核CPU、4G內(nèi)存
2.主從復(fù)制的方式
mysql5.6開始主從復(fù)制有兩種方式:基于日志(binlog)、基于GTID(全局十事務(wù)標(biāo)示符),下面主要介紹基于日志(binlog)的復(fù)制。
主從復(fù)制的原理
master將數(shù)據(jù)改變記錄到二進制文件(binary log)中,也就是配置文件log-bin指定的文件,這些記錄叫做二進制事件(binary log events);
slave通過I/O線程讀取master中的binary log events并寫入到它的中繼日志(relay log);
slave重做中繼日志中的事件,把中繼日志中的事件信息一條一條的在本地執(zhí)行一次完成數(shù)據(jù)在本地的存儲,進而實現(xiàn)將改變反映到自己的數(shù)據(jù);
3.主從復(fù)制注意的點
主從服務(wù)器操作系統(tǒng)版本和位數(shù)一致
master和slave數(shù)據(jù)庫的版本要一致
master和slave數(shù)據(jù)庫中的數(shù)據(jù)要一致
master開啟二進制日志,master和slave的server_id在局域網(wǎng)內(nèi)必須唯一
4.主從配置簡要步驟
master上面的配置:
1.安裝數(shù)據(jù)庫
2.修改數(shù)據(jù)庫配置文件,指明server_id,開啟二進制日志(log-bin)
3.啟動數(shù)據(jù)庫,查看當(dāng)前是哪個日志,position號是多少
4.登錄數(shù)據(jù)庫,授權(quán)數(shù)據(jù)復(fù)制用戶
5.備份數(shù)據(jù)庫(記得加鎖和解鎖)
6.傳送備份數(shù)據(jù)到slave上
7.啟動數(shù)據(jù)庫
slave上面的配置:
1.安裝數(shù)據(jù)庫
2.修改數(shù)據(jù)庫配置文件,指明server_id
3.啟動數(shù)據(jù)庫,還原備份
4.查看當(dāng)前是哪個日志,position號是多少
5.指明master的地址、用戶、密碼等信息
6.開啟同步,查看狀態(tài)
5.單向主從環(huán)境的搭建
兩臺數(shù)據(jù)庫服務(wù)器的selinux都要disable(永久關(guān)閉selinux,請修改/etc/selinux/config,將SELINUX改為disabled)
修改master的配置文件/etc/my.cnf,增加以下配置項:
server_id = 100 ?#一般設(shè)置為ip的最后一部分
binlog-do-db = admin ?#需要備份的數(shù)據(jù)庫
binlog-ignore-db = mysql #不需要復(fù)制的數(shù)據(jù)庫
log-bin = edu-mysql-bin #開啟二進制日志功能,可以隨便定義但是建議有含義
6.重新啟動master數(shù)據(jù)庫服務(wù),創(chuàng)建數(shù)據(jù)庫,創(chuàng)建數(shù)據(jù)庫同步用戶并授予相應(yīng)的權(quán)限
創(chuàng)建數(shù)據(jù)庫同步用戶并授予相應(yīng)的權(quán)限:
grant replication slave, replication client on *.* to 'repl'@'192.168.1.206' identified by 'admin.123';
flush privileges;
show master status; #查看position號,記下position號(從機上需要用到這個position和現(xiàn)在的日志文件)
7.創(chuàng)建admin庫、表,并寫入一定量的數(shù)據(jù),用于模擬現(xiàn)有的業(yè)務(wù)系統(tǒng)數(shù)據(jù)庫
8.修改slave的配置文件/etc/my.cnf,增加以下配置項:
server_id = 206 ? ?#一般設(shè)置為ip的最后一部分
binlog-do-db = admin ?#需要備份的數(shù)據(jù)庫
binlog-ignore-db = mysql #不需要復(fù)制的數(shù)據(jù)庫
log-bin = edu-mysql-bin #開啟二進制日志功能,以備 Slave 作為其它 Slave 的 Master 時使用
9.重啟slave數(shù)據(jù)庫服務(wù),將數(shù)據(jù)復(fù)制到從數(shù)據(jù)庫中
10.slave中添加master相關(guān)信息
change master to master_host='121.199.168.20', master_user='repl', master_password='admin.123', master_port=3306, ? ? ?master_log_file='edu-mysql-bin.000008' , master_log_pos=513, master_connect_retry=30;
上述參數(shù)說明:
master_log_file、master_log_pos是通過上述master的狀態(tài)獲取的
master_connect_retry ? #當(dāng)重新建立主從連接時,如果連接建立失敗,間隔多久后重試。 單位為秒,默認(rèn)設(shè)置為 60 秒,同步延遲調(diào)優(yōu)參數(shù)。
11.slave執(zhí)行主從同步:start slave;
12.show slave status\G;
Slave_IO_Running: Yes
Slave_SQL_Running: Yes
這兩個參數(shù)為Yes顯示主從狀態(tài)正常
13.主從配置完成,可以在master上面修改數(shù)據(jù)庫驗證slave數(shù)據(jù)庫是否發(fā)生了改變
14.注意:如果再slave沒做只讀控制的情況下,千萬不要在slave中手動插入數(shù)據(jù),那樣數(shù)據(jù)就會不一致,主從就會斷開,就需要重新配置了
15.如果同步過程中出現(xiàn)錯誤,可以在slave上重置主從復(fù)制數(shù)據(jù)
reset slave
change master to master_host='121.199.168.20', master_user='repl', master_password='admin.123', master_port=3306, ? ? ?master_log_file='edu-mysql-bin.000008' , master_log_pos=513, master_connect_retry=30;
master_log_file、master_log_pos根據(jù)最新的master狀態(tài)獲取
總結(jié)
以上是生活随笔為你收集整理的mysql cluster 设置单向复制_mysql单向主从配置的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 山不过来我就过去什么意思 山不过来我就过
- 下一篇: mysql忽略数据类型_MYSQL 常用