keepalived+nginx 模型示例

原理为:

调度器 利用 keepalived 保持高可用性,实现对系统的监控和VIP 的floating

NGINX 利用upstream模块进行调度

关键点:

keepalived 对NGINX 状态的监控: //利用配置文件中设定的脚本对调度器的nginx 进程的监控

实验步骤:

基于上一篇LVS-DR架构来做,具体LVS-DR架构请参考上一篇

  • 先设置主备单VIP 式LVS架构
    • 调度器分别安装nginx

      #yum install nginx -y

    • 修改配置文件,填加反代设置 /etc/nginx/nginx.conf

      upstream websrvs{

      server 172.18.48.63:80 ;

      server 172.18.48.64:80 ;

      server 127.0.0.1:80 backup;

      }

      注:这里是最基本的配置

      location / {

      proxy_pass http://websrvs;

      }

    • 配置keepalived 配置文件

      订制监控脚本:

      vrrp_script nginxstatus {

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

      interval 1

      weight -5

      }

      调用脚本:

      track_script {

      nginxstatus

      }

    • 启动 nginx 和 keepalived 服务

      service nginx start

      service keepalived start

    • 测试链接:
      • keepalived+nginx 模型示例
      • 循环链接测试

        keepalived+nginx 模型示例

  • 现在构建双主模型 // 即再次配置一套keepalived
    • 备调度器设置

    keepalived+nginx 模型示例

    从调度器设置

    keepalived+nginx 模型示例

    重新启动keepalived

    #service keepalived restart

    VIP分布:

    keepalived+nginx 模型示例

    keepalived+nginx 模型示例

    测试链接:

    keepalived+nginx 模型示例

  • 现在停掉一个调度器中的nginx服务:
    • VIP地址 已经转移;再次链接实验
    • keepalived+nginx 模型示例
    • 再次链接: //成功
    • keepalived+nginx 模型示例

    • 现在测验nginx 的调度算法为ip_hash 时,VIP Floating 会不会带来影响:

      预想应该不会受影响,nginx 的哈希算法不变的话就不会变

      • keepalived+nginx 模型示例
      • 注: ip_hash 不能于backup 共存,
      • 官方说明:

        If one of the servers needs to be temporarily removed, it should be marked with the down parameter in order to preserve the current hashing of client IP addresses.

      • 重启服务:

        service nginx restart

      • 链接测试:

        双调度器都在线时:

        keepalived+nginx 模型示例

      • 停掉149 的nginx 服务时:

        keepalived+nginx 模型示例

        测试链接:

        keepalived+nginx 模型示例

      • 149 nginx 服务重启后:
        • keepalived+nginx 模型示例

        • keepalived+nginx 模型示例
      • 测试链接:

        keepalived+nginx 模型示例

      • 148测试也没有变化:

    思考题

    nginx使用ip_hash或hash $request_uri算法时,故障切换后,同一个客户端是否依然能关联至此前绑定的upstream server;

    答:由于hash 时nginx 根据预定的算法进行的计算,所以只要IP和请求资源不变,被调度的地址就不会变

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

(0)
zhoulzzhoulz
上一篇 2017-05-13 21:30
下一篇 2017-05-13

相关推荐

  • 第三周作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可 who |cut -d ' ' -f1 |sort|uniq 2、取出最后登录到当前系统的用户的相关信息 last|head -1 3、取出当前系统上被用户当作其默认shell的最…

    Linux干货 2016-12-26
  • 文件查找

    文件查找: locate查找:     locate:     依赖于事先构建好的索引库,操作系统刚完成没有       系统自动实现(周期性任务);      &nbs…

    Linux干货 2016-08-15
  • LVM2

    1、逻辑卷     逻辑卷为何物:逻辑,是从人的角度出发的,合乎人类的思维的,所以逻辑卷相对于其它磁盘分区高级一些。主要作用就是可以进行动态扩展缩减,不像其它分区大小固定了要想变动就必须重新格式化。 在实际工作环境中,LVM更适用于现实复杂多变的环境。 现在使用的是LVM2,Logical Volume Manager,Version 2…

    Linux干货 2016-08-30
  • ☞CentOS安装程序{ 源码包安装;rpm包安装;}&&恢复rpm功能

    ☞CentOS安装程序{ 源码包安装;rpm包安装;}&&恢复rpm功能 本文是继上一篇文章“CentOS程序安装的3种方式{ 源码包安装 | rpm包安装 | yum安装;}”的补充,上篇文章http://www.178linux.com/38812主要介绍了yum安装软件的方法以及归纳了详细的yum命令。本文继续介绍基于本地file、远程…

    Linux干货 2016-08-24
  • 数组和变量之间的关系及如何灵活运用数组

    什么是数组?数组:存储多个元素的连续的内存空间,相当于多个变量的集合什么是变量? 变量即是存储单个元素的内存空间 如果整个数组只有一个名字;数组名是数组的标识;也是数组所指向的存储多个元素的连续的内存空间开始地址的标识;数组索引定义从 0 开始(第一个数组元素);到 N 结束引用某个数组元素时,数组名+【索引】格式:${ARRAY_NAM…

    Linux干货 2017-05-22
  • N25第五周 grep 和find 命令使用示例

    1、显示/boot/grub/grub.conf中以至少一个空白字符开头的行;    [root@localhost grub]# grep "^[[:space:]]\+.*" grub.conf    root (hd0,0)…

    Linux干货 2016-12-25