heartbeat v1版CRM的高可用web集群的实现

简介:

实验环境规划:


实验环境:

CentOS release 6.6(Final)  三台

IP地址:

Node1: eth0172.16.31.10/16

Node2:  eth0172.16.31.11/16

Client: eth0172.16.31.12/16



wKioL1SnoFuwzogyAAD7WnoeO7w392.jpg

集群架构图 :

wKiom1Snn9GhnoO0AAGpQF3Pnns029.jpg



 

一.heartbeat特性介绍:

1.实现底层心跳传递

2.启动关闭集群服务

3.工作节点多达16个节点,由一个主节点和其他备节点组成

对称和非对称节点

4.启动时心跳信息由主节点发送

基于UDP的单播(Unicast),UDP的广播(Broadcast),UDP的多播(Multicast),串行线路通信的传播(serial cable)

 

 

二.配置HA集群的前提:

1、节点之间时间必须同步;

建议使用ntp协议进行;

2、节点之间必须要通过主机名互相通信;

建议使用hosts文件;

通信中使用的名字必须与其节点为上“uname -n”命令展示出的名字保持一致;

3、如果是2个节点,需要仲裁设备;

4、节点之间彼此root用户能基于ssh密钥方式进行通信;

                  

注意:定义为集群服务中的任意资源都不能开机自动启动,因为它们将由CRM启动;

                  

三.资源准备:

1、选定vip;

2、httpd:

安装好程序;

配置好httpd,本地测试完成;

关闭服务,并确保开机不会自动启动;

3、shared storage:NFS

 

四.节点系统HA的前提条件配置

1.时间同步

参考我的博客:http://sohudrgon.blog.51cto.com/3088108/1598314

 

2.主机名同步

[root@node1 ~]# cat /etc/hosts

127.0.0.1  localhost localhost.localdomain localhost4 localhost4.localdomain4

::1        localhost localhost.localdomain localhost6 localhost6.localdomain6

172.16.0.1 server.magelinux.com server

172.16.31.10 node1.stu31.com node1

172.16.31.11 node2.stu31.com node2

 

3.仲裁设备为网关172.16.0.1

 

4.ssh无密钥通信

node1

[root@node1 ~]# ssh-keygen -t rsa -P""

[root@node1 ~]# ssh-copy-id -i.ssh/id_rsa.pub root@node2

测试将node1的hosts文件复制到node2:

[root@node1 ~]# scp /etc/hosts root@172.16.31.11:/etc/hosts

hosts                                        100%  268     0.3KB/s  00:00

 

node2

[root@node2 ~]# ssh-keygen -t rsa -P""

[root@node2 ~]# ssh-copy-id -i .ssh/id_rsa.pub  root@node1

 

测试无密钥通信结果:

[root@node1 ~]# date ;ssh node2 'date'

Thu Jan 1 20:44:09 CST 2015

Thu Jan 1 20:44:09 CST 2015

保证时间一致!

 

五.安装heartbeat程序

1.安装heartbeat程序包组

获取程序包组:

[root@node1 heartbeat2]# ls

heartbeat-2.1.4-12.el6.x86_64.rpm

heartbeat-gui-2.1.4-12.el6.x86_64.rpm

heartbeat-ldirectord-2.1.4-12.el6.x86_64.rpm

heartbeat-pils-2.1.4-12.el6.x86_64.rpm

heartbeat-stonith-2.1.4-12.el6.x86_64.rpm

 

安装程序包组:

node1和node2都需要安装;

前提条件需要安装如下依赖包:

[root@node1 heartbeat2]# yum install -y net-snmp-libs libnet PyXML


安装heartbeat套件程序:

[root@node1 heartbeat2]# rpm -ivh heartbeat-2.1.4-12.el6.x86_64.rpm heartbeat-stonith-2.1.4-12.el6.x86_64.rpm heartbeat-pils-2.1.4-12.el6.x86_64.rpm heartbeat-gui-2.1.4-12.el6.x86_64.rpm

