CentOS 7下怎么搭建高可用集群。高可用集群是指以減少服務(wù)中斷時(shí)間為目的的服務(wù)器集群技術(shù)。它通過保護(hù)用戶的業(yè)務(wù)程序?qū)ν獠婚g斷提供的服務(wù),把因軟件/硬件/人為造成的故障對(duì)業(yè)務(wù)的影響降低到最小程度。那么新的centos下怎么來搭建高可用集群。
環(huán)境:本文以兩臺(tái)機(jī)器實(shí)現(xiàn)雙集熱備高可用集群,主機(jī)名node1的IP為192.168.122.168 ,主機(jī)名node2的IP為192.168.122.169 。
一、安裝集群軟件必須軟件pcs,pacemaker,corosync,fence-agents-all,如果需要配置相關(guān)服務(wù),也要安裝對(duì)應(yīng)的軟件
二、配置防火墻
1、禁止防火墻和selinux
修改/etc/sysconfig/selinux確保SELINUX=disabled,然后執(zhí)行setenforce 0或者reboot服務(wù)器以生效
2、設(shè)置防火墻規(guī)則
三、各節(jié)點(diǎn)之間主機(jī)名互相解析分別修改2臺(tái)主機(jī)名分別為node1和node2,在centos 7中直接修改/etc/hostname加入本機(jī)主機(jī)名和主機(jī)表,然后重啟網(wǎng)絡(luò)服務(wù)即可。
配置2臺(tái)主機(jī)的主機(jī)表,在/etc/hosts中加入
四、各節(jié)點(diǎn)之間時(shí)間同步在node1和node2分別進(jìn)行時(shí)間同步,可以使用ntp實(shí)現(xiàn)。
五、各節(jié)點(diǎn)之間配置ssh的無密碼密鑰訪問。下面的操作需要在各個(gè)節(jié)點(diǎn)上操作。
兩臺(tái)主機(jī)都要互相可以通信,所以兩臺(tái)主機(jī)都得互相生成密鑰和復(fù)制公鑰,相互的節(jié)點(diǎn)上的hosts文件是都要解析對(duì)方的主機(jī)名, 192.168.122.168 node1 192.168.122.169 node2
六、通過pacemaker來管理高可用集群
1、創(chuàng)建集群用戶
為了有利于各節(jié)點(diǎn)之間通信和配置集群,在每個(gè)節(jié)點(diǎn)上創(chuàng)建一個(gè)hacluster的用戶,各個(gè)節(jié)點(diǎn)上的密碼必須是同一個(gè)。
2、設(shè)置pcsd開機(jī)自啟動(dòng)
3、集群各節(jié)點(diǎn)之間進(jìn)行認(rèn)證
4、創(chuàng)建并啟動(dòng)集群
5、設(shè)置集群自啟動(dòng)
6、查看集群狀態(tài)信息
7、設(shè)置fence設(shè)備
這個(gè)可以參考<Red Hat Enterprise Linux 7 High Availability Add-On Reference>
corosync默認(rèn)啟用了stonith,而當(dāng)前集群并沒有相應(yīng)的stonith設(shè)備,因此此默認(rèn)配置目前尚不可用,這可以通過如下命令驗(yàn)證:
可以通過如下面命令禁用stonith:
8、配置存儲(chǔ)
高可用集群既可以使用本地磁盤來構(gòu)建純軟件的鏡像型集群系統(tǒng),也可以使用專門的共享磁盤裝置來構(gòu)建大規(guī)模的共享磁盤型集群系統(tǒng),充分滿足客戶的不同需求。
共享磁盤主要有iscsi或DBRD。本文并沒有使用共享磁盤。
9、配置浮點(diǎn)IP
不管集群服務(wù)在哪運(yùn)行,我們要一個(gè)固定的地址來提供服務(wù)。在這里我選擇192.168.122.101作為浮動(dòng)IP,給它取一個(gè)好記的名字ClusterIP 并且告訴集群 每30秒檢查它一次。
10、配置apache服務(wù)
在node1和node2上安裝httpd ,確認(rèn)httpd開機(jī)被禁用
配置httpd監(jiān)控頁面(貌似不配置也可以通過systemd監(jiān)控),分別在node1和node2上執(zhí)行