Nginx+Keepalived高可用架构平台

简介:



前言随着Nginx在国内的发展潮流,越来越多的互联网公司都在使用Nginx

Nginx高性能、稳定性成为IT人士青睐的http和反向代理服务器。今天我们来一起来温习一下Nginx+Keepalived高可用配置,鉴于互联网类似的优秀文章很多,这里仅供参考和交流。

一、实验环境:

系统环境:CentOS 6.0 x86_64

Nginx版本:nginx v1.2.4

Keepalived版本:keepalived v1.2.1

Nginx-1192.9.117.160 Master

Nginx-2192.9.117.161 Backup

二、Nginx安装配置:

分别在两台服务器安装Nginxkeepalived,如下: 
 
yum install -y pcre-devel   安装perl 兼容的正规表达式库 
 
tar -xzf nginx-1.2.4.tar.gz && cd nginx-1.2.4 ; sed -i -e 's/1.2.2//g' -e 's/nginx\//TDTWS/g' -e 's/"NGINX"/"TDTWS"/g' src/core/nginx.h &&./configure --prefix=/usr/local/nginx --user=www --group=www  --with-http_stub_status_module --with-http_ssl_module
 

三、Keepalived安装配置:

tar -xzvf keepalived-1.2.1.tar.gz &&cd keepalived-1.2.1 && ./configure && make && make install 
 
if 
 
[ $? -eq 0 ];then 
 
echo "Install keepalived success,please waiting configure keepalived ..............." 
 
else 
 
echo "Install keepalived failed ,please check install version !" 
 
exit 0 
 
fi 
 
DIR=/usr/local/ ;cp $DIR/etc/rc.d/init.d/keepalived  /etc/rc.d/init.d/ ; cp $DIR/etc/sysconfig/keepalived /etc/sysconfig/ ; mkdir -p /etc/keepalived ; cp $DIR/sbin/keepalived /usr/sbin/ 

NginxKeepalived软件安装完毕,接下来进行详细配置。

 四、配置Keepalived

两台服务器端keepalived.conf内容都为如下,都设置为backup,不抢占,注意修改优先级不同:

! Configuration File for keepalived 
 
 global_defs { 
 
  notification_email { 
 
      wgkgood@163.com 
 
 } 
 
    notification_email_from wgkgood@163.com 
 
    smtp_server 127.0.0.1 
 
    smtp_connect_timeout 30 
 
    router_id LVS_DEVEL 
 
 } 
 
 vrrp_script chk_nginx { 
 
    script "/data/sh/check_nginx.sh" 
 
    interval 2 
 
    weight 2 
 
 } 
 
 # VIP1 
 
 vrrp_instance VI_1 { 
 
     state BACKUP 
 
     interface eth0 
 
     lvs_sync_daemon_inteface eth0 
 
     virtual_router_id 151 
 
     priority 100 
 
     advert_int 5 
 
     nopreempt 
 
     authentication { 
 
         auth_typePASS 
 
         auth_pass  1111 
 
     } 
 
     virtual_ipaddress { 
 
         192.9.117.162 
 
     } 
 
     track_script { 
 
     chk_nginx 
 
    } 
 
 } 

如上配置,我们需要自己建立check_nginx脚本,以方便检查本地Nginx否存活更好的切换。Check_nginx.sh脚本内容如下:

#!/bin/bash 
 
#auto check nginx  process 
 
#2012-10-16 wugk 
 
 killall  -0   nginx 
 
 if 
 
 [[ $? -ne 0 ]];then 
 
 /etc/init.d/keepalived stop 
 
 fi 
 

五、Nginx 配置:

在两台Nginx服务器分别新建index.html测试页面,然后启动Nginx服务测试。

访问VIP http://192.9.117.162 如下:

Down192.9.117.160Nginx服务,分别查看keepalived后台日志和ping VIP日志如下:

Oct 16 16:47:48 localhost Keepalived: Stopping Keepalived v1.2.1 (10/16,2012)

Oct 16 16:47:49 localhost Keepalived_vrrp: Terminating VRRP child process on signal

 至此,Nginx+Keepalived高可用WEB架构搭建成功!目前此套系统已经在线上使用,后期会观察使用情况并分享给大家,欢迎多交流!


本文转自 wgkgood 51CTO博客,原文链接:http://blog.51cto.com/wgkgood/1028529

相关文章
|
7月前
|
SQL 监控 关系型数据库
MySQL主从复制:构建高可用架构
本文深入解析MySQL主从复制原理与实战配置,涵盖复制架构、监控管理、高可用设计及性能优化,助你构建企业级数据库高可用方案。
|
8月前
|
运维 监控 搜索推荐
MSE ZooKeeper:Flink 高可用架构的企业级选择
本文深入解析了 Apache Flink 架构中 ZooKeeper 的核心作用,包括 Leader 选举、Checkpoint 管理、作业协调及配置管理等关键功能,并结合金融风控与电商推荐等典型场景,分析了 ZooKeeper 在实际应用中的技术实现。
|
6月前
|
运维 监控 安全
公链开发中的高可用架构设计要点
本指南提供公链高可用架构的可复用流程与模板,涵盖目标拆解、先决条件、分步执行、故障排查及验收标准,结合跨链DApp与量化机器人案例,提升落地效率与系统稳定性。
|
7月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
430 18
|
7月前
|
Ubuntu 安全 应用服务中间件
详细指南:配置Nginx服务器在Ubuntu平台上
以上步骤涵盖了基本流程:从软件包管理器获取 Ngnix, 设置系统服务, 调整UFW规则, 创建并激活服务器块(也称作虚拟主机), 并进行了初步优化与加固措施。这些操作都是建立在命令行界面上,并假设用户具有必要权限(通常是root用户)来执行这些命令。每个操作都有其特定原因:例如,设置开机启动确保了即使重启后也能自动运行 Ngnix;而编辑server block则定义了如何处理进入特定域名请求等等。
707 17
|
7月前
|
存储 监控 NoSQL
Redis高可用架构全解析:从主从复制到集群方案
Redis高可用确保服务持续稳定,避免单点故障导致数据丢失或业务中断。通过主从复制实现数据冗余,哨兵模式支持自动故障转移,Cluster集群则提供分布式数据分片与水平扩展,三者层层递进,保障读写分离、容灾切换与大规模数据存储,构建高性能、高可靠的Redis架构体系。
|
11月前
|
监控 Linux 应用服务中间件
Linux多节点多硬盘部署MinIO:分布式MinIO集群部署指南搭建高可用架构实践
通过以上步骤,已成功基于已有的 MinIO 服务,扩展为一个 MinIO 集群。该集群具有高可用性和容错性,适合生产环境使用。如果有任何问题,请检查日志或参考MinIO 官方文档。作者联系方式vx:2743642415。
3722 57
|
9月前
|
Ubuntu 编译器 C语言
在Ubuntu22.04平台上交叉编译针对Rv1126架构的GCC13.2.0编译器的步骤。
遵循上述步骤,您应该能够在Ubuntu 22.04平台上成功交叉编译适用于RISC-V架构RV1126的GCC 13.2.0编译器,允许您为目标硬件构建应用程序和操作系统组件。
611 10
|
9月前
|
应用服务中间件 Linux 网络安全
使用Nginx免费版与Keepalived实现高可用性High Availablity方案
本文介绍了如何使用Nginx免费版与Keepalived实现高可用性(HA)方案,涵盖环境搭建、Keepalived安装配置、版本升级及主从模式设置。通过虚拟机测试,结合CentOS与宝塔,详细说明VIP配置与服务启动流程,助你构建稳定可靠的Web高可用架构。
|
9月前
|
文字识别 运维 监控
架构解密|一步步打造高可用的 JOCR OCR 识别服务
本文深入解析了JOCR OCR识别服务的高可用架构设计,涵盖从用户上传、智能调度、核心识别到容错监控的完整链路,助力打造高性能、低成本的工业级OCR服务。
397 0
架构解密|一步步打造高可用的 JOCR OCR 识别服务