使用Nginx+Keepalived组建高可用负载平衡Web server集群

转载 2016年08月30日 00:29:27

转自:http://blog.csdn.net/luxiaoyu_sdc/article/details/7333024
一,首先说明一下网络拓扑结构:


1,Nginx 反向代理Server(HA):
①Nginx master:192.168.1.157
②Nginx backup:192.168.1.158
虚拟IP统一为:192.168.1.110  
2,web服务器:
192.168.1.160 ,192.168.1.161,192.168.1.162   即web服务器,已配置好 Tomcat(Jboss等皆可)和Java程序
3,MySQL 数据库Server
mysql主从服务器

二,Nginx安装配置
1,安装
建议先用yum install yum-fastestmirror更新下源

下载并安装nginx1.0.9,下载文件均放到/usr/local/src目录下
cd /usr/local/src

①update yum
yum -y update

②利用CentOS Linux系统自带的yum命令安装、升级所需的程序库

安装依赖包

yum install gcc pcre pcre-devel zlib zlib-devel openssl openssl-devel

下载nginx

cd /usr/local/src

wget http://www.nginx.org/download/nginx-1.0.9.tar.gz

tar zxvf nginx-1.0.9.tar.gz

cd nginx-1.0.9

配置安装:

./configure –prefix=/usr –sbin-path=/usr/sbin/nginx –conf-path=/etc/nginx/nginx.conf –error-log-path=/var/log/nginx/error.log –pid-path=/var/run/nginx/nginx.pid –lock-path=/var/lock/nginx.lock –user=nginx –group=nginx –with-http_ssl_module –with-http_flv_module –with-http_gzip_static_module –http-log-path=/var/log/nginx/access.log –http-client-body-temp-path=/var/tmp/nginx/client/ –http-proxy-temp-path=/var/tmp/nginx/proxy/ –http-fastcgi-temp-path=/var/tmp/nginx/fcgi/

make

make install

建立用户:
/usr/sbin/groupadd nginx
/usr/sbin/useradd -g nginx -M nginx
mkdir -p /var/tmp/nginx/client
启动nginx

/usr/sbin/nginx

ps:如果中途提示缺少库,直接yum install xxx即可。
即:conf-path=/etc/nginx/nginx.conf,用户名为nginx,所属的组为nginx

   2,配置

Nginx负载均衡设置:

①修改配置文件:
vi /etc/nginx/nginx.conf

步骤1,添加负载均衡的http upstream模块
upstream esbwebserver {
server 192.168.1.160:8888;
server 192.168.1.161:8888;
}

步骤2,server指令
server
{
listen 80;
server_name localhost;#注意此处为localhost

location / {
proxy_pass http://esbwebserver;# 添加的tomcat集群名称
……
}

②,重启Nginx,加载修改过的配置文件:
步骤1, 停止nginx引擎
killall -9 nginx

步骤2,启动nginx
/usr/sbin/nginx

到此为止,我们的负载均衡就实现了,下面实现Nginx的高可用,即双机热备。

三,Keepalived 安装配置
1,下载并安装keepalived-1.1.15.tar.gz,下载文件均放到/usr/local/src目录下
cd /usr/local/src
wget http://www.keepalived.org/software/keepalived-1.1.15.tar.gz

①解压缩
tar zxvf keepalived-1.1.15.tar.gz

②安装
cd keepalived-1.1.15
./configure –prefix=/usr/local/keepalived
make && make install

③安装成功后做成服务模式,方便启动和关闭
cp /usr/local/keepalived/sbin/keepalived /usr/sbin/
cp /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
cp /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/

④ 分别设置主和备Nginx上的 安装Keepalived配置文件。

配置文件位置:
/usr/local/keepalived/etc/keepalived/keepalived.conf

步骤一,先配置主Nginx server上的keepalived.conf文件,如下所示:

! Configuration File for keepalived

global_defs {
notification_email {
644856452@qq.com
}
notification_email_from 644856452@qq.com
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id LVS_DEVEL
}

vrrp_script check_run {
script “/root/bin/nginx_check.sh”
interval 5
}
vrrp_sync_group VG1 {
group {
VI_1
}
}

vrrp_instance VI_1 {
state MASTER
interface eth0
virtual_router_id 51
mcast_src_ip 192.168.1.157
priority 100
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}

track_script {
    check_run
}

virtual_ipaddress {
192.168.1.110
}
}

步骤二,配置backup 服务器的keepalived.conf文件,如下所示:
! Configuration File for keepalived

global_defs {
notification_email {
644856452@qq.com
}
notification_email_from Alexandre.Cassen@firewall.loc
smtp_server 127.0.0.1
smtp_connect_timeout 30
router_id LVS_DEVEL
}

vrrp_script check_run {
script “/root/bin/nginx_check.sh”
interval 5
}
vrrp_sync_group VG1 {
group {
VI_1
}
}

vrrp_instance VI_1 {
state BACKUP
interface eth0
virtual_router_id 51
priority 99
advert_int 1
authentication {
auth_type PASS
auth_pass 1111
}

track_script {
    check_run
}

virtual_ipaddress {
192.168.1.110
}
}

参考下例配置:
—————————————————–带注释的示例—————————————————-
在主服务器编写配置文件
vrrp_script check_run{
script “/opt/nginx_pid.sh”

监控脚本

            interval 2                             

监控时间

            weight 2                                ###如果检测返回值不为真weight 2 表示减2,权重值降低,backup server权重值>现Master的,切换

}

