linux下nginx结合keepalived实现主从切换的配置

 

解决方法:

实现一个主nginx宕机,请求转到另一个nginx中。

1.确保两台nginx已启动,假如端口分别是192.168.0.2:8080和192.168.0.3:8080

2.分别在两台nginx所在的主机192.168.0.2和192.168.0.3中安装keepalived,安装keepalived请参考:http://www.yayihouse.com/yayishuwu/chapter/1649

3.分别再两个主机的/etc/keepalived/下新建一个check_nginx_pid.sh文件,内容如下:

#!/bin/bash

A=`ps -C nginx --no-header |wc -l`

if [ $A -eq 0 ];then

/usr/local/nginx/nginx/sbin/nginx                #如果检测到nginx挂掉了就重启nginx

if [ `ps -C nginx --no-header |wc -l` -eq 0 ];then    #nginx重启失败,则停掉keepalived服务,进行VIP转移

killall keepalived

fi

fi

4.分别修改两个keepalived的配置文件/etc/keepalived/keepalived.conf

假如把192.168.0.2:8080的nginx的keepalived设置为主,把192.168.0.3:8080的nginx的keepalived设置为备用

主keepalived.conf:

global_defs {

notification_email {

997914490@qq.com

}

notification_email_from sns-lvs@gmail.com

smtp_server smtp.hysec.com

smtp_connection_timeout 30

router_id nginx_master        # 设置nginx master的id,在一个网络应该是唯一的

}

vrrp_script chk_http_port {

script "/etc/keepalived/check_nginx_pid.sh"    #最后手动执行下此脚本,以确保此脚本能够正常执行

interval 2                          #(检测脚本执行的间隔,单位是秒)

weight 2

}

vrrp_instance VI_1 {

state MASTER            # 指定keepalived的角色,MASTER为主,BACKUP为备

interface eth0            # 当前进行vrrp通讯的网络接口卡(当前centos的网卡)

virtual_router_id 66        # 虚拟路由编号,主从要一直

priority 100            # 优先级,数值越大,获取处理请求的优先级越高

advert_int 1            # 检查间隔,默认为1s(vrrp组播周期秒数)

authentication {

auth_type PASS

auth_pass 1111

}

track_script {

chk_http_port            #(调用检测脚本)

}

virtual_ipaddress {

192.168.0.200            # 定义虚拟ip(VIP),可多设,每行一个

}

}

从keepalived.conf:

global_defs {

notification_email {

997914490@qq.com

}

notification_email_from sns-lvs@gmail.com

smtp_server smtp.hysec.com

smtp_connection_timeout 30

router_id nginx_backup              # 设置nginx backup的id,在一个网络应该是唯一的

}

vrrp_script chk_http_port {

script "/etc/keepalived/check_nginx_pid.sh"

interval 2                          #(检测脚本执行的间隔)

weight 2

fall 3

}

vrrp_instance VI_1 {

state BACKUP                        # 指定keepalived的角色,MASTER为主,BACKUP为备

interface eth0                      # 当前进行vrrp通讯的网络接口卡(当前centos的网卡)

virtual_router_id 66                # 虚拟路由编号,主从要一直

priority 99                         # 优先级,数值越大,获取处理请求的优先级越高

advert_int 1                        # 检查间隔,默认为1s(vrrp组播周期秒数)

authentication {

auth_type PASS

auth_pass 1111

}

track_script {

chk_http_port                   #(调用检测脚本)

}

virtual_ipaddress {

192.168.0.200                   # 定义虚拟ip(VIP),可多设,每行一个

}

}

5.启动两个keepalived,执行service keepalived start启动

6.使用192.168.0.200:8080访问即可,如果正常访问,说明配置正常;

如果此时杀掉主nginx,而且主nginx又重启了(check_nginx_pid.sh配置了重启),说明执行了check_nginx_pid.sh文件,这是正常的;

如果主nginx重启失败,而且192.168.0.200:8080访问失败,说明没转发到备用nginx,检查一下check_nginx_pid.sh是否被正常执行了,不被执行的原因一般来说是权限不够,到/etc/keepalived/目录执行 chmod u+x *即可。

