keepalived 高可用主备

这篇具有很好参考价值的文章主要介绍了keepalived 高可用主备。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

实验采用两台centos9 nginx+keepalived 一共两台,进行主备切换

主服务器 192.168.100.105 备用 192.168.100.106 虚拟ip 192.168.100.200

安装

dnf install vim wget curl vim net-tools nginx keepalived

Undefined

nginx 配置需要更改为虚拟ip

  server {
        listen       80;
        listen       [::]:80;
        server_name  192.168.100.200;

CSS

两台机器均已经配置好监听同ip

keepalived
master配置

! Configuration File for keepalived             # 这一行为注释
global_defs { 
        router_id nginx01       # router_id 机器标识,通常使用 hostname,相对具有唯一性,和备机区分开,不能使用同一个标识
}
 
vrrp_instance VI_1 {            # 定义一个vrrp_install实例,名称为VI_1
        state MASTER                    # 表示该实例的角色状态,有MASTER和BACKUP两种主备状态
        interface eth0                  # 对外提供服务的网络接口,注意修改为自己的网卡名称,如 ens33,eth0,eth1
        virtual_router_id 51    # 虚拟路由ID标识,主备服务器配置中相同实例的ID必须一致
        priority 100                    # priority表示实例优先级,数字越大,优先级越高。master 的优先级必须大于 backup
        advert_int 1                    # 设定 master 与 backup 负载均衡器之间同步检查的时间间隔,默认是秒
 
        authentication {                # 权限认证配置
                auth_type PASS          # 主要有 PASS 和 AH 两种
                auth_pass 1111          # 验证密码,同一个 vrrp_instance 下 MASTER 和 BACKUP 密码必须相同
        }
 
        virtual_ipaddress {
                192.168.100.200         # 虚拟IP地址;可以配置多个IP,每个IP占一行。注意,这里的IP就是在工作中访问 zabbix server 需要和域名绑定的ip
        }
}

GraphQL

备用服务器配置

! Configuration File for keepalived             # 这一行为注释
global_defs { 
        router_id nginx02       # router_id 机器标识,通常使用 hostname,相对具有唯一性,和主机区分开,不能使用同一个标识
}
vrrp_instance VI_1 {            # 定义一个vrrp_install实例,名称为VI_1
        state BACKUP                    # 表示该实例的角色状态,有MASTER和BACKUP两种主备状态
        interface eth0                  # 对外提供服务的网络接口,注意修改为自己的网卡名称,如 ens33,eth0,eth1
        virtual_router_id 51    # 虚拟路由ID标识,主备服务器配置中相同实例的ID必须一致
        priority 99                     # priority表示实例优先级,数字越大,优先级越高。master 的优先级必须大于 backup
        advert_int 1                    # 设定 master 与 backup 负载均衡器之间同步检查的时间间隔,默认是秒
 
        authentication {                # 权限认证配置
                auth_type PASS          # 主要有 PASS 和 AH 两种
                auth_pass 1111          # 验证密码,同一个 vrrp_instance 下 MASTER 和 BACKUP 密码必须相同
        }
 
        virtual_ipaddress {
                192.168.100.200         # 虚拟IP地址;可以配置多个IP,每个IP占一行。注意,这里的IP就是在工作中访问 zabbix server 需要和域名绑定的ip
        }
}

GraphQL

直接访问192.168.100.200

这里主服务掉线vip后会自动切换到备用服务器上去了

keep宕机后 会自动切换但是nginx宕机他不会切换 需要用到脚本让他自己关闭

#! /bin/bash
# 当 nginx 服务 down 掉之后,通过 keepalived 检查,确认没有服务重新启动 nginx
nginx_server=`ps -C nginx --no-header | wc -l`
 
if [ $nginx_server -gt 0 ];then
    exit 1
else
	nginx
fi

Bash

keep 里面要加入文章来源地址https://www.toymoban.com/news/detail-758181.html

vrrp_script chk_nginx {		# 定义一个检测脚本,在global_defs之外配置
  script "/etc/keepalived/check_nginx.sh"	# 自己写的监测脚本
  interval 2	# 每2s监测一次
  weight 10		# 该参数用于指定当监测失效时,该设备的优先级会减少的值,该值为负表示减少
  fall 2        # 尝试两次都成功才成功
  rise 2        # 尝试两次都失败才失败
}

到了这里,关于keepalived 高可用主备的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【云原生】容器编排工具Kubernetes

    目录 一、 K8S介绍 官网地址: 1.1docker编排与k8s编排相比 1.2特性 1.3功能 二、K8S重要组件 2.1核心组件 (1)Kube-apiserver (2)Kube-controller-manager (3)Kube-scheduler (4)Node ①kubelet ②kube-proxy ③docker (5)etcd 2.2Kubernetes工作原理 三、Pod 3.1 Pod控制器 (1)Deployment (2)ReplicaSet (3)

    2024年02月09日
    浏览(33)
  • 【云原生】Kubernetes容器编排工具

    目录 1. K8S介绍 1.1 k8s的由来 下载地址 1.2 docker编排与k8s编排相比 1.3 传统后端部署与k8s 的对比 传统部署 k8s部署  ​2. k8s的集群架构与组件 (1) Kube-apiserver (2)Kube-controller-manager  (3)Kube-scheduler   2.2 k8s的配置存储中心 2.3  k8s的Node 组件   (1)Kubelet   (2)Kube-Proxy 

    2024年02月10日
    浏览(28)
  • centos7系统keepalived安装配置(服务器主备、负载均衡)

    https://gitcode.net/zengliguang/nginx_keepalived.git 主备服务器上都需要安装 主服务器脚本 备服务器脚本 虚拟机ip:192.168.11.56 主服务器:192.168.11.53 备服务器:192.168.11.54 keepalived安装之后,在 etc 里面生成目录 keepalived,有文件 keepalived.conf /etc/keepalived  需要修改的内容如下 hostname 需要

    2024年04月23日
    浏览(60)
  • 云原生、容器化、Kubernetes、微服务

    作者:禅与计算机程序设计艺术 云原生(Cloud Native)是一个开放且社区驱动的项目,它定义了一组架构原则、最佳实践和工具集,这些原则、实践和工具围绕业务需求和工程实践而设计,可用于开发人员在构建和运行分布式系统时更加顺畅地交付可靠的软件。云原生可以帮助

    2024年02月07日
    浏览(34)
  • 【云原生】kubernetes中容器的资源限制

    目录 1 metrics-server 2 指定内存请求和限制 3 指定 CPU 请求和限制 资源限制 在k8s中对于容器资源限制主要分为以下两类: 内存资源限制: 内存 请求 (request)和内存 限制 (limit)分配给一个容器。 我们保障容器拥有它请求数量的内存,但不允许使用超过限制数量的内存。 官网参

    2024年02月14日
    浏览(34)
  • 云原生Kubernetes:CRI 容器运行时接口

    目录 一、理论 1.​CRI 2.容器运行时层级 3.容器运行时比较 二、总结 (1)概念       Kubernetes Node (kubelet) 的主要功能就是启动和停止容器的组件,我们 称之为容器运行时( Container Runtime) ,其中最知名的就是 Docker 。为了 更具扩展性, Kubernetes 1.5 版本开始就加入了容器运行

    2024年02月09日
    浏览(33)
  • 云原生|kubernetes|kubernetes集群部署神器kubekey安装部署高可用k8s集群(半离线形式)

    前面利用kubekey部署了一个简单的非高可用,etcd单实例的kubernetes集群,经过研究,发现部署过程可以简化,省去了一部分下载过程(主要是下载kubernetes组件的过程)只是kubernetes版本会固定在1.22.16版本,etcd集群可以部署成生产用的外部集群,并且apiserver等等组件也是高可用,

    2024年02月15日
    浏览(39)
  • 【云原生|Kubernetes】08-Pod中的Init容器

    Init 容器是一种特殊容器,在 Pod内的应用容器启动之前运行。Init 容器可以包括一些应用镜像中不存在的实用工具和安装脚本。 你可以在 Pod 的spec中与用来描述应用容器的 containers 数组平行的位置指定 Init 容器。 Init 容器的状态在 status.initContainerStatuses 字段中以容器状态数组

    2024年02月09日
    浏览(43)
  • 容器和云原生(三):kubernetes搭建与使用

            目录 单机K8S docker containerd image依赖 kubeadm初始化 验证 crictl工具 K8S核心组件 上文安装单机docker是很简单docker,但是生产环境需要多个主机,主机上启动多个docker容器,相同容器会绑定形成1个服务service,微服务场景中多个service会互相调用,那么就需要保证多个servi

    2024年02月11日
    浏览(22)
  • 【云原生-深入理解Kubernetes-1】容器的本质是进程

    大家好,我是秋意零。 😈 CSDN作者主页 😎 博客主页 👿 简介 👻 普通本科生在读 在校期间参与众多计算机相关比赛,如:🌟 “省赛”、“国赛” ,斩获多项奖项荣誉证书 🔥 各个平台, 秋意零/秋意临 账号创作者 🔥 云社区 创建者 点赞、收藏+关注下次不迷路! 欢迎加

    2024年02月02日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包