Preparing...               ########################################### [100%]

  1:heartbeat-pils        ########################################### [ 25%]

  2:heartbeat-stonith     ########################################### [ 50%]

  3:heartbeat             ########################################### [ 75%]

  4:heartbeat-gui         ########################################### [100%]

 

2.复制配置文件到/etc/ha.d目录下:

[root@node1 heartbeat2]# cd /usr/share/doc/heartbeat-2.1.4/

[root@node1 heartbeat-2.1.4]# cp ha.cf authkeys haresources /etc/ha.d/

 

3.配置rsyslog记录heartbeat的日志

[root@node1 ~]# vim /etc/rsyslog.conf

local0.*                                               /var/log/heartbeat.log

拷贝一份到node2:

[root@node1 ~]# scp /etc/rsyslog.conf root@node2:/etc/rsyslog.conf

rsyslog.conf                                  100%3203     3.1KB/s  00:00

 

4.配置ha.cf主配置文件:

[root@node1 ~]# cat /etc/ha.d/ha.cf |grep-v ^#

#日志记录

logfacility     local0

#组播配置

mcast eth0 225.131.31.23 694 1 0

auto_failback on

#集群节点

node   node1.stu31.com

node   node2.stu31.com

#仲裁设备

ping 172.16.0.1

#是否开启heartbeat v2 版本的CRM,我们使用v1版本的CRM来测试,注释掉。

#crm on

 

5.定义域共享密钥,认证文件权限必须是600或者400

[root@node1 ~]# openssl rand -hex 6

72907725aaf0

[root@node1 ~]# vim /etc/ha.d/authkeys

auth   2

2      sha1    72907725aaf0

 

6.配置集群资源

[root@node1 ~]# vim /etc/ha.d/haresources

node1.stu31.com  172.16.31.180/24/eth0/172.16.31.255 httpd

 

将三个配置文件复制一份拷贝到node2:

[root@node1 ha.d]# scp -p authkeys ha.cf haresources node2:/etc/ha.d/

authkeys                                      100%  684    0.7KB/s   00:00   

ha.cf                                         100%   10KB 10.4KB/s   00:00   

haresources                                   100%5964     5.8KB/s   00:00

 

7.确定httpd服务正常

[root@node2 ~]# echo"node2.stu31.com" > /var/www/html/index.html

[root@node1 ~]# echo"node1.stu31.com" > /var/www/html/index.html


启动httpd服务进行测试

[root@node1 ha.d]# service httpd start

Starting httpd:                                           [  OK  ]

[root@node2 ~]# service httpd start

Starting httpd:                                           [  OK  ]

 

访问测试:

[root@node1 ha.d]# curl http://172.16.31.10

node1.stu31.com

[root@node1 ha.d]# curl http://172.16.31.11

node2.stu31.com

 

完成后将服务自启动关闭,及停止httpd服务:

node1:

[root@node1 ha.d]# service httpd stop

Stopping httpd:                                           [  OK  ]

[root@node1 ha.d]# chkconfig httpd off

node2:

[root@node2 ~]# service httpd stop

Stopping httpd:                                           [  OK  ]

[root@node2 ~]# chkconfig httpd off

 

 

六.启动heartbeat集群

1.启动heartbeat服务:

[root@node1 ha.d]# service heartbeat start; ssh node2 'service heartbeat start'

logd is already running

Starting High-Availability services:

2015/01/01_21:10:33 INFO:  Resource is stopped

Done.

  

logd is already running

Starting High-Availability services:

2015/01/01_21:10:33 INFO:  Resource is stopped

Done.

 

2.访问测试:

[root@nfs ~]# curl http://172.16.31.180

node1.stu31.com

 

我们关闭node1,在进行测试:

[root@node1 ha.d]# service heartbeat stop

Stopping High-Availability services:

Done.


ip地址切换到了node2:

[root@node2 ~]# ip addr show

1: lo: <LOOPBACK,UP,LOWER_UP> mtu65536 qdisc noqueue state UNKNOWN

   link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00

   inet 127.0.0.1/8 scope host lo

   inet6 ::1/128 scope host

      valid_lft forever preferred_lft forever