linux下nginx结合keepalived实现主从切换的配置的更多相关文章

  1. Linux下Nginx+Tomcat负载均衡和动静分离配置要点

    本文使用的Linux发行版:CentOS6.7 下载地址:https://wiki.centos.org/Download 一.安装Nginx 下载源:wget http://nginx.org/pa ...

  2. VMware Linux 下 Nginx 安装配置 - nginx.conf 配置 [负载两个 Tomcat] (三)

    首先启动Nginx 1. 相关浏览 两个 Tomcat 配置:  VMware Linux 下 Nginx 安装配置 - Tomcat 配置 (二) Nginx 安装配置启动: VMware Linu ...

  3. 【转】Linux下nginx配置https协议访问的方法

    一.配置nginx支持https协议访问,需要在编译安装nginx的时候添加相应的模块--with-http_ssl_module 查看nginx编译参数:/usr/local/nginx/sbin/ ...

  4. VMware Linux 下 Nginx

    负载   VMware Linux 下 Nginx 安装配置 - nginx.conf 配置 [负载两个 Tomcat] (三) Weiseditor 2014-11-26 23:42 阅读:1 评论 ...

  5. VMware Linux 下 Nginx 安装配置 - Tomcat 配置 (二)

    准备工作 相关浏览: VMware Linux 下 Nginx 安装配置 (一) 1. 选在 /usr/local/ 下创建 softs 文件夹,通过 ftp 命令 把 apache-tomcat-7 ...

  6. Linux下nginx编译安装教程和编译参数详解

    这篇文章主要介绍了Linux下nginx编译安装教程和编译参数详解,需要的朋友可以参考下 一.必要软件准备1.安装pcre 为了支持rewrite功能,我们需要安装pcre 复制代码代码如下: # y ...

  7. linux下nginx+php+mysql 自助环境搭建

    ++++++++++++++++++++++++++++++++++++++++++++++linux下nginx+php+mysql环境搭建+++++++++++++++++++++++++++++ ...

  8. hadoop搭建杂记:Linux下JDK环境变量的设置(三种配置环境变量的方法)

    Linux下JDK环境变量的设置(三种配置环境变量的方法) Linux下JDK环境变量的设置(三种配置环境变量的方法) ①修改/etc/profile文件 如果你的计算机仅仅作为开发使用时推荐使用这种 ...

  9. linux下svn(subversion)服务端添加工程及配置权限

    linux下svn(subversion)服务端添加工程及配置权限 转载请注明源地址:http://www.cnblogs.com/funnyzpc/p/9010507.html 此篇我只是将所做过的 ...

随机推荐

  1. Socket的一些疑惑整理

    关于listen的问题请看steven<tcp/ip详解1>18章18.11.4 呼入连接请求队列一节,说的很清楚

  2. django实现发送邮件功能

    django实现邮件发送功能 1)首先注册一个邮箱,这里以163邮箱为例 2)注册之后登录,进行如下修改 找到设置,设置一个授权码,授权码的目的仅仅是让你有权限发邮件,但是不能登录到邮箱进行修改,发送 ...

  3. 前端学习笔记--CSS布局--盒子模型

    1.概述: 2.盒子模型 overflow属性: border属性: 1.padding属性: margin:

  4. git如何利用分支进行多人开发

    在使用git时,假如远程仓库有 dev 和 master 两个分支,master 作为一个稳定版分支,可用于直接发布产品,日常的开发则 push 到 dev 分支,那本地是不是要从 dev 分支中创建 ...

  5. docker常用命令以及搭建

    1. 进入容器中 docker exec -it <容器的名字> /bin/bash 2. 查看镜像 docker images 3. 查看所有容器 docker ps -a 4. 运行容 ...

  6. 安装部署mongodb

    准备 groupadd mongodb useradd -g mongodb mongodb echo password |passwd --stdin mongodb mkdir -pv /data ...

  7. yum -y install 问题解决

    1.错误如下: Last login: Thu Jul 26 09:04:14 2018 from 192.168.3.250[root@diagbot01 ~]# yum -y install do ...

  8. C# 使用递归获取所有下属、所有子部门……

    本例中获取的是所有的晚辈!首先定义家庭成员类: public class FamilyMember { /// <summary> /// 身份 /// </summary> ...

  9. 爬虫(十):scrapy命令行详解

    建爬虫项目 scrapy startproject 项目名例子如下: localhost:spider zhaofan$ scrapy startproject test1 New Scrapy pr ...

  10. NodeJs的Event Loop

    我们之前谈过浏览器的Event Loop:https://www.cnblogs.com/amiezhang/p/11349450.html 简单来说,就是每执行一个宏任务,就去执行微任务队列,直到清 ...