在互联网高速发展的今天,尤其在电子商务的发展,要求服务器能够提供不间断服务。在电子商务中,如果服务器宕机,造成的损失是不可估量的。要保证服务器不间断服务,就需要对服务器实现冗余。在众多的实现服务器冗余的解决方案中,Pacemaker为我们提供了廉价的、可伸缩的高可用解决方案。

  双机热备测试环境如下:

主节点:10.0.0.20

副节点:10.0.0.21

虚拟IP:10.0.0.100

一、关闭selinux和防火墙-两台机均执行

  1、  关闭selinux

$ sudo sed -i “s/SELINUX=enforcing/SELINUX=disabled/g” /etc/selinux/config
$ sudo reboot

  2、  闭防火墙

$ sudo systemctl stop firewalld
$ sudo systemctl disable firewalld

二、两台机安装Pacamaker

  1、  利用yum安装Pacemaker

$ sudo yum install -y fence-agents-all corosync pacemaker pcs

  2、  修改两台机的hostname

#主节点改为node1
$ sudo hostnamectl set-hostname node1 #副节点
$ sudo hostnamectl set-hostname node2

  3、  修改两台机的hosts

$ sudo vim /etc/hosts

  10.0.0.20 node1
10.0.0.21 node2

三、node1与node2实现无密钥访问

#在两台机均运行以下命令

$ sudo -i

# ssh-keygen
# ssh-copy-id -p 22 root@10.0.0.20
# ssh-copy-id -p 22 root@10.0.0.21

四、配置两台机的集群用户hacluster,此帐户在安装Pacemaker时已经自动创建。

#设置hacluster用户的密码

$ sudo passwd hacluster

五、配置集群节点之间的认证

  1、  启动并设置开机启动pcsd服务,两台机上均执行以下命令

$ sudo systemctl start pcsd

$ sudo systemctl enable pcsd

  2、  配置节点间的认证,以下命令只在node1节点上执行

#以下操作需要输入用户名hacluster和密码

$ sudo pcs cluster auth node1 node2

  到此为止,节点认证配置完成!

六、Pacemaker可以为多种服务提供支持,例如Apache、MySQL、Xen等,可使用的类型有IP地址、文件系统、服务、fence设备等。以下以Apache为例。

  1、  两台机均安装httpd

$ sudo yum install -y httpd

  2、  设置httpd.conf-两台主机均配置

$ sudo vim /etc/httpd/conf/httpd.conf

  Listen 0.0.0.0:80
ServerName www.node1.com      //另外一台为www.node2.coom #设置服务器状态页面以便集群检测
<Location /server-status>
SetHandler server-status
Require all granted
</Location>

  3、Pacemaker可以控制httpd服务的启动和关闭,所以node1和node2配置完httpd后需关闭httpd服务。

$ sudo systemctl stop httpd

七、 新建并启动集群,以下操作均在node1上执行

  1、  新建一个名为mycluster的集群

$ sudo pcs cluster setup --name mycluster node1 node2

  2、  启动集群

$ sudo pcs cluster start --all

  3、  设置自启动集群

$ sudo pcs cluster enable –all

# 查看集群状态
$ sudo pcs status

通过以上在node1的设置后,所有的设置都会同步在node2上。

八、为集群添加资源

#添加一个名为VIP的IP地址资源
#使用heartbeat作为心跳检测
#集群每隔30s检查该资源一次 $ sudo pcs resource create VIP ocf:heartbeat:IPaddr2 ip=10.0.0.100 cidr_netmask=24 op monitor interval=30s $ sudo pcs resource create Web ocf:heartbeat:apache configfile=/etc/httpd/conf/httpd.conf statusurl="http://127.0.0.1/server-status" op monitor interval=30s $ sudo pcs status

九、调整资源,让VIP和Web两个资源“捆绑”在一起。

# 方式一:将VIP和Web添加到myweb组中
$ sudo pcs resource group add myweb VIP
$ sudo pcs resource group add myweb Web # 方式二:使用托管约束
$ sudo pcs constraint colocation add Web VIP INFINITY # 设置先启动VIP,再启动Web
$ sudo pcs constraint order start VIP then start Web

十、优先级:如果node1与node2的硬件配置不同,那么应该调整节点的优先级,让资源运行于硬件配置更好的服务器上,待其失效后再转移至较低配置的服务器上。这就需要配置优先级(Pacemaker中称为Location)。

  1、调整Location

# 数值越大表示优先级越高
$ sudo pcs constraint location Web prefers node1=10
$ sudo pcs constraint location Web prefers node2=5

  

  2、查看设置结果

$ sudo crm_simulate -sL

  

  3、验证VIP是否启用-需显示IP10.0.0.100

$ ip addr show

  4、验证httpd是否启动 

$ ps -aux|grep httpd

  5、报错:WARNING: no stonith devices and stonith-enabled is not false,请执行以下命令:

$ sudo pcs property set stonith-enabled=false

十一、  启动后正常情况下VIP设置在主节点10.0.0.20上。如主节点故障,则节点node2自动接管服务,方法是直接重启节点node1,然后观察备用节点是否接管了主机的资源,测试过程如下:

  1、  在节点node1上执行重启操作

#执行重启
$ sudo reboot

  2、node1重启前截图

  3、node1重启后状态如下图

  4、当节点node1故障时,节点node2收不到心跳请求,超过设置的时间节点后node2启用资源接管程序,上述命令输出中说明VIP和Web已经被节点node2成功接管。如果节点node1恢复且设置了优先级,VIP和Web又会重新被节点node1接管。下图为node1重启后的截图:

