HA即高可用(high avaliable),又被叫做双机热备,用于关键性业务,简单理解就是,有两台机器A和B,正常是A提供服务,B待机闲置,当A宕机或服务宕掉,会切换到B机器继续提供服务。常用实现高可用的开源软件有heartbeat和keepalived,其中keepalived有负载均衡的功能。
图:

下面我们使用heartbeat来做HA集群,并且把nginx服务器作为HA对应的服务。

实验准备:
两台机器,都是centos6.5,网卡eth0,ip如下:
aming 192.168.31.166
aming1 192.168.31.100
两个eth1 ip如下:
aming 192.168.21.166
aming1 192.168.21.100

要弄两个网卡,在本实验中使用了同一张网卡配置不同IP,可以参考上一篇文章

下面操作1-5都是在两个机器上操作的

1.hostname设置好,分别为aming aming1
2.关闭防火墙iptables -F
关闭selinux setenforce 0
3.vi /etc/hosts //内容如下
192.168.31.166 aming
192.168.31.100 aming1

4.安装epel拓展源
yum install -y epel-release

5.两个机器上都安装heartbeat/libnet
yum install -y heartbeat* libnet nginx

6.主上(aming)配置
cd /usr/share/doc/heartbeat-3.0.4/
cp authkeys ha.cf haresorces /etc/ha.d/
cd /etc/ha.d
vi authkeys //加入
auth 3
3 md5 Hello!

chmod 600 authkeys

vi haresorces
用来指定主节点,虚拟IP,网段,网卡名字,掌控的服务
如果针对nginx 做HA
那就加入:
aming 192.168.31.110(对外提供服务的IP)/24/eth0:0 nginx(必须要把服务放到/etc/init.d/)

vi ha.cf
//改为如下内容
打开debugfile 
logfile
keepalive 表示多长时间检测一次
auto_failback on
warntime 警告时间
initdead 秒死掉了就真的死掉了
uddport 广播
baud 串口(如果要用到串口才打开)
ubast 广播形式
ucast 用IP找
ucast eth1 192.138.21.100 (这个要)
respawn hacluster /usr/lib32/heartbeat/ipfail
ping 192.168.21.1
node aming主节点
node aming1从节点

7.然后就拷贝上面三个文件给从
然后从,

8.从上编辑ha.cf
ucast eth1 改成对方的IP

9.启动heartbeat:
先主后从
service heartbeat start

10.检查测试
ifconfig 看看是否有eth1:0
ps aux|grep nginx 看看有没有进程

11.测试1
主上故意禁止ping
iptables -I INPUT -p icmp -j DROP

12.测试2
主上停止heartbeat服务
service heartbeat stop

13.测试脑裂
主从上都down掉eth1网卡
ifdown eth1

拓展学习:
关于heartbeat配置文件参考文档:http://blog/chinaunix.net/uid-20749043-id-1878328.html
heartbeat和keepalived的比较:
http://blog.csdn.net/yunhua_lee/article/details/9788433
http://zhengdl126.iteye.com/blog/1738012
DRBD工作原理和配置:http://502245466.51cto.com/7559397/1298945

用Heartbeat实现HA集群的更多相关文章

  1. corosync+pacemaker实现高可用(HA)集群

    corosync+pacemaker实现高可用(HA)集群(一)     重要概念 在准备部署HA集群前,需要对其涉及的大量的概念有一个初步的了解,这样在实际部署配置时,才不至于不知所云 资源.服务与 ...

  2. 架构之高可用性(HA)集群(Keepalived)

    Keepalived简介 Keepalived是Linux下一个轻量级别的高可用解决方案.高可用(High Avalilability,HA),其实两种不同的含义:广义来讲,是指整个系统的高可用行,狭 ...

  3. 安装spark ha集群

    安装spark ha集群 1.默认安装好hadoop+zookeeper 2.安装scala 1.解压安装包 tar zxvf scala-2.11.7.tgz 2.配置环境变量 vim /etc/p ...

  4. Hadoop的HA集群启动和停止流程

    假设我们有3台虚拟机,主机名分别是hadoop01.hadoop02和hadoop03. 这3台虚拟机的Hadoop的HA集群部署计划如下: 3台虚拟机的Hadoop的HA集群部署计划 hadoop0 ...

  5. 使用QJM部署HDFS HA集群

    一.所需软件 1. JDK版本 下载地址:http://www.oracle.com/technetwork/java/javase/index.html 版本: jdk-7u79-linux-x64 ...

  6. Storm-1.0.1+ZooKeeper-3.4.8+Netty-4.1.3 HA集群安装

    Storm-1.0.1+ZooKeeper-3.4.8+Netty-4.1.3 HA集群安装 下载Storm-1.0.1 http://mirrors.tuna.tsinghua.edu.cn/apa ...

  7. 菜鸟玩云计算之十九:Hadoop 2.5.0 HA 集群安装第2章

    菜鸟玩云计算之十九:Hadoop 2.5.0 HA 集群安装第2章 cheungmine, 2014-10-26 在上一章中,我们准备好了计算机和软件.本章开始部署hadoop 高可用集群. 2 部署 ...

  8. 菜鸟玩云计算之十八:Hadoop 2.5.0 HA 集群安装第1章

    菜鸟玩云计算之十八:Hadoop 2.5.0 HA 集群安装第1章 cheungmine, 2014-10-25 0 引言 在生产环境上安装Hadoop高可用集群一直是一个需要极度耐心和体力的细致工作 ...

  9. 手动部署 kubernetes HA 集群

    前言 关于kubernetes HA集群部署的方式有很多种(这里的HA指的是master apiserver的高可用),比如通过keepalived vip漂移的方式.haproxy/nginx负载均 ...

随机推荐

  1. Class.forName()用法

    主要功能 Class.forName(xxx.xx.xx)返回的是一个类. Class.forName(xxx.xx.xx)的作用是要求JVM查找并加载指定的类,也就是说JVM会执行该类的静态代码段. ...

  2. windows 全角 怎么切换到半角

    windows 全角 怎么切换到半角 :shift+空格键

  3. 分布式计算 要不要把写日志独立成一个Server Remote Procedure Call Protocol

    w https://en.wikipedia.org/wiki/Remote_procedure_call In distributed computing a remote procedure ca ...

  4. ubuntu-16.04.2-server-amd64.iso

    w

  5. view简写 TemplateView.as_view()

    view简写 TemplateView.as_view() https://code.ziqiangxuetang.com/django/django-generic-views.html (1)如果 ...

  6. LeetCode:课程表【207】

    LeetCode:课程表[207] 题目描述 现在你总共有 n 门课需要选,记为 0 到 n-1. 在选修某些课程之前需要一些先修课程. 例如,想要学习课程 0 ,你需要先完成课程 1 ,我们用一个匹 ...

  7. 微信小程序学习笔记(4)--------框架之逻辑层

    逻辑层 逻辑层(App Service):小程序框架的逻辑层是由JavaScript编写的,逻辑层将数据进行处理后发送给视图层,同时接受视图层的事件反馈. App进行程序注册,Page进行页面注册 g ...

  8. sql创建表、改变表、关联查询语句

  9. kmp模板 && 扩展kmp模板

    kmp模板: #include <bits/stdc++.h> #define PB push_back #define MP make_pair using namespace std; ...

  10. 设计模式(四) 手动实现AOP代理

    1.事务的使用: 每次对数据库操作我们都需要开启事务,事务开启后,我们就需要对数据库进行一次或者多次操作,当操作完成后就需要提交事务.比如一个业务中多次操作数据库,但是当某个方法出错的时候,我们需要整 ...