一、环境

nginx1   192.168.40.211

nginx2   192.168.40.132

vip1     192.168.40.223  主为keep1,从为keep2

vip2     192.168.40.222  主为keep2,从为keep1

(此处安装过程皆采用yum方式,不作累述)

二、keepalived配置文件

nginx1

vi /etc/keepalived/keepalived.conf

global_defs {

notification_email {

root@localhost

}

notification_email_from keepalived@localhost

smtp_server 127.0.0.1

smtp_connect_timeout 30

route_id LVS_DEVEL

}

vrrp_script_chk_nginx {

script "/etc/keepalived/ck_ng.sh"

interval 2

weight 2

}

#VIP1

vrrp_instance VI_1 {

state MASTER

interface ens33

lvs_sync_daemon_interface ens33

virtual_router_id 151

priority 100

advert_int 5

nopreempt

authentication {

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {

192.168.40.223

}

track_script {

chk_nginx

}

}

#VIP2

vrrp_instance VI_2 {

state BACKUP

interface ens33

lvs_sync_daemon_interface ens33

virtual_router_id 152

priority 90

advert_int 5

nopreempt

authentication {

auth_type PASS

auth_pass 2222

}

virtual_ipaddress {

192.168.40.222

}

track_script {

chk_nginx

}

}


nginx2

#vi /etc/keepalived/keepalived.conf

global_defs {

notification_email {

root@192.168.40.132

}

notification_email_from keepalived@192.168.40.132

smtp_server 127.0.0.1

smtp_connect_timeout 30

route_id LVS_DEVEL

}

vrrp_script_chk_nginx {

script "/etc/keepalived/ck_ng.sh"

interval 2

weight 2

}

#VIP1

vrrp_instance VI_1 {

state BACKUP

interface ens33

lvs_sync_daemon_interface ens33

virtual_router_id 151

priority 90

advert_int 5

nopreempt

authentication {

auth_type PASS

auth_pass 1111

}

virtual_ipaddress {

192.168.40.223

}

track_script {

chk_nginx

}

}

#VIP2

vrrp_instance VI_2 {

state MASTER

interface ens33

lvs_sync_daemon_interface ens33

virtual_router_id 152

priority 100

advert_int 5

nopreempt

authentication {

auth_type PASS

auth_pass 2222

}

virtual_ipaddress {

192.168.40.222

}

track_script {

chk_nginx

}

}

三、nginx检测脚本(两台机子一样)

#vi /etc/keepalived/ck_ng.sh

#!/bin/bash

#检查nginx进程是否存在

counter=$(ps -C nginx --no-heading|wc -l)

if [ "${counter}" = "0" ]; then

#尝试启动一次nginx,停止5秒后再次检测

service nginx start

sleep 5

counter=$(ps -C nginx --no-heading|wc -l)

if [ "${counter}" = "0" ]; then

#如果启动没成功,就杀掉keepalive触发主备切换

service keepalived stop

fi

fi

#chmod +x /etc/keepalived/ck_ng.sh

四、测试

[root@localhost ~]# ip a (nginx1)

....

2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000

link/ether 00:0c:29:17:c0:db brd ff:ff:ff:ff:ff:ff

inet 192.168.40.211/24 brd 192.168.40.255 scope global ens33

valid_lft forever preferred_lft forever

inet 192.168.40.223/32 scope global ens33

valid_lft forever preferred_lft forever

inet6 fe80::20c:29ff:fe17:c0db/64 scope link

valid_lft forever preferred_lft forever

[root@localhost ~]# ip a  (nginx2)

....

2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000

link/ether 00:0c:29:5e:ba:a3 brd ff:ff:ff:ff:ff:ff

inet 192.168.40.132/24 brd 192.168.40.255 scope global ens33

valid_lft forever preferred_lft forever

inet 192.168.40.222/32 scope global ens33

valid_lft forever preferred_lft forever

inet6 fe80::20c:29ff:fe5e:baa3/64 scope link

valid_lft forever preferred_lft forever

停掉nginx1的keepalived,此时nginx1的vip转移到nginx2,如下

[root@localhost ~]# ip a

....

2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP qlen 1000

link/ether 00:0c:29:5e:ba:a3 brd ff:ff:ff:ff:ff:ff

inet 192.168.40.132/24 brd 192.168.40.255 scope global ens33

valid_lft forever preferred_lft forever

inet 192.168.40.222/32 scope global ens33

valid_lft forever preferred_lft forever

inet 192.168.40.223/32 scope global ens33

valid_lft forever preferred_lft forever

inet6 fe80::20c:29ff:fe5e:baa3/64 scope link

valid_lft forever preferred_lft forever

两个虚拟IP跑到一台机子上,实验成功

nginx+keepalived(双主)的更多相关文章

  1. 企业Nginx+Keepalived双主架构案例实战

    通过上一次课程的学习,我们知道Nginx+keepalived主从配置,始终有一台服务器处于空余状态,那如何更好的利用起来呢,我们需要借助Nginx+keepalived双主架构来实现,如下图通过改装 ...

  2. nginx+keepalived双主高可用负载均衡

    实验环境及软件版本:CentOS版本: 6.6(2.6.32.-504.el6.x86_64)nginx版本: nginx-1.6.3keepalived版本:keepalived-1.2.7 主LB ...

  3. Nginx+Keepalived双主架构实现

    Keepalived+Nginx实现高可用Web负载均衡 Master 192.168.0.69 nginx.keepalived Centos7.4backup 192.168.0.70 nginx ...

  4. 配置nginx + keepalived 双主模式(双机互为主备)

  5. [转] Haproxy、Keepalived双主高可用负载均衡

    http://blog.chinaunix.net/uid-25266990-id-3989321.html 在测试了Nginx+Keepalived的负载均衡后,也对Haproxy+Keepaliv ...

  6. Nginx + Keeplived双主测试

    Author: JinDate: 20130613Title: Nginx + Keeplived 双主测试 前言:一年多前做过一次测试,时间久了忘记了,现在又重新做一次 一.环境1.基本信息和规划p ...

  7. MariaDB+Keepalived双主高可用配置MySQL-HA

    利用keepalived构建高可用MySQL-HA,保证两台MySQL数据的一致性,然后用keepalived实现虚拟VIP,通过keepalived自带的服务监控功能来实现MySQL故障时自动切换. ...

  8. keepalived+双主实践HA

    工作不怎么忙,搞点儿开发吧差点儿事,就想着弄点儿架构的事儿.正好前段时间看过关于keepalived+双主实现高可用的文章,也恰好身边的朋友所在的公司也部分用这个架构.没什么事儿就搞搞吧,正好对比下M ...

  9. Mysql+Keepalived双主热备高可用操作记录

    我们通常说的双机热备是指两台机器都在运行,但并不是两台机器都同时在提供服务.当提供服务的一台出现故障的时候,另外一台会马上自动接管并且提供服务,而且切换的时间非常短.MySQL双主复制,即互为Mast ...

  10. MySQL keepalived 双主.md

    MySQL keepalived 双主搭建 环境说明 系统 IP 主机名 mysql keepalived VIP CentOS 6.8 192.168.197.61 C6-node1 5.6.36 ...

随机推荐

  1. 使用jvisualvm远程监控tomcat(阿里云ECS)

    写在前面:  使用jvisualvm远程监控tomcat(阿里云ECS),连接是报错:service:jmx:rmi:////jndi/rmi:IP:端口//  连接到 IP:端口,网上找了很多资料, ...

  2. CMMI分为哪几个等级?

    一共分为五个等级. 1.CMMI一级,完成级.在完成级水平上,企业对项目的目标与要做的努力很清晰.项目的目标得以实现. 2.CMMI二级,管理级.在管理级水平上,企业在项目实施上能够遵守既定的计划与流 ...

  3. 提取包含QQ的文本为QQ邮箱

    # -*- coding: utf-8 -*- """ Created on Sun Dec 15 14:08:03 2019 @author: Dell 提取包含QQ号 ...

  4. Swagger使用--在一个Controller中使用相同(类似)参数的方法

    解决方法:在Startup.cs中加入CustomSchemaIds // Register the Swagger generator, defining 1 or more Swagger doc ...

  5. Java验证身份证是否合法

    import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.GregorianCalendar; im ...

  6. JavaScript 输出的四种方法

    JavaScript 没有任何打印或者输出的函数. ㈠JavaScript 显示数据 ⑴使用 window.alert() 弹出警告框. ⑵使用 document.write() 方法将内容写到 HT ...

  7. sh_02_del关键字

    sh_02_del关键字 name_list = ["张三", "李四", "王五"] # (知道)使用 del 关键字(delete)删除 ...

  8. C1:DOM 元素的尺寸和位置

    DOM元素的尺寸和位置 DOM 元素的尺寸 DOM.offsetWidth/offsetHeight: 包括内容区宽/高,padding,border,不包括margin.如果元素的box-sizei ...

  9. 191106DjangoORM之admin数据库管理组件

    一.admin数据库管理系统的使用 创建用户 >python manage.py createsuperuser 访问http://127.0.0.1/admin/ app/admin.py 注 ...

  10. linux 中文乱码解决办法

    就是从数据库中取出来时,在存入linux的文件里时,在字符流时制定编码格式.代码如下: FileOutputStream fos=new FileOutputStream(new File(fileP ...