百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

5分钟动手操作,掌握keepalive

wptr33 2024-11-20 22:37 23 浏览

实验目的

配置keepalived,掌握基本的配置方法,并模拟主节点宕机、恢复操作。

实验拓扑

实验步骤

编写docker-compose文件

version: '3'

services:
  nginx-master:
    image: nginx:alpine
    container_name: nginx-master
    ports:
      - "8081:80"
    networks:
      vrrp-net:
        ipv4_address: 192.168.8.10
    volumes:
      - ./html/index-master.html:/usr/share/nginx/html/index.html

  keepalived-master:
    image: osixia/keepalived:2.0.20
    container_name: keepalived-master
    depends_on:
      - nginx-master
    network_mode: "service:nginx-master"
    cap_add:
      - NET_ADMIN
    volumes:
      - ./keepalived-master.conf:/usr/local/etc/keepalived/keepalived.conf
      - ./check_nginx.sh:/usr/local/bin/check_nginx.sh

  nginx-backup:
    image: nginx:alpine
    container_name: nginx-backup
    ports:
      - "8082:80"
    networks:
      vrrp-net:
        ipv4_address: 192.168.8.11
    volumes:
      - ./html/index-backup.html:/usr/share/nginx/html/index.html

  keepalived-backup:
    image: osixia/keepalived:2.0.20
    container_name: keepalived-backup
    depends_on:
      - nginx-backup
    network_mode: "service:nginx-backup"
    cap_add:
      - NET_ADMIN
    volumes:
      - ./keepalived-backup.conf:/usr/local/etc/keepalived/keepalived.conf
      - ./check_nginx.sh:/usr/local/bin/check_nginx.sh

  proxy:
    image: haproxy:1.7-alpine
    ports:
      - 8000:6301
    volumes:
      - ./haproxy.cfg:/usr/local/etc/haproxy/haproxy.cfg
    networks:
      - vrrp-net
  observer:
    image: alpine
    container_name: observer
    networks:
      vrrp-net:
        ipv4_address: 192.168.8.12
    depends_on:
      - keepalived-master
      - keepalived-backup
    command: >
      /bin/sh -c "apk add --no-cache curl;
        while true; do
          echo 'Checking VIP...';
          curl -s http://192.168.8.100;
          sleep 2;
        done"

networks:
  vrrp-net:
    driver: bridge
    ipam:
      config:
        - subnet: 192.168.8.0/24

主节点配置文件

keepalived-master.conf

vrrp_script chk_nginx {
    script "/usr/local/bin/check_nginx.sh"
    interval 2    # 每2秒检查一次
    weight -10    # 检查失败时降低优先级
}

vrrp_instance VI_1 {
    state MASTER
    interface eth0
    virtual_router_id 51
    priority 150
    advert_int 1 
    preempt #启用抢占机制,恢复后重新做主
    unicast_src_ip 192.168.8.10
    unicast_peer {
        192.168.8.11
    }
    authentication {
        auth_type PASS
        auth_pass 1234
    }
    virtual_ipaddress {
        192.168.8.100
    }
    track_script {
        chk_nginx
    }
}

从节点配置文件

vrrp_script chk_nginx {
    script "/usr/local/bin/check_nginx.sh"
    interval 2    # 每2秒检查一次
    weight -10    # 检查失败时降低优先级
}

vrrp_instance VI_1 {
    state BACKUP
    interface eth0
    virtual_router_id 51
    priority 100
    advert_int 1
    unicast_src_ip 192.168.8.11
    unicast_peer {
        192.168.8.10
    }
    authentication {
        auth_type PASS
        auth_pass 1234
    }
    virtual_ipaddress {
        192.168.8.100
    }
    track_script {
        chk_nginx
    }
}

Nginx检测脚本

check_nginx.sh

#!/bin/sh
if curl -s http://localhost:80 > /dev/null; then
    exit 0
else
    exit 1
fi

Nginx主页配置

为方便展示效果,将nginx 主备两个节点显示内容进行区分。设置不同的主页内容。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Keepalived Nginx Master</title>
</head>
<body>
    <h1>Master</h1>
</body>
</html>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Keepalived Nginx Backup</title>
</head>
<body>
    <h1>Backup</h1>
</body>
</html>

VIP查看配置

使用haproxy配置下对vip的代理,方便在浏览器中直接访问VIP地址,查看确认当前nginx服务节点。

global
    log 127.0.0.1 local0
    maxconn 4096
    daemon
    nbproc 4

defaults
    log 127.0.0.1 local3
    mode http
    option dontlognull
    option redispatch
    retries 2
    maxconn 2000
    balance roundrobin
    timeout connect 5000ms
    timeout client 5000ms
    timeout server 5000ms

frontend main
    bind *:6301
    default_backend webserver

backend webserver
    server ngxin_master 192.168.8.100:80 check inter 2000 rise 2 fall 5

