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
```
![8-1-13](http://pded8ke3e.bkt.clouddn.com/8-1-13.jpg)
7)创建并启动名为openstack_cluster的集群,在controlle1上操作即可
```
pcs cluster setup --force --name openstack-cluster controller1 controller2 controller3
```
![8-1-14](http://pded8ke3e.bkt.clouddn.com/8-1-14.png)
8)设置集群开启启动并查看状态,在controlle1上操作即可
```
pcs cluster enable --all
pcs cluster start --all
pcs cluster status
```
![8-1-15](http://pded8ke3e.bkt.clouddn.com/8-1-15.jpg)
9)查看并设置集群属性,在controlle1上操作即可
```
ps aux |grep pacemaker
```
10)验证corosync的安装及当前corosync的状态
```
corosync-cfgtool -s
corosync-cmapctl | grep members
pcs status corosync
```
![8-1-16](http://pded8ke3e.bkt.clouddn.com/8-1-16.jpg)
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"
```
![8-1-17](http://pded8ke3e.bkt.clouddn.com/8-1-17.jpg)
- 献给我的朋友们
- 一、个人对学习的看法
- 二、运维技能图谱
- 三、运维常用技能
- 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实战