Pacemaker是OpenStack官方推薦的資源管理工具,群集基礎架構利用Coresync提供的信息和成員管理功能來檢測和恢復云端資源級別的故障,達到集群高可用性。Corosync在云端環境中提供集群通訊,主要負責為控制節點提供傳遞心跳信息的作用。
1)在三個節點上安裝以下安裝包
```
yum install -y lvm2 cifs-utils quota psmisc
yum install -y pcs pacemaker corosync fence-agents-all resource-agents crmsh
```
2)在三個節點上設置pcs服務開機啟動
```
systemctl enable pcsd.service
systemctl start pcsd.service
```
3)在三個節點上設置hacluster用戶密碼
```
passwd hacluster
New password ####設置密碼為yjscloud
Retry new password
```
4)配置編寫`corosync.conf`文件
```
vim /etc/corosync/corosync.conf
```
添加以下內容:
```
totem {
version: 2
secauth: off
cluster_name: openstack_cluster
transport: udpu
}
nodelist {
node {
ring0_addr: controller1
nodeid: 1
}
node {
ring0_addr: controller2
nodeid: 2
}
node {
ring0_addr: controller3
nodeid: 3
}
}
quorum {
provider: corosync_votequorum
}
logging {
to_logfile: yes
logfile: /var/log/cluster/corosync.log
to_syslog: yes
}
```
5)在三個節點上設置開機啟動服務
```
systemctl enable corosync
systemctl restart corosync
```
6)設置集群互相驗證,在controlle1上操作即可
```
pcs cluster auth controller1 controller2 controller3 -u hacluster -p yjscloud --force
```

7)創建并啟動名為openstack_cluster的集群,在controlle1上操作即可
```
pcs cluster setup --force --name openstack-cluster controller1 controller2 controller3
```

8)設置集群開啟啟動并查看狀態,在controlle1上操作即可
```
pcs cluster enable --all
pcs cluster start --all
pcs cluster status
```

9)查看并設置集群屬性,在controlle1上操作即可
```
ps aux |grep pacemaker
```
10)驗證corosync的安裝及當前corosync的狀態
```
corosync-cfgtool -s
corosync-cmapctl | grep members
pcs status corosync
```

11)驗證配置是否正確
```
controller1# crm_verify -L -V
controller1# pcs property set stonith-enabled=false
controller1# pcs property set no-quorum-policy=ignore
```
12)通過crm設置VIP
```
crm(live)configure# primitive vip_piblic ocf:heartbeat:IPaddr2 params ip="192.168.0.168" cidr_netmask="24" nic=eth0 op monitor interval="30s"
crm(live)configure# primitive vip_management ocf:heartbeat:IPaddr2 params ip="10.1.1.168" cidr_netmask="24" nic=ens8 op monitor interval="30s"
```

- 獻給我的朋友們
- 一、個人對學習的看法
- 二、運維技能圖譜
- 三、運維常用技能
- 3.1 Vim(最好用的編輯器)
- 3.2 Nginx & Tengine(Web服務)
- 1. Nginx介紹和部署
- 2. Nginx配置解析
- 3. Nginx常用模塊
- 4. Nginx 的session 一致性問題
- 3.3 Tomcat(Web中間件)
- 3.4 Keepalived(負載均衡高可用)
- 3.5 Memcache(分布式緩存)
- 3.6 Zookeeper(分布式協調系統)
- 3.7 KVM(開源虛擬化)
- 1. 虛擬化介紹
- 2. KVM基礎
- 3. 設置VNC和時間同步
- 4. kvm虛擬機快照備份
- 5. kvm虛擬機在線擴展磁盤
- 6. kvm虛擬機靜態遷移
- 7. kvm虛擬機動態遷移
- 8. kvm虛擬機存儲池配置
- 9. cpu添加虛擬化功能
- 3.8 GitLab(版本控制)
- 3.8.1 GitLab安裝與漢化
- 3.9 Jenkins(運維自動化)
- 3.10 WAF(Web防火墻)
- 3.10.1初探WAF
- 四、常用數據庫
- 4.1 MySQL(關系型數據庫)
- 1. MySQL源碼安裝
- 4.2 Mongodb(適用與大數據分析的數據庫)
- 4.3 Redis(非關系數據庫)
- 五、自動化運維工具
- 5.1 Cobbler(系統自動化部署)
- 5.2 Ansible(自動化部署)
- 5.3 Puppet(自動化部署)
- 5.4 SaltStack(自動化運維)
- 六、存儲
- 6.1 GFS(文件型存儲)
- 6.2 Ceph(后端存儲)
- 七、運維監控工具
- 7.1 對監控的理解
- 7.2 Zabbix(運維監控)
- 7.2.1 Zabbix簡介
- 7.2.2 Zabbix服務部署
- 1. Zabbix服務端部署
- 2. Zabbix客服端部署
- 3. 配置前端展示
- 4. zabbix告警配置
- 7.2.3 Zabbix監控服務
- 1. 監控網絡設備
- 2. 自定義Nginx監控
- 7.3 云鏡(安全監控)
- 7.4 ELK(日志收集展示)
- 八、運維云平臺
- 8.1 OpenStack(開源云操作系統)
- 8.1.1 OpenStack簡介
- 8.1.2 實驗架構設計
- 8.1.3 集群環境準備
- 8.1.4 controller節點部署
- 1. 安裝Mariadb Galera Cluster集群
- 2. 安裝RabbitMQ Cluster集群
- 3. 安裝Pacemaker
- 4. 安裝HAProxy
- 5. 安裝配置Keystone
- 6. 安裝配置glance
- 1. 制作鏡像模板
- 7. 安裝配置nova
- 8. 安裝配置neutron
- 1. 配置虛擬機網絡
- 9. 安裝Dashboard
- 10. 安裝配置cinder
- 8.1.5 compute節點部署
- 1. 安裝相關軟件包
- 2. 安裝Neutron
- 3. 配置cinder
- 4. 創建第一個虛擬機
- 8.1.6 OpenStack報錯處理
- 1. cinder僵尸卷刪除
- 8.1.7 快速孵化虛擬機方案
- 8.1.8 Kolla容器化部署OpenStack
- 1. 單點部署
- 2. 多節點部署
- 8.2 Tstack(騰訊云平臺)
- 8.3 K8s(微服務容器化)
- 九、運維編程技能
- 9.1 Shell(運維必會語言)
- 9.2 Python(萬能的膠水語言)
- 十、Devops運維
- 10.1 理念
- 10.2 Devops實戰