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

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

off999 2025-02-28 17:02 39 浏览 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的双机热备安装完成。

相关推荐

电脑连接投影仪快捷键(笔记本电脑如何连接投影仪)

电脑如何设置于投影的仪连接的电脑快捷键电脑连接投影仪的快捷键: 1、可以通过使用“FN+F4”或“FN+F8”组合键来切换投影仪画面。 2、如果使用的是WIN7及以上系统,可以按“WIN+P”组合键,...

手机远程桌面连接电脑(手机远程桌面连接电脑app)

想要使用手机远程桌面连接电脑,需要使用一款支持远程桌面协议的应用,比如MicrosoftRemoteDesktop或TeamViewer等。首先,需要在电脑上安装相应的远程桌面服务,并开启远程桌面...

itunes备份文件(itunes备份文件把c盘爆满了)
  • itunes备份文件(itunes备份文件把c盘爆满了)
  • itunes备份文件(itunes备份文件把c盘爆满了)
  • itunes备份文件(itunes备份文件把c盘爆满了)
  • itunes备份文件(itunes备份文件把c盘爆满了)
ghost系统之家win10(windows ghost)

Ghost备份系统Win10可以通过使用Ghost软件来完成。首先,需要下载和安装Ghost软件。然后,将系统文件和数据备份到外部硬盘或其他存储设备中。接下来,打开Ghost软件,选择备份选项,并按照...

免费cad制图软件(电脑版cad免费怎么下载)

迅捷cad编辑器永久免费版全面支持图纸的编辑功能,软件体积小巧功能强大,他支持几乎所有主流的图片格式,让用户不会出现无法打开图纸的困扰,也不会让用户收到领域的困扰,包括电气、机械、建筑等等领域的cad...

笔记本电脑没声音是什么原因

笔记本电脑没有声音的原因是:1.声音是否被调到最小了。2.音频是否被禁用了。3.声卡驱动是不是有问题。4.如果电脑既没有声音也没有小喇叭的图标,则表示电脑的音频设备未启用。笔记本电脑没有声音的原因是:...

melogin路由器设置登录入口(192.168.1.1直接进入)

melogincn路由器的设置步骤如下第一、路由器线路连接1、请把你的.水星双频路由器上的WAN接口,用网线连接到猫的网口。如果你家宽带没有用到猫,就把入户的宽带网线,插在路由器的WAN口。2、把你的...

如何优化电脑性能
如何优化电脑性能

可以通过以下几个步骤来提高电脑运行速度和游戏流畅度:1.清理垃圾文件和无用程序,可以使用系统自带的清理工具或第三方软件;2.关闭开机自启动项,只保留必要的程序开机启动;3.升级硬件,比如增加内存、更换硬盘等;4.优化系统设置,如关闭不必要的...

2026-01-02 06:51 off999

ie8以上版本浏览器(ie8及以上版本浏览器)

浏览器IE8版本以上的意思就是当浏览的网页不支持低版本的IE浏览器,就会提示需要版本较高的IE8以上的版本才可以打开浏览网页。IE浏览器是美国微软公司推出的一款网页浏览器,原名MicrosoftIn...

适合电脑的应用商店(电脑最好的应用商店)

1.MicrosoftToDo推荐理由:微软出品,必属精品2.Microsoft便笺推荐理由:又是一款微软官方出品的良心免费应用,相比MicrosoftToDo,Microsoft便笺更加...

家里无线网连上不能用(家里无线网不能使用)

WiFi连上但不能使用可能有多种原因。以下是一些常见问题和解决方法:1.路由器问题:首先要确认路由器是否正常工作。可以尝试重启路由器,等待几分钟后再次连接并测试。2.网络设置问题:检查设备上的网络...

低价香港服务器(香港服务器推荐性价比)

香港最好的服务器是双向cn2+移动+联通三线优化直连的,性能配置都非常高,而且速度还非常稳定。 香港服务器的使用方法:1、首先需要选择一个服务商进行购买服务器;2、购买成功后,可在本地计算机...

免费360清理大师官方版(华为自带清理软件)

挺好用的。它可以清除你手机的里面的垃圾,检测和修复软件安全性。还有一些漏洞垃圾,你可以试着对比和使用,功效和针对性比较强。您杀毒没有效果的原因可能是您的安全软件版本过旧导致的,建议您使用最新版的腾讯手...

万能解压器安卓版(万能解压器官方下载)

是一款手机文件的助手。万能解压器手机版。专注于快速解压和压缩的文件管理工具!支持ZIP,RAR,7Z,TAR,ZIPX,GZIP,JAR等压缩和解压文件格式。是超好用、超便捷的解压软件!支持在手机上将...

cad看图(cad看图王)

以下是一些CAD看图的方法和技巧:1.放大/缩小:使用滚轮或放大镜工具可以方便地放大或缩小绘图。2.平移:使用平移工具可以在不改变视角的情况下将绘图向上、向下、向左或向右移动。3.旋转:使用旋转...

取消回复欢迎 发表评论: