双主模型的Nginx高可用负载均衡集群

双主模型的Nginx高可用负载均衡集群

实验目的:使用keepalived实现Nginx的双主高可用负载均衡集群

实验环境:两台Nginx proxy(双主Nginx,各需要两块网卡,eth0连接内网,eth1连接外网)、两台web server(请求的负载均衡)、一台client用于验证结果。

注意:为了不影响实验结果,在实验开始前先关闭iptables和selinux

操作步骤:

一、配置IP

1.配置A主机的IP

# ip addr add dev eth0 192.168.10.2/24

2.配置B主机的IP

# ip addr add dev eth0 192.168.10.23/24

3.配置C主机的IP

# ip addr add dev eth0 192.168.10.3/24

4.配置D主机的IP

# ip addr add dev eth0 192.168.10.33/24

二、配置web服务(CD主机都做同样配置,只需修改默认主页中的IP地址为本机的IP即可,以示区别)

1.安装apache

# yum -y install apache

2.创建默认主页

# vim /var/www/html/index.html

<h1>192.168.10.3</h1>

3.启动apache

# service httpd start

三、配置sorry_server(此服务配置于Nginx proxy主机上,两台Nginx proxy都做同样配置,只需修改默认主页中的IP地址为本机的IP即可,以示区别)

1.安装apache

# yum -y install apache

2.创建默认主页

# vim /var/www/html/index.html

<h1>sorry_server:192.168.10.2</h1>

3.修改监听端口为8080,以免与nginx所监听的端口冲突

# vim /etc/httpd/conf/httpd.conf

Listen 8080

4.启动apache服务

四、配置代理(两台Nginx proxy都做同样配置)

1.安装nginx

# yum -y install nginx

2.定义upstream集群组,在http{}段中定义;

# vim /etc/nginx/nginx.conf

        http {

            upstream websrvs {

                server 192.168.10.3:80;

                server 192.168.10.33:80;

                server 127.0.0.1:8080 backup;

            }

        }

3.调用定义的集群组,在server{}段的location{}段中调用;

# vim /etc/nginx/conf.d/default.conf

        server {

            location / {

                proxy_pass http://wersrvs;

                index index.html;

            }

        }

4.启动服务

# service nginx start

五、配置keepalived

A主机上操作

1.安装keepalived

# yum -y install keepalived

2.编辑A主机的配置文件/etc/keepalived/keepalived.conf,作如下配置:

! Configuration File for keepalived

    global_defs {

    notification_email {

        root@localhost

    }

    notification_email_from keepalived@localhost

    smtp_server 127.0.0.1

    smtp_connect_timeout 30

    router_id centos6

    vrrp_mcast_group4 224.0.100.39

    }

    vrrp_script chk_down {

        script “[[ -f /etc/keepalived/down ]] && exit 1 || exit 0”

        interval 1

        weight -5

    }

    vrrp_script chk_nginx {

        script “killall -0 nginx && exit 0 || exit 1”

        interval 1

        weight -5

        fall 2

        rise 1

    }

    vrrp_instance ngx {

        state MASTER

        interface eth1

        virtual_router_id 14

        priority 100

        advert_int 1

        authentication {

            auth_type PASS

            auth_pass MDQ41fTp

        }

        virtual_ipaddress {

            192.168.20.100/24 dev eth1

        }

        track_script {

            chk_down

            chk_nginx

        }

    }

    vrrp_instance ngx2 {

        state BACKUP

        interface eth1

        virtual_router_id 15

        priority 98

        advert_int 1

        authentication {

            auth_type PASS

            auth_pass XYZ41fTp

        }

        virtual_ipaddress {

            192.168.20.200/24 dev eth1

        }

        track_script {

            chk_down

        chk_nginx

        }

    }

B主机也作同样配置,稍作修改即可,需要修改的地方如下:

    vrrp_instance ngx {

        state BACKUP

        priority 98

    }

    vrrp_instance ngx2 {

        state MASTER

        priority 100

    }

六、模拟故障,验证结果

1.启动两台Nginx proxykeepalived服务

# service keepalived start

2.访问192.168.20.100,结果应是后端的web server轮询响应请求

双主模型的Nginx高可用负载均衡集群

3.访问192.168.20.200,结果应是后端的web server轮询响应请求

双主模型的Nginx高可用负载均衡集群

4.将后端的web server关闭一台,访问192.168.20.100192.168.20.200,响应请求的将只是另一台正常运行web server的主机

双主模型的Nginx高可用负载均衡集群

5.将后端的web server都关闭,此时访问192.168.20.100192.168.20.200,响应请求的将只是Nginx proxy中定义的主server中的sorry_server

双主模型的Nginx高可用负载均衡集群

6.关闭一台Nginx proxy nginx服务,备server将把IP地址添加到本机,继续提供服务,此时访问192.168.20.100192.168.20.200并不会有任何察觉

双主模型的Nginx高可用负载均衡集群

原创文章,作者:人字拖,如若转载,请注明出处:http://www.178linux.com/75394

(0)
人字拖人字拖
上一篇 2017-05-13
下一篇 2017-05-13

相关推荐

  • DNS和BIND配置(第一部分)

    一、知识整理 1、最初只有七个一级域名:Top Level Domain:tld:com、edu、mil、gov、net、org、int;     一级域名分三类:组织域、国家域、反向域。最多127级域名;全球有13个根节点服务器。 2、一次完整的查询请求经过的流程:client—hosts文件&#8212…

    Linux干货 2016-10-17
  • LVS负载均衡WordPress

    LVS:        LVS是四层协议的开源负载均衡器,工作在netfilter框架INPUT链中,它根据不同的算        法将用户的请求调度给后端服务器,它不受sockt套接字文件限制,性能比nginx七层       …

    Linux干货 2017-05-18
  • sed

    复制/etc/rc.d/rc.sysinit文件到/tmp目录中,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首家#; 2.复制/boot/grub/grub.conf至/tmp中,删除/tmp/grub.conf文件中的行首的空白字符 3.删除/tmp/rc.sysinit文件中的以#开头,且后面跟了一个至少一个空白字符的行行的#…

    Linux干货 2016-12-04
  • 马哥linux0801课程内容

    0801课堂笔记 硬链接和软链接最根本的区别 硬链接是同一个文件,而软链接是两个文件 软链接查询到文件的软链接个数.比较麻烦. 而硬链接的个数可以通过链接数就可以看到. 硬链接不能跨分区,而软链接可以跨分区 (因为每个分区都有自己的inode表) ln 创建硬链接 ln–s 创建软链接(软链接如果使用相对路径,对象是相对软链接的路径,而硬…

    Linux干货 2016-08-04
  • M20 – 1- 第二周博客(1):帮助手册查询的使用

    Linux系统中存在诸多的命令,而这些命令分为内键命令和外部命令。如何查询命令属于内部还是外部呢。前一篇博客已经介绍type命令,type命令可以区分命令属于内部还是外部,下面举个例子: 为什么这一期博客还重复讲如何区分内部与外部命令呢,因为在man手册查询中,内部命令并不是使用man查询帮助手册,仅仅使用与外部命令,那内键命令如何查询呢,接下来要讲的就是h…

    Linux干货 2016-08-02
  • 8月4号作业

    正则表达式表示18位身份证号 egrep "\b[0-9]{17}(x|X|[0-9])\b" 正则表达式表示手机号 egrep "\b1[3,5,8,7][0-9]{9}\b" phone 正则表达式表示邮箱 grep -E "\b[[:alnum:]].*@[[:alnum:]]{2,3}.[[:alnu…

    Linux干货 2016-08-08