1. 首先准备两台tomcat机器,作为集群的单点server。

第一台:

1)tomcat,需要Java的支持,所以同样要安装Java环境。

安装非常简单。

tar xf  jdk-7u65-linux-x64.tar.gz

mv jdk1.7.0_65 /usr/local/java

然后在环境变量中加入Java的运行路径

vim  /etc/profile

JAVA_HOME=/usr/local/java

export PATH=$PATH:$JAVA_HOME/bin

修改后,source /etc/profile, 使变量生效

我们可以测试一下  java-version

出现Java版本信息,信息会随着系统的版本不同,以下为centos 7

openjdk version "1.8.0_131" OpenJDK Runtime Environment (build 1.8.0_131-b12) OpenJDK 64-Bit Server VM (build 25.131-b12, mixed mode)

2)安装Tomcat

tar xfv  apache-tomcat-7.0.54.tar.gz

mv  apache-tomcat-7.0.54  /usr/local/tomcat

找到tomcat的启动文件 /usr/local/tomcat/bin/startup.sh

关闭文件 /usr/local/tomcat/bin/shutdown.sh

启动后可用 netstat -anpt|grep 8080是否为Java占用,正常。

tcp6       0      0 :::8080                 :::*                    LISTEN      1990/java

同时我也可以查看日志情况,tail  -f  /var/log/tomcat7/catalina.out     catalina.out  为日志文件

3)我们要搭建一个测试环境

cd /usr/local/tomcat7/conf找到server.xml 文件,修改前做备份,cp  server.xml  server.xml.bak

主要Host 同时对context项,进行修改,把 docBase改为要测试的页面的目录,可为相对目录,也可为绝对目录。

本例中我们用一个jsp编写的一个项目做实验,修改为SLSaleSystem,保存退出

将项目解压至tomcat的网页存放目录webapps 下。tar  xvf  SLSaleSystem.tar.gz  /usr/local/tomcat7/webapps/

重启服务

/usr/local/tomcat7/bin/shutdown.sh

/usr/local/tomcat7/bin/startup.sh

打开浏览器,输入tomcat的ip,测试一下,出现登录界面,tomcat搭建完成

第二台tomcat,配置同第一台一样

2.安装两台haproxy+keepalived服务器

1)安装haproxy

yum -y install haproxy

修改前做备份

cp  /etc/haproxy/haproxy.cfg /etc/haproxy/haproxy.cfg.bak

vim /etc/haproxy/haproxy.cfg

在最后添加

listen  web_tomcat 0.0.0.0:80                                  定义一个服务器组,监听所有端口的80
        #option httpchk GET /index.html
        balance roundrobin
        server  web_tomcat_1 172.16.1.2:80 check inter 2000 rise 2 fall 3 weight 1               加两台服务器
        server  web_tomcat_2 172.16.1.12:80 check inter 2000 rise 2 fall 3 weight 1

为了便于日志管理,将日志独立定义到haproxy.conf ,并放到/etc/rsyslog.d  下

先在    /etc/haproxy/haproxy.conf中加

log /dev/log local0 info
    log /dev/log local0 notice      定义这两类信息,要记录到日志文件中

再创建/etc/rsyslog.d/haproxy.conf 文件

if ($programname == 'haproxy' and $syslogseverity-text =='info') then                           意思为如果程序名为haproxy并且日志验证文本为 info和notice分别记录到haproxy-info.log和haproxy-notice.log文件
  -/var/log/haproxy/haproxy-info.log
&~
if ($programname == 'haproxy' and $syslogseverity-text =='notice') then
        -/var/log/haproxy/haproxy-notice.log
&~

重启日志服务/etc/init.d/rsyslog restart

创建这两个文件

touch haproxy-info.log

touch haproxy-notice.logfo.log

打开浏览器http://haproxy主机ip,能显示

2).安装keepalived

我们选择用yum -y install keepalived

添加为开机启动 chkconfig  keepalived on

修改配置文件

cd /etc/keepalived/

cp keepalived.conf   keepalived.conf.bak

vim keepalived.conf

vrrp_instance VI_1 {

#备用服务器上为 BACKUP

state BACKUP

#绑定vip的网卡为ens33

interface ens33

virtual_router_id 51

#备用服务器上为90

priority 90

advert_int 1

authentication {

auth_type PASS

  auth_pass 1111

}

}

virtual_ipaddress {

172.16.1.200

}

}

3)第二台配置同第一台,不同的是keepalived.conf 文件中从priority 为90

3,高可用测试

模拟停止 nginx1服务,用ip a 查看网卡信息,发现VIP已转移到nginx2上。

service nginx stop

ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000     link/ether 00:0c:29:a7:c0:25 brd ff:ff:ff:ff:ff:ff     inet 192.168.1.2/24 brd 192.168.1.255 scope global ens33        valid_lft forever preferred_lft forever     inet 172.16.1.200/32 scope global ens33        valid_lft forever preferred_lft forever     inet6 fe80::20c:29ff:fea7:c025/64 scope link        valid_lft forever preferred_lft forever

同时打开浏览器,查看,服务正常。

haproxy + keepalived 实现高可用负载均衡集群的更多相关文章

  1. 基于Haproxy+Keepalived构建高可用负载均衡集群

    实验环境: 主机名 IP地址 VIP 192.168.200.254 Haproxy-1 192.168.200.101 Haproxy-2 192.168.200.102 Nginx1 192.16 ...

  2. Haproxy+Keepalived构建高可用负载均衡集群

    实验环境: 主机名 IP地址 VIP 192.168.200.254 Haproxy-1 192.168.200.101 Haproxy-2 192.168.200.102 Nginx1 192.16 ...

  3. Linux 笔记 - 第十八章 Linux 集群之(三)Keepalived+LVS 高可用负载均衡集群

    一.前言 前两节分别介绍了 Linux 的高可用集群和负载均衡集群,也可以将这两者相结合,即 Keepalived+LVS 组成的高可用负载均衡集群,Keepalived 加入到 LVS 中的原因有以 ...

  4. LVS+Keepalived 实现高可用负载均衡集群

    LVS+Keepalived  实现高可用负载均衡集群     随着网站业务量的增长,网站的服务器压力越来越大?需要负载均衡方案!商业的硬件如 F5 ,Array又太贵,你们又是创业型互联公司如何有效 ...

  5. Keepalived+LVS高可用负载均衡集群

    概述 Keepalived是专门针对LVS设计的一款强大的辅助工具,主要用来提供故障切换(Failover)和健康检查(HeathChecking)功能——判断LVS负载调度器.节点服务器的可用性,及 ...

  6. Nginx+Keepalived搭建高可用负载均衡集群

    本文的重点是Keepalived的配置,Nginx的配置就简略带过.软件:CentOS 7.2 / Nginx 1.12.2 / Keepalived 1.3.9 ha-01:192.168.1.97 ...

  7. Haproxy+Keepalived搭建Weblogic高可用负载均衡集群

    配置环境说明: KVM虚拟机配置 用途 数量 IP地址 机器名 虚拟IP地址 硬件 内存3G  系统盘20G cpu 4核 Haproxy keepalived 2台 192.168.1.10 192 ...

  8. Dubbo入门到精通学习笔记(二十):MyCat在MySQL主从复制的基础上实现读写分离、MyCat 集群部署(HAProxy + MyCat)、MyCat 高可用负载均衡集群Keepalived

    文章目录 MyCat在MySQL主从复制的基础上实现读写分离 一.环境 二.依赖课程 三.MyCat 介绍 ( MyCat 官网:http://mycat.org.cn/ ) 四.MyCat 的安装 ...

  9. haproxy+keepalived实现高可用负载均衡

    软件负载均衡一般通过两种方式来实现:基于操作系统的软负载实现和基于第三方应用的软负载实现.LVS就是基于Linux操作系统实现的一种软负载,HAProxy就是开源的并且基于第三应用实现的软负载. HA ...

随机推荐

  1. docker nginx 反向代理

    上一篇介绍了docker 安装和docker-compose配置 使用docker pull nginx:1.12.0 编写docker-compose.yml nginx: image: 17dae ...

  2. aws查看官方centos镜像imageid

    aws ec2 describe-images --owners aws-marketplace --filters Name=product-code,Values=aw0evgkw8e5c1q41 ...

  3. JavaMelody监控spring、struts

    前言 前面讲过了Javamelody的基本配置,如何使用Javamelody来监控JDBC以及SQL. 这里继续讲解一下如何监控struts和spring. 手码不易,转载请注明:xingoo 由于s ...

  4. Oracle数据库克隆后temp文件因路径变化无法找到问题

    Oracle数据库克隆后temp文件因路径变化无法找到出现如下报错Errors in filexxxx.trc:ORA-01157: cannot identify/lock data file xx ...

  5. June 07th 2017 Week 23rd Wednesday

    Failure is the condiment that gives success its flavor. 失败是让成功变美味的调味料. There are kinds of flavors in ...

  6. 初识Git与Github

    学习和使用Git和Github的确是一件很有意义的事,通过使用Git和Github,可以让我们很方便地管理自己的各种文件,还可以帮助一名程序员更好地用于代码管理.而对于一名软件技术人员,建立自己的Gi ...

  7. OC typedef(起别名)

    // #define Integer int // 给基本数据类型起别名 void test() { typedef int Integer; typedef Integer MyInteger; t ...

  8. 【[AHOI2012]树屋阶梯】

    卡特兰数! 至于为什么是卡特兰数,就稍微说那么一两句吧 对于一个高度为\(i\)的阶梯,我们可以在左上角填一个高度为\(k\)的阶梯,右下角填一个高度为\(i-1-k\)的阶梯剩下的我们用一个大的长方 ...

  9. Educational Codeforces Round 53 (Rated for Div. 2) C. Vasya and Robot 【二分 + 尺取】

    任意门:http://codeforces.com/contest/1073/problem/C C. Vasya and Robot time limit per test 1 second mem ...

  10. c#正则表达式最简demo

    各个语言的正则表达式规则略有不同 项目中用到,所以将这个最简单的demo记录 using System; using System.Collections.Generic; using System. ...