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