2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP>mtu 1500 qdisc pfifo_fast state UP qlen 1000

   link/ether 08:00:27:58:d3:3e brd ff:ff:ff:ff:ff:ff

   inet 172.16.31.11/16 brd 172.16.255.255 scope global eth0

   inet 172.16.31.180/24 brd 172.16.31.255 scope global eth0:0

   inet6 fe80::a00:27ff:fe58:d33e/64 scope link

      valid_lft forever preferred_lft forever

 

访问测试:

[root@nfs ~]# curl http://172.16.31.180

node2.stu31.com

 

测试成功!



本文转自 dengaosky 51CTO博客,原文链接:http://blog.51cto.com/dengaosky/1964550,如需转载请自行联系原作者
相关文章
|
5月前
|
Java 应用服务中间件 Shell
Nginx+Keepalived+Tomcat 实现Web高可用集群
Nginx+Keepalived+Tomcat 实现Web高可用集群
165 0
|
5月前
|
负载均衡 算法 应用服务中间件
负载均衡技术在Web服务器集群中的应用
【8月更文第28天】随着互联网的发展和用户对Web服务需求的增长,单台服务器很难满足大规模访问的需求。为了提高系统的稳定性和扩展性,通常会采用Web服务器集群的方式。在这种架构中,负载均衡器扮演着至关重要的角色,它能够合理地分配客户端请求到不同的后端服务器上,从而实现资源的最优利用。
178 2
|
存储 分布式计算 资源调度
Hadoop运行模式(三)、群起集群、配置workers、启动集群、启动HDFS、拼接、Web端查看HDFS的NameNode、Web端查看YARN的ResourceManager
Hadoop运行模式(三)、群起集群、配置workers、启动集群、启动HDFS、拼接、Web端查看HDFS的NameNode、Web端查看YARN的ResourceManager
Hadoop运行模式(三)、群起集群、配置workers、启动集群、启动HDFS、拼接、Web端查看HDFS的NameNode、Web端查看YARN的ResourceManager
|
运维 关系型数据库 MySQL
【运维知识进阶篇】集群架构-Nginx实现基础web架构(Linux+Nginx+PHP+Mysql)(二)
【运维知识进阶篇】集群架构-Nginx实现基础web架构(Linux+Nginx+PHP+Mysql)(二)
253 0
|
负载均衡 监控 算法
百度搜索:蓝易云【HAProxy搭建web集群教程。】
这是一个简单的HAProxy搭建Web集群的教程。在实际应用中,还可以进行更多的配置和优化,以满足你的需求。建议在搭建之前查阅官方文档或参考其他详细的教程以获取更全面的指导。
121 3
百度搜索:蓝易云【HAProxy搭建web集群教程。】
|
弹性计算 Kubernetes 索引
使用Kubectl部署web服务到K8s集群
本场景带您体验如何使用k8s的原生命令kubectl部署一个web应用(魔方应用)的镜像到k8s集群中,并通过Ingress将部署的服务暴露出来由外部访问。
|
弹性计算 Kubernetes 容器
使用Kubectl部署web服务到K8s集群
本次基于阿里云实验室提供的实验环境,使用预创建好的创建云服务器ECS和ACK集群资源,实现通过Kubectl部署web服务到K8s集群。
|
运维 关系型数据库 MySQL
【运维知识进阶篇】集群架构-Nginx实现基础web架构(Linux+Nginx+PHP+Mysql)(一)
【运维知识进阶篇】集群架构-Nginx实现基础web架构(Linux+Nginx+PHP+Mysql)
234 0
|
负载均衡 网络协议 Linux
web集群第二次作业
LVS(Linux Virtual Server)是一种高性能、可扩展的负载均衡软件,它可以将客户端请求分发到多个后端服务器上,从而实现负载均衡。LVS支持多种工作模式,其中最常用的是NAT模式和DR模式。这两种模式各有优缺点,下面我将详细介绍他们的特点及适用场景。
92 0
|
Unix 应用服务中间件 Linux
ansible在web集群中批量部署nfs
ansible在web集群中批量部署nfs
202 0