实现双主模式的反向nginx代理高可用(centos7)

keepalived + nginx实现高可用web集群

集群架构图
web集群拓扑结构图

  1. 首先准备五台centos7系统的虚拟机
  2. 每台机器上安装好nginx
    一键编译安装nginx脚本
  3. 修改两台负载均衡nginx的配置文件

http {
	...
    upstream my_nginx_lb {
    server 192.168.44.132;
    server 192.168.44.133;
    server 192.168.44.134;
    ...
}
    server {
        listen       80;
        server_name  localhost;
        location / {
            root   html;
            index  index.html index.htm;
	    proxy_pass http://my_nginx_lb;
        }
        ...
        }

  1. 分别再两台机器上安装keepalived
yum install keepalived -y
  1. 修改配置文件
    master主机上
global_defs {
   router_id nginx_keepalived
   #vrrp_skip_check_adv_addr
   #vrrp_strict
   #vrrp_iptables
   script_user root  //执行脚本的用户
   enable_script_security
}

vrrp_script check_nginx {
    script "/etc/keepalived/check_nginx.sh"
    interval 2
}


vrrp_instance VI_1 {
    state MASTER
    interface ens33
    virtual_router_id 66
    priority 100
    advert_int 2
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
    192.168.44.100/24 ens33
    }
   track_script {
	check_nginx
}	
}

backup主机上

global_defs {
   router_id nginx_keepalived2
   script_user root
   enable_script_security
}

vrrp_script check_nginx {
    script "/etc/keepalived/check_nginx.sh"
    interval 2
}


vrrp_instance VI_1 {
    state BACKUP
    interface ens33
    virtual_router_id 66
    priority 80
    advert_int 2
    authentication {
        auth_type PASS
        auth_pass 1111
    }
    virtual_ipaddress {
    192.168.44.100/24 ens33
    }
   track_script {
	check_nginx
}	
}

脚本/etc/keepalived/check_nginx.sh,检查maste 主机上nginx是否down机,如果down机停止keepalived,vip飘逸至backup主机

#! /usr/bin/bash

check_result=`ps -C nginx --no-header|wc -l`

if [ $check_result -eq 0 ];then
	killall keepalived
fi
  1. 查看master负载均衡器上的ip,并访问虚拟ip:192.168.44.100
    master上的ip

访问vip

  1. 关闭master上的nginx,继续访问vip
    master上关闭nginx
    发现仍可以继续访问
    在这里插入图片描述
    查看backup主机ip,发现vip漂移至backup

backup的ip信息
至此完成双主高可用web集群

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: CentOS 7上配置Nginx反向代理的步骤如下: 1. 安装Nginx 使用以下命令安装Nginx: ``` sudo yum install nginx ``` 2. 配置Nginx反向代理 打开Nginx配置文件: ``` sudo vi /etc/nginx/nginx.conf ``` 在http块中添加以下内容: ``` server { listen 80; server_name example.com; location / { proxy_pass http://localhost:808; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } } ``` 其中,example.com是你的域名,localhost:808是你要反向代理的服务地址。 3. 重启Nginx 使用以下命令重启Nginx: ``` sudo systemctl restart nginx ``` 现在,你的Nginx反向代理已经配置完成。当访问example.com时,Nginx会将请求转发到localhost:808。 ### 回答2: CentOS 7 是一款广泛使用的开源操作系统,而Nginx是一种轻量级的高性能 Web 服务器和反向代理服务器。 在本文中,我们将讨论如何在CentOS 7上配置Nginx反向代理。 1. 安装 Nginx 在CentOS 7 上安装 Nginx 非常简单,只需使用以下命令即可: sudo yum install nginx 2. 配置反向代理 为了进行反向代理配置,我们需要编辑 /etc/nginx/nginx.conf 文件。打开文件并找到以下位置: http { # ... } 在这个部分的上面添加以下代码: upstream backend { server 192.168.1.100:80; server 192.168.1.101:80; } 这里我们创建了一个名为“backend”的上游服务器块,并添加了两个服务器。这些服务器的 IP 地址和端口号是根据你自己的需求进行配置。 在上面的代码块中,我们使用了 IP 地址,因此正如你所看到的,我们将使用其它服务器上的 Nginx 服务器作为反向代理。接下来,我们需要配置关闭本地缓存、缓存控制、代理请求和日志记录的 Nginx 指令。添加以下代码段: proxy_cache_path /var/cache/nginx levels=1:2 keys_zone=my_cache:10m inactive=60m; proxy_cache_key "$scheme$request_method$host$request_uri$is_args$args"; proxy_cache_valid 200 60m; proxy_cache_bypass $http_pragma; proxy_cache_revalidate on; proxy_ignore_headers Cache-Control Expires; proxy_set_header Cache-Control public; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; access_log /var/log/nginx/access.log; error_log /var/log/nginx/error.log; 最后,我们需要指定我们的 Nginx 服务器作为反向代理。添加以下代码段: server { listen 80; server_name example.com; location / { proxy_pass http://backend; proxy_cache my_cache; } } 在上述代码段中,我们使用一个名为“example.com”的虚拟主机来实现反向代理。我们还将代理传递到名为“backend”的上游服务器集合中,并启用了 Nginx 反向代理服务器缓存。 此外,代码代码段中的 location 必须位于 server 指令块内,我们还配置了存储在缓存中的页面缓存,以及 Nginx 访问和错误日志记录。 最后,重启Nginx服务来应用更改: sudo systemctl restart nginx 恭喜你!现在你可以使用 Nginx 反向代理来扩展你的服务。 ### 回答3: CentOS 7是目前应用最广泛的Linux操作系统之一,集成了很多开源软件,其中包括一个非常流行的Web服务器——Nginx,其强大的反向代理功能被广泛应用于各种场景中,本文将介绍如何在CentOS 7上配置Nginx反向代理。 配置前的准备 在进行配置之前,需要确保已经安装了Nginx和其他必要的依赖软件。可以通过以下命令检查: ``` # 安装epel仓库 yum install epel-release # 安装nginx和必要的依赖 yum install nginx openssl net-tools wget -y ``` 配置Nginx反向代理 在配置Nginx反向代理之前,需要确保已经了解了代理服务器和目标Web服务器的基本架构和访问方式。下面我们将针对一个具体案例进行配置,具体步骤如下: 在Nginx的配置文件中添加反向代理配置 首先需要打开Nginx配置文件`/etc/nginx/nginx.conf`,在`http`段中添加下列代码: ``` http { ... server { listen 80; server_name example.com; location / { proxy_pass http://192.168.1.10:8080; } } ... } ``` 其中,`listen`指定Nginx监听的端口和协议(这里是80端口),`server_name`指定代理服务器的域名或IP地址(这里是example.com),`location`指定反向代理的目标Web服务器地址和端口号(这里是192.168.1.10:8080),注意需要确保目标Web服务器是可访问的。 重启Nginx服务 在修改配置文件之后,需要使用以下命令重启Nginx服务,使得新的配置生效: ``` sudo systemctl restart nginx ``` 测试反向代理是否生效 完成上述步骤之后,可以使用浏览器访问`http://example.com`来测试反向代理是否生效。如果一切正常,则应该能够看到目标Web服务器上的页面。 总结 Nginx反向代理是一个非常强大的功能,可以解决多个Web服务器之间的负载均衡、高可用等问题。本文介绍了在CentOS 7上配置Nginx反向代理的具体步骤,希望对有需要的读者有所帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值