启动docker-compose服务

执行docker-compose up -d 命令,启动服务.

可执行docker-compose logs -f 命令观察日志,出现类似下图类似日志,说明启动成功。

确认启动成功

此时访问http://127.0.0.1:8000,应该访问到主节点

模拟关闭master节点

将nginx-master节点关闭,查看http://127.0.0.1:8000输出内容。

为方便操作执行,编写关闭及恢复脚本。

docker stop nginx-master
sleep 2
sh showip.sh
echo "master ip info "
docker exec -it nginx-master ip addr show
echo ""
echo ""
echo ""

echo "backup ip info "
docker exec -it nginx-backup ip addr show

sh showip.sh 执行效果如下,注意观察192.168.8.100的绑定关系。默认是在主节点。

docker start nginx-master
docker restart keepalived-master
sleep 2
sh showip.sh

准备好脚本后,执行sh stop-master.sh

输出内容形如下图:

此时访问http://127.0.0.1:8000

可以看到此时已切换到nginx备机上了。

执行sh showip.sh可以看到,192.168.8.100这个vip已经转义到备机上了。

模拟恢复master节点

当故障解除后,需要恢复master节点,执行sh start-master.sh

输出如下内容:

此时再次访问http://127.0.0.1:8000

可以看到,我们的VIP的服务内容重新回到主节点。

执行sh showip.sh看下我们的虚IP的绑定情况。

此时虚IP已经重新回到了主节点上。

相关推荐

Windows10 编译OpenCV4.5源码

在OpenCV4.5+VisualStudio2017开发环境配置...

什么是OpenCV?有哪些基础图像处理操作?

一、OpenCV简介OpenCV是一款由Intel公司俄罗斯团队发起并参与和维护的一个计算机视觉处理开源软件库,支持与计算机视觉和机器学习相关的众多算法,并且正在日益扩展。...

学习Opencv-第9节-读写图像

1、读图像---imread()Matimread(conststring&filename,ingflags=1)定义中包含两个参数,一个图像文件名,一个flag标志位,返回的是一个Ma...

基于opencv的视觉巡线实现

前言这段时间在和学弟打软件杯的比赛,有项任务就是机器人的视觉巡线,这虽然不是什么稀奇的事情,但是对于一开始不了解视觉的我来说可以说是很懵了,所以现在就想着和大家分享一下,来看看是如何基于opencv来...

OpenCV学习之图像读取与显示

1、OpenCV的特点(1)总体描述...

OpenCV+Python裁剪图像

最近使用OpenCV+Python做了一个程序,功能是自动将照片中的文本部分找出来并裁剪/旋转保存为新的图片。这个功能用专业些的说法就是选择并提取感兴趣区域(ROI(RegionofInteres...

OpenCV-Python速查表:从导入图像到人脸检测

——本文对图像裁剪、调整大小、旋转、阈值、模糊、在图像上绘图和书写、人脸检测和使用轮廓图像检测对象都进行了解释。什么是OpenCV-Python?OpenCV是一个开源的计算机视觉(computer...

Python图像处理:OpenCV基础教程

OpenCV(OpenSourceComputerVisionLibrary)是一个开源计算机视觉和机器学习软件库。它提供了大量的图像和视频处理功能,可以用于各种应用场景,比如人脸识别、物体检...

OpenCV学堂深度学习系统化学习路线图专题(2023版)

参考资料:aixuetang.xyz/15842...

OpenCV4系统化学习路线图与教程

获课:bcwit.top/15489...

使用OpenCV库操作摄像头拍照、调节参数和视频录制

需求使用OpenCV做功能,播放摄像头(usb和网络),对摄像头设备进行参数调整(亮度、对比度、饱和度、色调、增益、曝光度)调节,拍照和录像。原理使用OpenCV打开摄像头(可打开USB和网路哦摄像...

Python图像处理:用OpenCV实现照片的趣味特效与编辑!

在当今数字化时代,图像处理已经成为了我们生活中不可或缺的一部分,无论是社交媒体上的照片美化,还是专业领域的图像分析,都离不开图像处理技术。Python作为一门强大的编程语言,搭配OpenCV库,为我们...

OpenCV-1: 读取图片,显示图片,保存图片

目标1在这里,将学习如何读取图像,如何显示图像以及如何将其保存回去将学习以下功能:...

JAVA学习笔记——fileUpload文件上传

一、什么是fileUpload?fileUpload是apache的commons组件提供的上传组件,它最主要的工作就是帮我们解析request.getInpustream()。可以参考在线API文档...

如何在Windows10中配置java的JDK环境

今天给大家分享一下如何配置java的JDK环境。操作步骤如下:1.下载好jdk的安装文件,我下载的是jdk-10.0.1_windows-x64_bin.exe这个版本的安装文件;2.使用鼠标...