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

小白入门必知必会-Nginx+Keepalived双机热备安装

off999 2025-02-28 17:02 20 浏览 0 评论

一 高可用介绍

1.1 概念简介

HA即(High Available)高可用,又被叫做双机热备,用于关键性业务。简单理解就是,有2台机器 server1和server2,正常是server1提供服务,server2待命闲置,当server1宕机或服务宕掉,会切换至server2机器继续提供服务。常见的实现高可用的开源软件有 heartbeat 和 keepalived。

1.2 场景介绍

一台web服务器一天24小时提供服务,难免会存在服务挂掉或服务器宕机的情况,那么用户就访问不了服务了,生产环境肯定是接受不了的。

但如果有2台服务器,server1对外提供web服务,server2作为备用,如果server1挂掉,那么server2立刻替代server1去提供服务,这样对用户来说是无感知的。

但是这里有个问题,server1的ip是 192.168.0.99,server2的ip是192.168.0.100,显然向用户提供server1或server2的ip地址是不可行的,因为用户总不能去切换ip来访问。

这时heartbeat或keepalived可以提供一个虚拟VIP:192.168.0.97,用户只需要访问192.168.0.97,当server1提供服务时,VIP 会漂移到server1服务器上,当server2提供服务时,VIP会漂移到server2服务器上,这样就可以让用户通过访问192.168.0.97来获取web服务,即使server1或server2服务器切换也不影响用户的正常访问。

1.3 keepalived介绍

Keepalived的作用是检测服务器的状态,如果有一台web服务器宕机,或工作出现故障,Keepalived将检测到,并将有故障的服务器从系统中剔除,同时使用其他服务器代替该服务器的工作,当服务器工作正常后Keepalived自动将服务器加入到服务器群中,这些工作全部自动完成,不需要人工干涉,需要人工做的只是修复故障的服务器。

下面使用keepalived来做 HA 集群,并且把 nginx 服务作为 HA 对应的服务。

二 Nginx+Keepalived安装

2.1 准备环境

服务器1:

  • 主机名:keepalived01
  • 操作系统:CentOS7.8 64位
  • IP地址:192.168.0.99

服务器2:

  • 主机名:keepalived02
  • 操作系统:CentOS7.8 64位
  • IP地址:192.168.0.100

虚拟VIP:

  • VIP:192.168.0.97

2.2 设置主机名

服务器1设置hostname

hostnamectl set-hostname keepalived01

退出重新登录

服务器2设置hostname

hostnamectl set-hostname keepalived02

2.3 关闭防火墙和selinux(2台节点都要操作)

关闭防火墙

systemctl stop firewalld

systemctl disable firewalld

关闭selinux

setenforce 0

sed -i 's/SELINUX=enforcing/SELINUX=disabled/' /etc/selinux/config

2.4 配置hosts文件(2台服务器都要操作)

vim /etc/hosts

增加内容如下:

192.168.0.97 VIP

192.168.0.99 keepalived01

192.168.0.100 keepalived02

2.5 安装nginx(2台服务器都操作)

yum install nginx nginx-mod-stream -y

vim /etc/nginx/nginx.conf

在文件最后添加如下内容

stream {

log_format proxy '$time_local|$remote_addr|$upstream_addr|$protocol|$status|'

'$session_time|$upstream_connect_time|$bytes_sent|$bytes_received|'

'$upstream_bytes_sent|$upstream_bytes_received' ;


upstream web {

server 192.168.0.99:81 max_fails=3 fail_timeout=30s;

server 192.168.0.100:81 max_fails=3 fail_timeout=30s;

}

server {

listen 80;

proxy_connect_timeout 2s;

proxy_timeout 900s;

proxy_pass web;

access_log /var/log/nginx/proxy.log proxy;

}

}

启动nginx

systemctl enable nginx --now

2.6 安装keepalived(2台服务器都操作)

yum install keepalived -y

添加检测脚本

vim /etc/keepalived/check_port.sh

#!/bin/bash

CHK_PORT=$1

if [ -n "$CHK_PORT" ];then

PORT_PROCESS=`ss -lnt|grep $CHK_PORT|wc -l`

if [ $PORT_PROCESS -eq 0 ];then

echo "Port $CHK_PORT is not used,end."

fi

if [ $PORT_PROCESS -eq 0 ];then

systemctl stop keepalived

fi

else

echo "Check Port Can Be Empty!"

fi

授予可执行权限

chmod +x /etc/keepalived/check_port.sh

2.7 keepalived01服务器操作

cat >/etc/keepalived/keepalived.conf<

! Configuration File for keepalived


global_defs {

router_id 192.168.0.99

}


vrrp_script chk_nginx {

script "/etc/keepalived/check_port.sh 80"

interval 2

weight -20

}


vrrp_instance VI_1 {

state MASTER

interface ens3

virtual_router_id 251

priority 100

advert_int 1

mcast_src_ip 192.168.0.99

authentication {

auth_type PASS

auth_pass 11111111

}

track_script {

chk_nginx

}


virtual_ipaddress {

192.168.0.97

}

}

EOF

启动keepalived

systemctl enable keepalived --now

2.8 keepalived02服务器操作

cat >/etc/keepalived/keepalived.conf<

! Configuration File for keepalived