Pacemaker实现双机热备的更多相关文章

  1. postgresql双机热备、高可用方案(采用pacemaker+corosync实现)

    http://blog.csdn.net/qguanri/article/details/51151974 需求描述 我们有两台centos7的数据库主机A.B.要对A.B实现双机热备,A作为数据库m ...

  2. 采用pacemaker+corosync实现postgresql双机热备、高可用方案

    环境说明 参照上章已完成postgresql流复制配置,并关闭postgres服务. su - postgres pg_ctl -D /data/postgresql/data/ stop -m fa ...

  3. 【Nginx】如何基于主从模式搭建Nginx+Keepalived双机热备环境?这是最全的一篇了!!

    写在前面 最近出版了<海量数据处理与大数据技术实战>,详情可以关注 冰河技术 微信公众号,查看<我的<海量数据处理与大数据技术实战>出版啦!>一文. 也有不少小伙伴 ...

  4. CentOS系统MySQL双机热备配置

    1  概述 在集成项目中需要应对不同环境下的安装配置,主流操作系统大致可以分为三种:Linux.Windows以及UNIX.其中Linux备受青睐的主要原因有两个: 首先,Linux作为自由软件有两个 ...

  5. MySQL 5.6 双机热备windows7

    MySQL 5.6 双机热备 目录: 1.说明 2.数据手工同步 3.修改主数据库配置文件 4.修改从数据库配置文件 5.主数据库添加备份用户 6.从数据库设置为Slave 7.验证 1.说明 1)数 ...

  6. Keepalived双机热备

    一,Keepalived双机热备的应用场景 1,网站流量不高,压力不大,但是对服务器的可靠性要求极其高,例如实时在线OA系统,政府部门网站系统,医院实时报医系统,公安局在线报案系统,股市后台网站系统等 ...

  7. SqlServer双机热备技术实践笔记

    SqlServer双机热备,大体上可以通过发布订阅,日志传送,数据库镜像来实现. 1,发布--订阅 是最早最简单的方案,但需要注意发布的时候,发布进程必须对快照目录有访问权限,这个问题可以从“查看快照 ...

  8. windows下使用mysql双机热备功能

    一. 准备工作 1. 准备两台服务器(电脑),接入局域网中,使互相ping得通对方 2. 两台服务器都安装mysql-server-5.1,必须保证mysql的版本一致 3. 假设,服务器A:192. ...

  9. Nginx+keepalived双机热备(主主模式)

    之前已经介绍了Nginx+Keepalived双机热备的主从模式,今天在此基础上说下主主模式的配置. 由之前的配置信息可知:master机器(master-node):103.110.98.14/19 ...

随机推荐

  1. Android 进阶12:进程通信之 Socket (顺便回顾 TCP UDP)

    不要害怕困难,这是你进步的机会! 读完本文你将了解: OSI 七层网络模型 TCPIP 四层模型 TCP 协议 TCP 的三次握手 TCP 的四次挥手 UDP 协议 Socket 简介 Socket ...

  2. makefile 学习归纳

    makefile 学习归纳 一直希望 好好整理下 makefile的写法,这在linux编程界是必备技能.下面就好好的说道说道. 可以参考的大神总结 整理 makefile是供make命令执行的 脚本 ...

  3. 【MFC】对话框自带滚动条的使用

    对话框自带滚动条的使用 摘自 http://wenku.baidu.com/link?url=aZe1zgBSBsf9xCYNpcz2fNGljmKxg372OVIGeJ7p6iRCWbbsertS7 ...

  4. c#模拟键盘输入

    System.Windows.Forms.SendKeys.SendWait("j");

  5. 在Spring中通过构造自动装配--constructor

    在Spring中,可以使用“通过构造自动装配”,实际上是按构造函数的参数类型自动装配. 这意味着,如果一个bean的数据类型与其他bean的构造器参数的数据类型是相同的,那么将自动装配. packag ...

  6. ncdu 查找linux下最占空间的文件(交互式查询)

    安装 wget -c https://dev.yorhel.nl/download/ncdu-1.11.tar.gz tar xzvf ncdu-1.11.tar.gz cd ncdu-1.11 ./ ...

  7. 【ecmall】解决无法上传店铺logo和banner照片问题 (转)

    问题描述:在ecmall个人用户登录,点击用户中心-店铺设置-更换店标,上传一个jpg图像(图像符合规范)后,不能预览,而且在页面底部点击提交后没有上传成功.banner店铺条幅也是一样的情况,还有下 ...

  8. Android中的基类—抽取出来公共的方法

    在Android中,一般来说一个应用会存在几十个页面,并且一个应用一般也会使用一个特定的主题,其中的页面的风格也是一致的,并且页面中的动画效果.页面的切换效果等也应该保持同样的风格,那么就需要一个基类 ...

  9. The method of type must override a superclass method解决方式(转)

    今天做struts2上传文件的时候出现了这个问题: The method execute() of type UploadAction must override or implement a sup ...

  10. eclipse解决git冲突举例

    本地修改了两个文件,提交时提示有冲突,想来应该是没有从远程仓库下载最新代码导致的.通过右击项目 -> Team -> Sychronized WorkSpace,比较本地仓库和远程仓库的异 ...