vrrp_instance VI_1 {
state MASTER ### 设置为 主
interface eth0 ### 监控网卡
virtual_router_id 51 ### 这个两台服务器必须一样
priority 101 ### 权重值 MASTRE 一定要高于 BAUCKUP
authentication {
auth_type PASS ### 加密
auth_pass 1111 ###加密的密码,两台服务器一定要一样,不然会出错
}

   track_script {
            check_run     ### 执行监控的服务
    }

    virtual_ipaddress {
         192.168.1.110                          ###    VIP 地址
    }

}

6.在backup server 服务器 keepalived 配置
vrrp_script check_run{
script “/opt/nginx_pid.sh”
interval 2
weight 2
}

vrrp_instance VI_1 {
state BACKUP ### 设置为 辅机
interface eth0
virtual_router_id 51 ### 与 MASTRE 设置 值一样
priority 100 ### 比 MASTRE权重值 低

    authentication {
                 auth_type PASS
                 auth_pass eric                    ### 密码 与 MASTRE 一样
    }

    track_script {
            check_run
    }

    virtual_ipaddress {
             192.168.1.110
    }

}
———————————————-over——————————————————————-

说明:
1,绑定虚拟IP:
ifconfig eth0:1 192.168.1.110 broadcast 192.168.1.255 netmask 255.255.255.0 up
route add -host 192.168.1.110 dev eth0:1

2, 启动,关闭keepalived :
service keepalived start
service keepalived stop

3,测试可用性:
①主Nginx停止Nginx或直接断网情况下(backup正常),访问虚拟IP:192.168.1.110的相关Web服务,正常,测试通过
②backup Nginx停止Nginx或直接断网情况下(Master正常),访问虚拟IP:192.168.1.110的相关Web服务,正常,测试通过

4,监控
可用安装Nagios监控服务,详细请网络搜寻,很多这种资料的。
也可以参考:
http://blog.csdn.net/luxiaoyu_sdc/article/details/7333416

nginx HA高可用

公司内部 代理服务器nginx 系统要做线上高可用,避免单点故障,所以计划使用2台nginx代理 通过 Keepalived 工具来实现 nginx 的高可用(High Avaiability),达到...
  • u010391029
  • u010391029
  • 2016年07月30日 11:41
  • 6303

主题:分布式架构高可用架构_Keepalived+Nginx实现高可用Web负载均衡

一、场景需求 二、Keepalived 简要介绍 Keepalived 是一种高性能的服务器高可用或热备解决方案,Keepalived 可以用来防止服务器单点故障的发生,通过配合 Ng...
  • u013870094
  • u013870094
  • 2016年11月26日 23:56
  • 2430

Nginx+Tomcat搭建高性能负载均衡集群

在Nginx反向代理转发tomcat这篇文章中,对nginx进行了简单的介绍,实现了nginx代理转发的功能,以及静态、动态资源分离的实现。本篇文章接着这篇文章继续写下去的,如果有不明白的地方,可以进...
  • mlc1218559742
  • mlc1218559742
  • 2016年11月11日 14:21
  • 3332

Nginx详解-服务器集群

Nginx是什么 代理服务器:一般是指局域网内部的机器通过代理服务器发送请求到互联网上的服务器,代理服务器一般作用在客户端。应用比如:GoAgent,翻墙神器.   一个完整的代理请求过程为:客户端首...
  • zouyujie1127
  • zouyujie1127
  • 2014年11月29日 23:09
  • 34569

【Nginx+Keepalived】组建高可用负载平衡Web server集群

版权声明:本文为博主原创文章,未经博主允许不得转载。 一,首先说明一下网络拓扑结构:   1,Nginx 反向代理Server(HA):      ①Nginx master:192.16...
  • baidu_39511645
  • baidu_39511645
  • 2017年10月23日 20:05
  • 96

keepalived + nginx组建高可用负载平衡Web server集群

1 nginx负载均衡高可用 1.1 什么是负载均衡高可用 nginx作为负载均衡器,所有请求都到了nginx,可见nginx处于非常重点的位置,如果nginx服务器宕机后端web服务将无法提供服...
  • l192168134
  • l192168134
  • 2016年07月01日 15:30
  • 5644

采用软件nginx实现web服务器集群

nginx:软件负载均衡器  是高并发量http/反向代理服务器。实现windows下IIS的负载均衡 条件:2台服务器 1、cpu:Inter(R) 酷睿 i5 cpu 2.26GHz 内存:...
  • rongaimeng
  • rongaimeng
  • 2013年03月31日 17:37
  • 4883

使用Nginx+Keepalived组建高可用负载平衡Web server集群

转自:http://blog.csdn.net/luxiaoyu_sdc/article/details/7333024 一,首先说明一下网络拓扑结构:   1,Nginx 反向代理S...
  • wingahi
  • wingahi
  • 2016年08月30日 00:29
  • 1550

使用Nginx+Keepalived组建高可用负载平衡Web server集群

版权声明:本文为博主原创文章,未经博主允许不得转载。 一,首先说明一下网络拓扑结构:   1,Nginx 反向代理Server(HA):      ①Nginx master...
  • oufua
  • oufua
  • 2015年12月12日 03:41
  • 262

keepalived + nginx组建高可用负载平衡Web server集群(转载)

原文地址:http://blog.csdn.net/l192168134/article/details/51801483 1 nginx负载均衡高可用 1.1 什么是负载均衡高可用 ...
  • maple980326
  • maple980326
  • 2016年07月07日 16:08
  • 265
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:使用Nginx+Keepalived组建高可用负载平衡Web server集群
举报原因:
原因补充:

(最多只允许输入30个字)