global_defs {

router_id 192.168.0.100

}


vrrp_script chk_nginx {

script "/etc/keepalived/check_port.sh 80"

interval 2

weight -20

}


vrrp_instance VI_1 {

state BACKUP

interface ens3

virtual_router_id 251

priority 90

advert_int 1

mcast_src_ip 192.168.0.100

authentication {

auth_type PASS

auth_pass 11111111

}

track_script {

chk_nginx

}


virtual_ipaddress {

192.168.0.97

}

}

EOF

启动keepalived

systemctl enable keepalived --now

2.9 测试高可用

先确定VIP在哪台服务器

浏览器访问

http://192.168.0.97

停止keepalived01服务器的nginx

pkill nginx

发现VIP漂移到keepalived02服务器上了

而此时,浏览器还是可以正常访问

http://192.168.0.97

至此,基于Keepalived的双机热备安装完成。

相关推荐

Python设计模式 第 13 章 中介者模式(Mediator Pattern)

在行为型模式中,中介者模式是解决“多对象间网状耦合”问题的核心模式。它就像“机场调度中心”——多个航班(对象)无需直接沟通起飞、降落时间,只需通过调度中心(中介者)协调,避免航班间的冲突与混乱...

1.3.1 python交互式模式的特点和用法

什么是Python交互模式Python交互模式,也叫Python交互式编程,是一种在Python解释器中运行的模式,它允许用户在解释器窗口中输入单个Python语句,并立即查看结果,而不需要编写整个程...

Python设计模式 第 8 章 装饰器模式(Decorator Pattern)

在结构型模式中,装饰器模式是实现“动态功能扩展”的核心模式。它就像“手机壳与手机的关系”——手机(原始对象)具备通话、上网等基础功能,手机壳(装饰器)可在不改变手机本身的前提下,为其新增保护、...

python设计模式 综合应用与实战指南

经过前面16章的学习,我们已系统掌握创建型模式(单例、工厂、建造者、原型)、结构型模式(适配器、桥接、组合、装饰器、外观、享元、代理)、行为型模式(责任链、命令、迭代器、中介者、观察者、状态、策略...

Python入门学习教程:第 16 章 图形用户界面(GUI)编程

16.1什么是GUI编程?图形用户界面(GraphicalUserInterface,简称GUI)是指通过窗口、按钮、菜单、文本框等可视化元素与用户交互的界面。与命令行界面(CLI)相比,...

Python 中 必须掌握的 20 个核心:str()

str()是Python中用于将对象转换为字符串表示的核心函数,它在字符串处理、输出格式化和对象序列化中扮演着关键角色。本文将全面解析str()函数的用法和特性。1.str()函数的基本用法1.1...

Python偏函数实战:用functools.partial减少50%重复代码的技巧

你是不是经常遇到这样的场景:写代码时同一个函数调用了几十次,每次都要重复传递相同的参数?比如处理文件时总要用encoding='utf-8',调用API时固定传Content-Type...

第2节.变量和数据类型【第29课-输出总结】

同学们,关于输出的知识点讲解完成之后,把重点性的知识点做一个总结回顾。·首先对于输出这一章节讲解的比如有格式化符号,格式化符号这里需要同学们额外去多留意的是不是百分号s格式化输出字符串。当然课上也说百...

AI最火语言python之json操作_python json.loads()

JSON(JavaScriptObjectNotation,JavaScript对象表示法)是一种开放标准的文件格式和数据交换格式,它易于人阅读和编写。JSON是一种常用的数据格式,比如对接各种第...

python中必须掌握的20个核心函数—split()详解

split()是Python字符串对象的方法,用于将字符串按照指定的分隔符拆分成列表。它是文本处理中最常用的函数之一。一、split()的基本用法1.1基本语法str.split(sep=None,...

实用方法分享:pdf文件分割方法 横向A3分割成纵向A4

今天在街上打印店给儿子打印试卷时,我在想:能不能,把它分割成A4在家中打印,这样就不需要跑到街上的打印店打印卷子了。原来,老师发的作业,是电子稿,pdf文件,A3格式的试卷。可是家中的打印机只能打印A...

20道常考Python面试题大总结_20道常考python面试题大总结免费

20道常考Python面试题大总结关于Python的面试经验一般来说,面试官会根据求职者在简历中填写的技术及相关细节来出面试题。一位拿了大厂技术岗SpecialOffer的网友分享了他总结的面试经...

Kotlin Data Classes 快速上手_kotlin快速入门

引言在日常开发中,我们常常需要创建一些只用来保存数据的类。问题是,这样的类往往需要写一堆模板化的方法:equals()、hashCode()、toString()……每次都重复,既枯燥又容易出错。//...

python自动化RobotFramework中Collections字典关键字使用(五)

前言介绍安装好robotframework库后,跟之前文章介绍的BuiltIn库一样BuiltIn库使用介绍,在“python安装目录\Lib\site-packages\robot\librarie...

Python中numpy数据分析库知识点总结

Python中numpy数据分析库知识点总结二、对已读取数据的处理②指定一个值,并对该值双边进行修改③指定两个值,并对第一个值的左侧和第二个值的右侧进行修改2.4数组的拼接和行列交换①竖直拼接(np...

取消回复欢迎 发表评论: