基于heartbeat的单播方式实现tomcat高可用
1、节点规划
在master、backup节点上添加eth0、eth1两网卡,具体添加过程,参考“基于VMware为CentOS 6.5配置两个网卡”
2、IP规划
|
master |
backup |
|
|
eth0 |
192.168.46.128 |
192.168.46.130 |
|
eth1 |
192.168.46.129 |
192.168.46.131 |
上面这个表格说明master节点中的eth0网卡的IP是192.168.46.128,eth1网卡的IP是192.168.46.129;backup节点中eth0网卡的IP是192.168.46.130,eth1网卡的IP是192.168.46.131
3、VIP规划(虚拟IP规划)
|
IP地址 |
子网掩码 |
说明 |
|
192.168.46.150 |
255.255.255.0 |
192.168.46.150/24 |
192.168.46.150/24就等同于IP是192.168.46.150,子网掩码是255.255.255.0
3、网卡规划
|
master |
backup |
|
|
eth0 |
数据网卡 |
数据网卡 |
|
eth1 |
心跳网卡 |
心跳网卡 |
4、软件规划
|
软件 |
版本 |
说明 |
|
heartbeat |
3.0.4 |
使用yum自动安装的 |
|
tomcat |
7.0.70 |
需要手动配置 |
5、目录规划
|
软件 |
目录 |
|
tomcat-7.0.70 |
/etc/server |
6、安装tomcat
下面以在master节点配置为例
1、创建/etc/server目录,并切换到该目录,如下

2、获得apache-tomcat-7.0.70.tar.gz连接(http://mirror.bit.edu.cn/apache/tomcat/tomcat-7/v7.0.70/bin/apache-tomcat-7.0.70.tar.gz)
3、使用wget下载,如下

4、解压apache-tomcat-7.0.70.tar.gz

5、将apache-tomcat-7.0.70.tar.gz删除,并重名为tomcat

6、在backup节点上也就行相同配置
7、测一下两个节点上的tomcat是否可以正常访问


7、安装heartbeat
在master节点上,输入“yum install heartbeat -y”,安装heartbeat

在执行上面这句时,可能报如下错误

解决方法
1、使用yum list heartbeat,查看源中是否存在heartbeat,如下

2、出现上面问题No matching Packages to list,可能是源中没有heartbeat,默认情况,系统自带了源,但自带源中是没有heartbeat,如下

3、可以添加epel,来解决问题,具体请参考“为centos6.5系统添加epel源”
在backup节点上也进行如上操作
8、配置heartbeat
1、heartbeat的配置文件是在/etc/ha.d目录下,默认情况下,haresources、authkeys、ha.cf文件在该目录下是没有的,需要从/usr/share/doc/ heartbeat-3.0.4/拷贝,下面以在master节点上操作为例,如下


在backup节点上也进行如上操作
2、配置ha.cf文件
master节点上的ha.cf文件内容,如下
debugfile /var/log/ha-debug
logfile /var/log/ha-log
# 指定心跳间隔时间为2秒
keepalive
# 指定若备节点在30秒内没有收到主节点的心跳信息号,则立即接管主节点的服务资源
deadtime
# 指定心跳延迟时间为10秒,10秒内备节点不能收到到主节点的心跳信号时,就会向日志中写入警告,
# 但此时不会接管服务,直到超过deadtime还是不能接到心跳再接管
warntime
# 初始化时间为120秒
initdead
udpport
# 采用网卡eth1来发送心跳,后面的ip地址应为对方的IP地址
ucast eth1 192.168.46.129
# 如果主节点重新恢复过来,主节点将资源抢占过来,如果为off,则只当备节点当掉后,主节点才取回资源
auto_failback on
# 主节点名称,必须和uname -n显示的一致
node master
# 备节点名词,必须和uname -n显示的一致
node backup
# 在备节点不能接收到主节点的心跳时,先ping一下ping服务器,将会判断自己网络是否有问题
ping 192.168.46.2
backup节点上的ha.cf文件与mater中的基本相同,区别如下
ucast eth1 192.168.46.131
其他配置和master中的是一样的,这里不再给出
3、配置authkeys
因为机器之间通信需要认证,所以需要配置认证文件authkeys,可选认证有crc、sha1、md5,这里我们选择crc,不加密认证
auth
crc
master与backup节点中authkeys配置是相同,如上
注意这里需要修改authkeys的权限为600,如下

4、配置haresources
master IPaddr::192.168.46.150//eth0 tomcat
master与backup节点中的haresources文件内容如上所示,它们内容是相同的
参数解释:
master是主机名,启动时会在这个主机上绑定vip
IPaddr是heartbeat自带的一个脚本,其后的ip等是脚本的参数
192.168.46.150/24/eth0这句话的意思是:初始化时,在master主机的eth0网卡上绑定虚拟IP(192.168.46.150),子网掩码为255.255.255.0
tomcat是一个脚本,这个脚本可以通过传start/stop参数可以启停tomcat,如果有多个服务要托管给heartbeat,只需使用空格隔开,在后面添加就行;如果要托管的服务需要走不同的虚拟IP就得单起一行去配置了
5、编写tomcat启停脚本
该脚本必须位于/etc/inid.d或/etc/ha.d/resource.d目录下,且脚本名字为tomcat,这里我们放到/etc/ha.d/resource.d目录下,下面以在master节点操作为例,如下
case $ in
start)
/etc/server/tomcat/bin/startup.sh
;;
stop)
/etc/server/tomcat/bin/shutdown.sh
;;
*)
echo "param (start|stop)"
exit
;;
esac
exit
为tomcat脚本增加可执行权限,如下

9、启动heartbeat
分别在master、backup节点上输入“/etc/init.d/heartbeat start”,启动heartbeat


10、执行效果如下

如果,您认为阅读这篇博客让您有些收获,不妨点击一下右下角的【推荐】。
如果,您希望更容易地发现我的新博客,不妨点击一下左下角的【关注我】。
如果,您对我的博客所讲述的内容有兴趣,请继续关注我的后续博客,我是【刘超★ljc】。
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
基于heartbeat的单播方式实现tomcat高可用的更多相关文章
- [转]搭建Keepalived+Nginx+Tomcat高可用负载均衡架构
[原文]https://www.toutiao.com/i6591714650205716996/ 一.概述 初期的互联网企业由于业务量较小,所以一般单机部署,实现单点访问即可满足业务的需求,这也是最 ...
- Keepalived + Nginx + Tomcat 高可用负载均衡架构
环境: 1.centos7.3 2.虚拟ip:192.168.217.200 3.192.168.217.11.192.168.217.12上分别部署Nginx Keepalived Tomcat并进 ...
- LVS+keeplived+nginx+tomcat高可用、高性能jsp集群
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 .作者信息和本声明.否则将追究法律责任.http://kerry.blog.51cto.com/172631/557749 #!/bin ...
- lvs + keepalived + nginx + tomcat高可用负载反向代理服务器配置(一) 简介
一. 为什么这样构架 1. 系统高可用性 2. 系统可扩展性 3. 负载均衡能力 LVS+keepalived能很好的实现以上的要求,keepalived提供健康检查,故障转移,提高系统的可用性!采用 ...
- LVS+Keepalived+Nginx+Tomcat高可用负载均衡集群配置(DR模式,一个VIP,多个端口)
一.概述 LVS作用:实现负载均衡 Keepalived作用:监控集群系统中各个服务节点的状态,HA cluster. 配置LVS有两种方式: 1. 通过ipvsadm命令行方式配置 2. 通过Red ...
- 基于无域故障转移群集 配置高可用SQLServer 2016数据库
基于上次的文章搭建的环境,可以在这里:http://www.cnblogs.com/DragonStart/p/8275182.html看到上次的文章. 演示环境 1. 配置一览 Key Value ...
- Apache tomcat高可用web集群搭建过程配置记录
说明,本文仅作为个人搭建配置保存,问题处理没有一一列出,过程也未见详尽,有问题的朋友可以直接留言给我,会一一回复,谢谢. 小目标: 支持故障转移(或主备,扩展性不佳),保证故障转移后,对前端用户透明, ...
- Nginx+Keepalived+Tomcat高可用负载均衡,Zookeeper集群配置,Mysql(MariaDB)搭建,Redis安装,FTP配置
JDK 安装步骤 下载 http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151.html rpm ...
- 基于Galera Cluster多主结构的Mysql高可用集群
Galera Cluster特点 1.多主架构:真正的多点读写的集群,在任何时候读写数据,都是最新的 2.同步复制:集群不同节点之间数据同步,没有延迟,在数据库挂掉之后,数据不会丢失 3.并发复制:从 ...
随机推荐
- NOIP 2011 提高组 计算系数
有二项式定理 `\left( a+b\right) ^{n}=\sum _{r=0}^{n}\left( \begin{matrix} n\\ r\end{matrix} \right) a^{n-r ...
- Windows Xp Home Edition 安装IIS组件
问题描述: 在虚拟机(操作系统是Windows Xp Home Edition)中安装Sql Server 2005的时候警告缺少IIS相关组件,控制面板"添加/删除组件"中也没有 ...
- QEvent整理归纳:140种类型,29个继承类,7个函数,3种事件来源
140种事件类型: QEvent::None QEvent::AccessibilityDescription QEvent::AccessibilityHelp QEvent::Accessibil ...
- 《鸟哥的Linux私房菜》读书笔记四
1.Linux的目录配置以『树状目录』来配置,至於磁碟分割槽(partition)则需要与树状目录相配合! 请问,在预设的情况下,在安装的时候系统会要求你一定要分割出来的两个Partition为何? ...
- FishEye简介
前言 在项目开发过程中,随着开发的进行,将有大量的代码编写提交到代码仓库,如何能全面准确的了解源代码的变化,提交的频率,代码量的趋势,发现代码的缺陷,将是控制源代码质量的重要指标,这个时候一个 ...
- perl unload utf-8 oracle Wide character in print at unload_oracle.pl line 105.
#!/usr/bin/perl use DBI; use Encode; my $dbName = 'oadb'; my $dbUser = 'vxspace'; my $dbUserPass = ' ...
- jdk jre jvm 关系
很多朋友可能跟我一样,已经使用JAVA开发很久了,可是对JDK,JRE,JVM这三者的联系与区别,一直都是模模糊糊的. 今天特写此文,来整理下三者的关系. JDK : Java Development ...
- mysql 限制并发select patch
限制并发select的patch,代码量很少,主要是为了学习mysql的源码,yy一下. 增加两个全局控制变量: thread_limit_min thread_limit_max 增加一个条件变量: ...
- HDU 4749 Parade Show 2013 ACM/ICPC Asia Regional Nanjing Online
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4749 题目大意:给一个原序列N,再给出一个序列M,问从N中一共可以找出多少个长度为m的序列,序列中的数 ...
- poj 3608 Bridge Across Islands
题目:计算两个不相交凸多边形间的最小距离. 分析:计算几何.凸包.旋转卡壳.分别求出凸包,利用旋转卡壳求出对踵点对,枚举距离即可. 注意:1.利用向量法判断旋转,而不是计算角度:避免精度问题和TLE. ...