如何部署MySQL-MMM高可用群集,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學(xué)習(xí)下,希望你能有所收獲。
十多年的巴南網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。營銷型網(wǎng)站的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整巴南建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)公司從事“巴南網(wǎng)站設(shè)計”,“巴南網(wǎng)站推廣”以來,每個客戶項目都認(rèn)真落實執(zhí)行。
MMM(Master-Master replication manager for MySQL)是一套支持雙主故障切換和雙主日常管理的腳本程序。MMM使用Perl語言開發(fā),主要用來監(jiān)控和管理MySQL Master-Master(雙主)復(fù)制,雖然叫做雙主復(fù)制,但是業(yè)務(wù)上同一時刻只允許對一個主進行寫入,另一臺備選主上提供部分讀服務(wù),以加速在主主切換時刻備選主的預(yù)熱,可以說MMM這套腳本程序一方面實現(xiàn)了故障切換的功能,另一方面其內(nèi)部附加的工具腳本也可以實現(xiàn)多個slave的read負(fù)載均衡。
MMM提供了自動和手動兩種方式移除一組服務(wù)器中復(fù)制延遲較高的服務(wù)器的虛擬ip,同時它還可以備份數(shù)據(jù),實現(xiàn)兩節(jié)點之間的數(shù)據(jù)同步等。由于MMM無法完全的保證數(shù)據(jù)一致性,所以MMM適用于對數(shù)據(jù)的一致性要求不是很高,但是又想最大程度的保證業(yè)務(wù)可用性的場景。對于那些對數(shù)據(jù)的一致性要求很高的業(yè)務(wù),非常不建議采用MMM這種高可用架構(gòu)。
搭建mysql高可用群集
在5臺服務(wù)器上關(guān)閉防火墻,安全性
setenforce 0
systemctl stop firewalld.service
一、master01、master02、slave01、slave02、monitor 5臺mysql服務(wù)器配置
1.配置all云源(yum源)
wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo`
2.配置epel源(最新版本)
yum -y install epel-release
3.加載元數(shù)據(jù)緩存
yum clean all && yum makecache`
4.安裝mariadb數(shù)據(jù)庫和mysql-mmm軟件包
yum install mariadb-sever mariadb mysql-mmm* -y
5.修改mariadb數(shù)據(jù)庫主配置文件
vim /etc/my.cnf
[mysqld]
log_error=/var/lib/mysql/mysql.err #錯誤日志
log=/var/lib/mysql/mysql_log.log #訪問日志
log_slow_queries=/var/lib/mysql_slow_queris.log #慢日志
binlog-ignore-db=mysql,information_schema #不生成二進制日志文件
character_set_server=utf8 #字符集
log_bin=mysql_bin #開啟二進制文件
server_id=1 #id號是唯一的
log_slave_updates=true #同步開啟
sync_binlog=1 #同步二進制日志,1設(shè)為安全值
auto_increment_increment=2 #自增列,起點為1,增量為2
auto_increment_offset=1備注:分別修改master02、slave01、slave02的配置文件server_id參數(shù)
6.啟動mariadb 服務(wù)
systemctl enable mariadb #開機自啟動mariadb systemctl start mariadb.service #啟動mariadb 服務(wù)
二、主、主復(fù)制(主服務(wù)器之間相互復(fù)制)
1.登錄mariadb,在主服務(wù)器master1上授權(quán)
mysql grant replication slave on *.* to 'replication'@'192.168.65.%' identified by '123456';
2.在master1上指定master2的日志和位置參數(shù)
change master to master_host='192.168.65.142',master_user='replication',master_password ='123456',master_log_file='mysql_bin.000003',master_log_pos=245;
3.開啟同步start slave;
4.在主服務(wù)器master2上授權(quán)
mysql grant replication slave on *.* to 'replication'@'192.168.65.%' identified by '123456';
5.在master2上指定master1的日志和位置參數(shù)
change master to master_host='192.168.65.159',master_user='replication',master_password='123456', master_log_file='mysql_bin.000003',master_log_pos=245;
6.開啟同步
start slave; show slave status\G
7.從服務(wù)器同步主(兩臺從服務(wù)器都指向同一臺主服務(wù)器)
兩臺從服務(wù)器同樣操作:
mysql change master to master_host='192.168.65.159',master_user='replication',master_password='123456',master_log_file='mysql_bin.000003',master_log_pos=245;(# 注意主服務(wù)器位置參數(shù)變化) start slave; #開啟同步
8.測試:四臺全部同步
三、配置mysql-MMM服務(wù)器(5臺服務(wù)器都配置)
1.編輯mysql-mmm的配置文件
vim mmm_common.conf #所有主機都要配置,復(fù)制cluster_interface ens33 #修改網(wǎng)卡為ens33 pid_path /run/mysql-mmm-agent.pid bin_path /usr/libexec/mysql-mmm/ replication_user replicantion replication_password 123456 #修改Mariadb給予權(quán)限的用戶密碼 agent_user mmm_agent agent_password 123456 #修改agent客戶端代理用戶密碼 #指定第一個數(shù)據(jù)庫 ip 192.168.65.159 #指定IP地址 mode master #模式為主服務(wù)器 peer db2 #與db2互為切換 #指定第二個數(shù)據(jù)庫 ip 192.168.65.142 #指定IP地址 mode master #模式為主服務(wù)器 peer db1 #與db1互為切換 #指定第二個數(shù)據(jù)庫 ip 192.168.65.165 #指定IP地址 mode slave #模式為從服務(wù)器 #指定第二個數(shù)據(jù)庫 ip 192.168.65.152 #指定IP地址 mode slave #模式為從服務(wù)器 #指定寫入服務(wù)器 hosts db1, db2 #指定db1,db2為寫入服務(wù)器 ips 192.168.65.100 #指定寫入虛擬ip地址 mode exclusive #模式為單獨的(只能有一個) #指定讀取服務(wù)器 hosts db3, db4 #指定db1,db2為寫入服務(wù)器 ips 192.168.65.101, 192.168.100.65.102 #指定讀取虛擬ip地址 mode balanced #模式為負(fù)載均衡,讀取操作會從db3、db4主機進行
2.將配置文件傳輸?shù)狡渌?臺數(shù)據(jù)庫服務(wù)器上
scp mmm_common.conf root@192.168.65.142:/etc/mysql-mmm/ scp mmm_common.conf root@192.168.65.152:/etc/mysql-mmm/ scp mmm_common.conf root@192.168.65.165:/etc/mysql-mmm/ scp mmm_common.conf root@192.168.65.164:/etc/mysql-mmm/
備注:一定要去其它4臺服務(wù)器上確認(rèn)已修改!
3.monitor配置
cd /etc/mysql-mmm/ vim mmm_mon.conf #改密碼 ping_ips 192.168.65.159,192.168.65.142,192.168.65.152,192.168.65.165 auto_set_online 10 #修改為10,表示10秒鐘上線 ...... 省略部分內(nèi)容monitor_user mmm_monitor #監(jiān)控機用戶名 monitor_password 123456 #修改密碼
4.在所有數(shù)據(jù)庫上為mmm_agent授權(quán)grant super,replication client,process on *.* to 'mmm_agent'@'192.168.65.%' identified by '123456';
6在所有數(shù)據(jù)庫上為mmm_monitor授權(quán)
grant replication client on *.* to 'mmm_monitor'@'192.168.65.%' identified by '123456'; flush privileges; #刷新生效
7.在4臺數(shù)據(jù)庫上分別修改mmm_agent.conf
vim mmm_agent.conf this is db1/2/3/4 #在4臺數(shù)據(jù)庫分別修改
8啟動mysql-mmm-agent
systemctl restart mysql-mmm-agent.service systemctl enable mysql-mmm-agent.service
9.啟動mysql-mmm-monitorsystemctl start mysql-mmm-monitor.service #啟動服務(wù)
10.檢查所有選項
mmm_control show #查看各節(jié)點情況 mmm_control checks all
11.可以手動切換主服務(wù)器
mmm_control move_role writer db2
四、模擬故障
1.先停止db1,db3systemctl stop mariadb
2.再查看mysql-mmm服務(wù)器狀態(tài)mmm_control show
3.恢復(fù)db1,db3上線
4.再查看mysql-mmm服務(wù)器狀態(tài)mmm_control show
5.當(dāng)db1服務(wù)器恢復(fù)后,并不會搶占vip地址,而是作為備用機在等待著,
當(dāng)db2下線后,再次查看
看完上述內(nèi)容是否對您有幫助呢?如果還想對相關(guān)知識有進一步的了解或閱讀更多相關(guān)文章,請關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝您對創(chuàng)新互聯(lián)的支持。