Linux系統(tǒng) CentOS 7怎么搭建集群? 搭建高可用集群的步驟

CentOS 7下怎么搭建高可用集群。高可用集群是指以減少服務(wù)中斷時(shí)間為目的的服務(wù)器集群技術(shù)。它通過(guò)保護(hù)用戶的業(yè)務(wù)程序?qū)ν獠婚g斷提供的服務(wù),把因軟件/硬件/人為造成的故障對(duì)業(yè)務(wù)的影響降低到最小程度。那么新的centos下怎么來(lái)搭建高可用集群。
環(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的無(wú)密碼密鑰訪問(wèn)。下面的操作需要在各個(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
六、通過(guò)pacemaker來(lái)管理高可用集群
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)前集群并沒(méi)有相應(yīng)的stonith設(shè)備,因此此默認(rèn)配置目前尚不可用,這可以通過(guò)如下命令驗(yàn)證:
可以通過(guò)如下面命令禁用stonith:
8、配置存儲(chǔ)
高可用集群既可以使用本地磁盤來(lái)構(gòu)建純軟件的鏡像型集群系統(tǒng),也可以使用專門的共享磁盤裝置來(lái)構(gòu)建大規(guī)模的共享磁盤型集群系統(tǒng),充分滿足客戶的不同需求。
共享磁盤主要有iscsi或DBRD。本文并沒(méi)有使用共享磁盤。
9、配置浮點(diǎn)IP
不管集群服務(wù)在哪運(yùn)行,我們要一個(gè)固定的地址來(lái)提供服務(wù)。在這里我選擇192.168.122.101作為浮動(dòng)IP,給它取一個(gè)好記的名字ClusterIP 并且告訴集群 每30秒檢查它一次。
10、配置apache服務(wù)
在node1和node2上安裝httpd ,確認(rèn)httpd開機(jī)被禁用
配置httpd監(jiān)控頁(yè)面(貌似不配置也可以通過(guò)systemd監(jiān)控),分別在node1和node2上執(zhí)行
首先我們?yōu)锳pache創(chuàng)建一個(gè)主頁(yè)。在centos上面默認(rèn)的Apache docroot是/var/www/html,所以我們?cè)谶@個(gè)目錄下面建立一個(gè)主頁(yè)。
node1節(jié)點(diǎn)修改如下:
node2節(jié)點(diǎn)修改如下:
下面語(yǔ)句是將httpd作為資源添加到集群中:
11、創(chuàng)建group
將VIP和WEB resource加入到這個(gè)group中,使之作為一個(gè)整體在集群中切換。(此配置為可選)
12、配置服務(wù)啟動(dòng)順序
以避免出現(xiàn)資源沖突,語(yǔ)法:(pcs resource group add的時(shí)候也可以根據(jù)加的順序依次啟動(dòng),此配置為可選)
13、指定優(yōu)先的 Location (此配置為可選)
Pacemaker 并不要求你機(jī)器的硬件配置是相同的,可能某些機(jī)器比另外的機(jī)器配置要好。這種狀況下我們會(huì)希望設(shè)置:當(dāng)某個(gè)節(jié)點(diǎn)可用時(shí),資源就要跑在上面之類的規(guī)則。為了達(dá)到這個(gè)效果我們創(chuàng)建location約束。同樣的,我們給他取一個(gè)描述性的名字(prefer-node1),指明我們想在上面跑WEB 這個(gè)服務(wù),多想在上面跑(我們現(xiàn)在指定分值為50,但是在雙節(jié)點(diǎn)的集群狀態(tài)下,任何大于0的值都可以達(dá)到想要的效果),以及目標(biāo)節(jié)點(diǎn)的名字:
這里指定分值越大,代表越想在對(duì)應(yīng)的節(jié)點(diǎn)上運(yùn)行。
14、資源粘性(此配置為可選)
一些環(huán)境中會(huì)要求盡量避免資源在節(jié)點(diǎn)之間遷移。遷移資源通常意味著一段時(shí)間內(nèi)無(wú)法提供服務(wù),某些復(fù)雜的服務(wù),比如Oracle數(shù)據(jù)庫(kù),這個(gè)時(shí)間可能會(huì)很長(zhǎng)。
為了達(dá)到這個(gè)效果,Pacemaker 有一個(gè)叫做“資源粘性值”的概念,它能夠控制一個(gè)服務(wù)(資源)有多想呆在它正在運(yùn)行的節(jié)點(diǎn)上。
Pacemaker為了達(dá)到最優(yōu)分布各個(gè)資源的目的,默認(rèn)設(shè)置這個(gè)值為0。我們可以為每個(gè)資源定義不同的粘性值,但一般來(lái)說(shuō),更改默認(rèn)粘性值就夠了。資源粘性表示資源是否傾向于留在當(dāng)前節(jié)點(diǎn),如果為正整數(shù),表示傾向,負(fù)數(shù)則會(huì)離開,-inf表示負(fù)無(wú)窮,inf表示正無(wú)窮。
常用命令匯總:查看集群狀態(tài):#pcs status
查看集群當(dāng)前配置:#pcs config
開機(jī)后集群自啟動(dòng):#pcs cluster enable –all
啟動(dòng)集群:#pcs cluster start –all
查看集群資源狀態(tài):#pcs resource show
驗(yàn)證集群配置情況:#crm_verify -L -V
測(cè)試資源配置:#pcs resource debug-start resource
設(shè)置節(jié)點(diǎn)為備用狀態(tài):#pcs cluster standby node1
這就是小編給大家?guī)?lái)的CentOS 7下怎么搭建高可用集群步驟,是不是很詳細(xì)。謝謝閱讀,希望能幫到大家,請(qǐng)繼續(xù)關(guān)注腳本之家,我們會(huì)努力分享更多優(yōu)秀的文章。
相關(guān)文章
Fedora Linux 42 穩(wěn)定版發(fā)布: 帶來(lái)大量新功能和軟件更新
Fedora 42昨日發(fā)布,這是 Red Hat 贊助開發(fā)的杰出前沿 Linux 發(fā)行版的最新版,包含大量新功能和軟件更新,使其成為 2025 年上半年發(fā)布的一款出色的 Linux 操作系統(tǒng)之一,內(nèi)2025-04-16如何在Linux查看硬盤信息? 查看Linux硬盤大小類型和硬件信息的5種方法
使用Linux系統(tǒng)的過(guò)程中,查看和了解硬盤信息是非常重要的工作,尤其是對(duì)于系統(tǒng)管理員而言,那么在Linux系統(tǒng)中如何查看硬盤信息?以下是具體內(nèi)容介紹2025-03-12如何在 Linux 中查看 CPU 詳細(xì)信息? 3招輕松查看CPU型號(hào)、核心數(shù)和溫度
在日常運(yùn)維工作中,獲取 CPU 信息是系統(tǒng)運(yùn)維管理員常見的工作內(nèi)容,無(wú)論是為了性能調(diào)優(yōu)、硬件升級(jí)還是僅僅滿足好奇心2025-03-11什么是 Arch Linux? 獨(dú)樹一幟的Arch Linux發(fā)行版分析
Arch Linux是為簡(jiǎn)化,優(yōu)化,現(xiàn)代化,實(shí)用主義,用戶中心和多功能性而創(chuàng)建Linux發(fā)行版,究竟是什么讓 Arch 與眾不同?下面我們就來(lái)簡(jiǎn)要解讀2025-02-19如何在Linux環(huán)境下制作 Win11裝機(jī)U盤?
一直用的linux辦公,想要將筆記本電腦從 Linux 系統(tǒng)切換回 Windows 11,我們可以制作一個(gè)win11裝機(jī)u盤,詳細(xì)如下2025-02-17Rsnapshot怎么用? 基于Rsync的強(qiáng)大Linux備份工具使用指南
Rsnapshot 不僅可以備份本地文件,還能通過(guò) SSH 備份遠(yuǎn)程文件,接下來(lái)詳細(xì)介紹如何安裝、配置和使用 Rsnapshot,包括創(chuàng)建每小時(shí)、每天、每周和每月的本地備份,以及如何進(jìn)2025-02-06Linux Kernel 6.13發(fā)布:附更新內(nèi)容及新特性解讀
Linux 內(nèi)核 6.13 正式發(fā)布,新版本引入了惰性搶占支持,簡(jiǎn)化內(nèi)核搶占邏輯,通過(guò)減少與調(diào)度器相關(guān)的調(diào)用次數(shù),讓內(nèi)核在運(yùn)行時(shí)表現(xiàn)更優(yōu),從而提高效率2025-01-23五大特性引領(lǐng)創(chuàng)新! 深度操作系統(tǒng) deepin 25 Preview預(yù)覽版發(fā)布
今日,深度操作系統(tǒng)正式推出deepin 25 Preview版本,該版本集成了五大核心特性:磐石系統(tǒng)、全新DDE、Treeland窗口合成器、AI For OS以及Distrobox子系統(tǒng)2025-01-18Linux Mint Xia 22.1重磅發(fā)布: 重要更新一覽
Beta 版 Linux Mint“Xia” 22.1 發(fā)布,新版本基于 Ubuntu 24.04,內(nèi)核版本為 Linux 6.8,這次更新帶來(lái)了諸多優(yōu)化和改進(jìn),進(jìn)一步鞏固了 Mint 在 Linux 桌面操作系統(tǒng)領(lǐng)域的2025-01-16LinuxMint怎么安裝? Linux Mint22下載安裝圖文教程
Linux Mint22發(fā)布以后,有很多新功能,很多朋友想要下載并安裝,該怎么操作呢?下面我們就來(lái)看看詳細(xì)安裝指南2025-01-16