Keepalived实现高可用Nginx反向代理

因为很久没有接触过负载相关的调试了复习一下html

实验系统:linux

(1)CentOS 6.5_x86_64;nginx

(2)共有二台主机,本实验以ip地址来命名主机,即10主机、11主机。web

实验前提:防火墙和selinux都关闭,主机之间时间同步apache

实验软件:nginx-1.10.2-1.el6.x86_6四、keepalived-1.2.13-5.el6_6.x86_6四、httpd-2.2.15-59.el6.centos.x86_64
为了方便实验只起了2台虚机方便测试,每台虚机上都安装nginx、keepalived、httpd,逻辑拓扑图以下vim


wKiom1knyxDB71rZAAAlA-8d8QA964.png


1、安装配置keepalivedcentos

1.直接使用yum安装:服务器

yum -y install keepalived nginx  httpd      #若是nginx没法安装先安装epel源,或者编译安装
ide

2.在34主机上配置keepalived:测试

vim /etc/keepalived/keepalived.conf
--------------------------------------------
global_defs {                      //此段配置忽略
  notification_email {
    acassen@firewall.loc
  }
  notification_email_from Alexandre.Cassen@firewall.loc
  smtp_server 192.168.200.1
  smtp_connect_timeout 30
  router_id master
}

vrrp_instance VI_1 {
    state MASTER                  //定义为MASTER主机
    interface eth0
    virtual_router_id 55      //虚拟id
    priority 100          //优先级
    advert_int 1                    //检测间隔
    authentication {
        auth_type PASS          //认证方式
        auth_pass abcd          //认证密码
    }
    virtual_ipaddress {
        192.168.1.15 brd 192.168.1.255 dev eth0     
    }
#    notify_master "/etc/init.d/nginx start"    //成为MASTER以后执行的动做
#    notify_backup "/etc/init.d/nginx stop"      //成为BACKUP以后执行的动做
#    notify_fault "/etc/init.d/nginx stop"      //FAULT以后执行的动做
}


3.将配置文件传到11主机,修改红色部分:


4.两台主机启动keepalived服务,如今10这台主机为MASTER,因此服务都起在这台主机上:

service keepalived start

ip addr show

wKiom1kmr87jjX0DAAA-KlIwAWQ508.png


若是10中止keeplived后,观察11上的vip是否有启动。若是没启动请排查缘由,多半是配置文件写错了。

另外有个问题须要注意,若是在master停掉后,backup是能够接过来的,可是master再启动,是接不回去的,只有停掉backup才能够回交给master。


五、配置nginx代理服务器

upstream webservers {
        server 192.168.1.10:8000;            ##apache-realserver地址

        server 192.168.1.11:8000;            ##apache-realserver地址
}


server {
    listen       80 default_server;
    server_name  _;
    root         /usr/share/nginx/html;

    # Load configuration files for the default server block.
    include /etc/nginx/default.d/*.conf;

    location / {
        proxy_pass http://webservers;
        proxy_set_header X-Real-IP $remote_addr;
    }

}


这里标记了主要部分


六、配置Apache的realserver部分

为了方便测试默认配置基本不用动,主要修改Listen端口为8000

用于区分访问两台realserver的不一样每一个文件里的内容修改成:

wKioL1kmseCRtNHjAAAQhTWoynQ250.png

wKiom1kmsgfxRFXbAAAOUI5eyVE043.png

七、最终测试

wKioL1kmsmfieVm6AAAO3qBsrbY867.png

wKiom1kmsmnjDUC1AAAOFWx88j4000.png

访问两次的结果分别访问了不一样的realserver。测试成功(由于nginx上没有配置ip_hash)因此每次访问到了不一样的realserver

相关文章
相关标签/搜索