ImageVerifierCode 换一换
格式:DOCX , 页数:11 ,大小:381.59KB ,
资源ID:5127240      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/5127240.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(Linux高可用HA集群之Corosync详解.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

Linux高可用HA集群之Corosync详解.docx

1、Linux高可用HA集群之Corosync详解Linux 高可用(HA)集群之Corosync詳解大綱一、Corosync概述二、Corysync與Pacemaker安裝三、Corosync詳細配置四、Corosync啟動信息一、Corosync概述 1.簡單概述 要說明corosync的由來,首先我們得從AIS說起,然後說明OpenAIS,最後才會說到corosync。2.AIS概述 應用介面規範(AIS)是用來定義應用程式介面(API)的開放性規範的集合,這些應用程式作為中間件為應用服務提供一種開放、高移植性的程式介面。是在實現高可用應用過程中是亟需的。服務可用性論壇(SA Forum)是

2、一個開放性論壇,它開發並發布這些免費規範。使用AIS規範的應用程式介面(API),可以減少應用程式的複雜性和縮短應用程式的開發時間,這些規範的主要目的就是為了提高中間組件可攜性和應用程式的高可用性。SAF AIS是一個開放性工程,在不斷更新中。3.OpenAIS概述 OpenAIS是基於SA Forum標準的集群框架的應用程式介面規範。OpenAIS提供一種集群模式,這個模式包括集群框架,集群成員管理,通信方式,集群監測等,能夠為集群軟件或工具提供滿足AIS標準的集群介面,但是它沒有集群資源管理功能,不能獨立形成一個集群。OpenAIS組件包括AMF,CLM,CKPT,EVT,LCK,MSG,

3、TMR,CPG,EVS等,因OpenAIS分支不同,組件略有不同。(下面介紹)OpenAIS主要包含三個分支:Picacho,Whitetank,Wilson。Wilson是最新的,比較穩定的版本是從openais 1.0.0到openais1.1.4。Whitetank現在是主流分支版本,比較穩定的版本是openais0.80到openais0.86。Picacho第一代的OpenAIS的分支,比較穩定的版本是openais0.70和openais0.71。現在比較常用的是Whitetank和Wilson,兩者之間有很多不同。OpenAIS從Whitetank升級到Wilson版本後,組件變

4、化很大,Wilson把Openais核心架構組件獨立出來放在Corosync(Corosync是一個集群管理引擎)裡面。Whitetank包含的組件有AMF,CLM,CKPT,EVT,LCK ,MSG, CPG,CFG,EVS, aisparser, VSF_ykd,bojdb等。而Wilson只含有AMF,CLM,CKPT,LCK, MSG,EVT,TMR(TMR,Whitetank裡面沒有),這些都是AIS組件。其他核心組件被放到了Corosync內。Wilson被當做Corosync的一個外掛程式。(詳細請查看官方文檔)4.Corosync概述 Corosync是OpenAIS發展到Wi

5、lson版本後衍生出來的開放性集群引擎工程。可以說Corosync是OpenAIS工程的一部分。OpenAIS從openais0.90開始獨立成兩部分,一個是Corosync;另一個是AIS標準介面Wilson。Corosync包含OpenAIS的核心框架用來對Wilson的標準介面的使用、管理。它為商用的或開源性的集群提供集群執行框架。Corosync執行高可用應用程式的通信組系統,它有以下特徵:一個封閉的程式組(A closed process group communication model)通信模式,這個模式提供一種虛擬的同步方式來保證能夠複製服務器的狀態。一個簡單可用性管理組件(A

6、 simple availability manager),這個管理組件可以重新啟動應用程式的進程當它失敗後。一個配置和內存數據的統計(A configuration and statistics in-memory database),內存數據能夠被設置,回復,接受通知的更改資訊。一個定額的系統(A quorum system?),定額完成或者丟失時通知應用程式。5.AIS、OpenAIS,Corosync的關係(1).AIS與Whitetank的關係由圖3,可以看出,OpenAIS的分支版本Whitetank除了包含AIS標準的應用程式介面,同時也有自己獨立的管理模塊,這些獨立的模塊為圖3

7、中淺黃色部分,包含CPG,CFG,EVS, aisparser, VSF_ykd,bojdb等控制模塊。(2).AIS與Wilson的關係當OpenAIS到了Wilson以後,OpenAIS一分為二,Wilson的組件基本都是AIS組件。其他控制的核心組件被添加到Corosync中,關係如圖4所示。(3).Corosync與OpenAIS關係圖5所示,Wilson與Whitetank的主要區別在於Wilson相比Whitetank缺少核心架構。Wilson 作為Corosync的外掛程式支持SA Forum 。 6.OpenAIS集群實例(1).CMAN CMAN是紅帽RHCS套件的核心部分,

8、CCS是CMAN集群配置系統,配置cluster.conf,而cluster.conf其實就是openais的設定檔,通過CCS映射到openais。(2).Pacemaker1.x+corosync1.x Pacemaker升級到1.0版本後,從Heartbeat獨立出來,Pacemaker achieves maximum availability for your cluster services by detecting and recovering from node and service-level failures.It achieves this by utilizing t

9、he messaging and membership capabilities provided by your preferred cluster infrastructure (currently either Corosync or Heartbeat)7.總結 簡單的說,AIS就是一個通用的應用程式編程介面,OpenAIS是AIS的子項目,標準的集群框架的應用程式介面規範,而corosync是OpenAIS是具體實現。這樣說大家應該很好理解吧!8.corosync版本官方網站:http:/corosync.github.io/corosync/,目前官方同在維護兩個版本分別為,cor

10、osync 1.x corosync 1.4.6(最新)代號:flatironcorosync 2.x corosync 2.3.1(最新) 代號:needle9.corosync與pacemaker組合 從上圖中我們可以看到,不管heartbeat,還是corosync都是高可用集群中的Cluster Messaging Layer(集群資訊層),是主要傳遞發集群資訊與心跳資訊的,並沒有資源管理功能,資源管理還得依賴於上層的crm(Cluster resource Manager,集群資源管理器),最著名的資源管理器,就是pacemaker,它是heartbeat v3分離出去的子項目。而現

11、在corosync+pacemaker成了高可用集群中的最佳組合。好了,到這裡corosync與pacemaker的基礎知識就說到這裡了,下面我們來看看怎麼安裝corosync與pacemaker。二、Corysync與Pacemaker 安裝1.環境說明(1).作業系統CentOS6.4 X86_64位元系統(2).軟體環境corosync-1.4.1-15.el6_4.1.x86_64pacemaker-1.1.8-7.el6.x86_64(3).拓撲環境2.前提條件node1:(1).各節點之間主機名稱互相解析rootnode1 # uname -nrootnode1 # vim /et

12、c/hosts127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4:1 localhost localhost.localdomain localhost6 localhost6.localdomain6 192.168.18.201 node1 192.168.18.202 node2rootnode1 # ping node1rootnode1 # ping node2(2).各節點之間時間同步 1 rootnode1 # ntpdate 210.72.145.44(3).各節點之間ssh互

13、信rootnode1 # ssh-keygen -t rsa -f /.ssh/id_rsa -P rootnode1 # ssh-copy-id -i .ssh/id_rsa.pub rootnode2:(1).各節點之間主機名稱互相解析rootnode2 # uname -nrootnode2 # vim /etc/hosts127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4:1 localhost localhost.localdomain localhost6 localhost6.l

14、ocaldomain6 192.168.18.201 node1 192.168.18.202 node2rootnode2# ping node1rootnode2 # ping node2(2).各節點之間時間同步 rootnode2 # ntpdate 210.72.145.44(3).各節點之間ssh互信rootnode2 # ssh-keygen -t rsa -f /.ssh/id_rsa -P rootnode2 # ssh-copy-id -i .ssh/id_rsa.pub root3.配置yum源(EPEL源)node1:rootnode1 src# wget http:/

15、download.Fedoraproject.org/pub/epel/5/x86_64/epel-release-5-4.noarch.rpmrootnode1 src# rpm -ivh epel-release-5-4.noarch.rpmwarning: epel-release-5-4.noarch.rpm: Header V3 DSA signature: NOKEY, key ID 217521f6Preparing. # 100%1:epel-release # 100%rootnode1 src# rpm -import /etc/pki/rpm-gpg/RPM-GPG-KE

16、Y-CentOS-5rootnode1 src# yum listnode2:rootnode2 src# wget http:/download.fedoraproject.org/pub/epel/5/x86_64/epel-release-5-4.noarch.rpmrootnode2 src# rpm -ivh epel-release-5-4.noarch.rpmwarning: epel-release-5-4.noarch.rpm: Header V3 DSA signature: NOKEY, key ID 217521f6Preparing. # 100%1:epel-rel

17、ease # 100%rootnode2 src# rpm -import /etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-5rootnode2 src# yum list4.關閉防火牆與SELinuxnode1:rootnode1 # service iptables stoprootnode1 # vim /etc/selinux/config# This file controls the state of SELinux on the system.# SELINUX= can take one of these three values:# enforcing

18、 - SELinux security policy is enforced.# permissive - SELinux prints warnings instead of enforcing.# disabled - SELinux is fully disabled.SELINUX=disabled# SELINUXTYPE= type of policy in use.Possible values are:# targeted - Only targeted network daemons are protected.# strict - Full SELinux protecti

19、on.SELINUXTYPE=targetednode2:rootnode2 # service iptables stoprootnode2 # vim /etc/selinux/config# This file controls the state of SELinux on the system.# SELINUX= can take one of these three values:# enforcing - SELinux security policy is enforced.# permissive - SELinux prints warnings instead of e

20、nforcing.# disabled - SELinux is fully disabled.SELINUX=disabled# SELINUXTYPE= type of policy in use.Possible values are:# targeted - Only targeted network daemons are protected.# strict - Full SELinux protection.SELINUXTYPE=targeted5.安裝corosync與pacemakernode1:12 rootnode1 # yum install -y corosync*

21、rootnode1 # yum install -y pacemaker*node2:rootnode2 # yum install -y corosync*rootnode2 # yum install -y pacemaker*三、Corosync 詳細配置1.提供設定檔rootnode1 # cd /etc/corosync/rootnode1 corosync# ll 總用量 24 -rw-r-r- 1 root root 445 5月 15 05:09 corosync.conf.example -rw-r-r- 1 root root 1084 5月 15 05:09 corosy

22、nc.conf.example.udpu drwxr-xr-x 2 root root 4096 5月 15 05:09 service.d drwxr-xr-x 2 root root 4096 5月 15 05:09 uidgid.d注:大家可以看到提供一個樣例檔corosync.conf.examplerootnode1 corosync# cp corosync.conf.example corosync.conf2.修改設定檔rootnode1 corosync# cat corosync.conf# Please read the corosync.conf.5 manual pa

23、ge compatibility: whitetanktotem version: 2 secauth: on #啟動認證 threads: 2 interface ringnumber: 0 bindnetaddr: 192.168.18.0 #修改心跳線網段 mcastaddr: 226.99.10.1 #組播傳播心跳資訊 mcastport: 5405 ttl: 1 logging fileline: off to_stderr: no to_logfile: yes to_syslog: no logfile: /var/log/cluster/corosync.log #日誌位置 d

24、ebug: off timestamp: on logger_subsys subsys: AMF debug: off amf mode: disabled #啟用pacemakerservice ver: 0 name: pacemaker aisexec user: root group: root 注:用 man corosync.conf 可以查看所有選項的意思。3.生成金鑰檔注:corosync生成key檔會預設調用/dev/random亂數設備,一旦系統中斷的IRQS的亂數不夠用,將會產生大量的等待時間,因此,為了節約時間,我們在生成key之前講random替換成urandom,

25、以便節約時間。rootnode1 corosync# mv /dev/random,random.bak rootnode1 corosync# ln -s /dev/urandom /dev/randomrootnode1 corosync# corosync-keygen Corosync Cluster Engine Authentication key generator. Gathering 1024 bits for key from /dev/random. Press keys on your keyboard to generate entropy. Writing coro

26、sync key to /etc/corosync/authkey.4.查看生成的key文件rootnode1 corosync# ll總用量 24 -r- 1 root root 128 8月 13 14:16 authkey -rw-r-r- 1 root root 521 8月 13 11:11 corosync.conf -rw-r-r- 1 root root 445 5月 15 05:09 corosync.conf.example -rw-r-r- 1 root root 1084 5月 15 05:09 corosync.conf.example.udpu drwxr-xr-x

27、 2 root root 4096 5月 15 05:09 service.d drwxr-xr-x 2 root root 4096 5月 15 05:09 uidgid.d5.將key文件authkey與設定檔corosync.conf複製到node2上rootnode1 corosync# scp -p authkey corosync.conf node2:/etc/corosync/authkey 100% 128 0.1KB/s 00:00 corosync.conf 100% 521 0.5KB/s 00:00rootnode2 # cd /etc/corosync/rootnode2 corosync# ll 總用量 24 -r- 1 root root 128 8月 13 14:16 authkey -rw-r-r- 1 root root 521 8月 13 11:11 corosync.conf -rw-r-r- 1 root root 445 5月 15 05:09 corosync.conf.example -rw-r-r- 1 root root 1084 5月 15 05:09 corosyn

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1