Nginx_反向代理配置+负载均衡配置

反向代理

概念介绍

正向代理:

  • 代理客户端
  • 例如用户无法访问外网而代理服务器能访问外网,则用户可通过访问代理服务器从而访问外网。

反向代理:

  • 代理服务端。
  • 代理服务器(如Nginx服务器)接收到来自客户端的请求后将请求分发到应用服务器。在这个过程中,代理服务器默认以轮询的方式代理,而应用服务器的ip和端口号对客户端是透明的。

反向代理的应用场景:

  • 代理业务服务服务器
  • 代理文件存储服务器

简单配置

反向代理需要在配置文件的http块中配置,如下所示:

txt 复制代码
http {
    include       mime.types;
    default_type  application/octet-stream;

    sendfile        on;

    keepalive_timeout  65;
    
    # upstearm块用于设置反向代理,后面跟着代理名称(可自定义)
    #文件服务
    upstream fileserver{
    server 192.168.101.65:9000;
    }
    
    #后台网关
    upstream gatewayserver{
    server 127.0.0.1:63010 ;
    server 127.0.0.1:63011 ;
  }
   
    server {
       
        listen       80;
	   #虚拟主机的域名
        server_name  www.yyds.cn localhost;     
        
	    #配置反向代理的url路径, 当输入域名/api/时会请求http://gatewayserver/处的服务
        location /api/ {
		# 此处名字要与upstream处设置的名字相同
                proxy_pass http://gatewayserver/;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }
    }

}

负载均衡

概念介绍

在集群化部署时,由于一个软件应用或服务被部署到多台应用服务器上,所以需要判断将客户端请求分发给哪台服务器处理。而负载均衡的目的就是对客户端请求进行合理分发。

简单配置

在配置文件的upstream块中进行配置

txt 复制代码
#后台网关
    upstream gatewayserver{
    # weight设置权重,服务器的权重越大分配到的请求越多
    server 127.0.0.1:63010 weight=10;
    server 127.0.0.1:63011 weight=5;
    # down,该台服务器不提供服务
    server 127.0.0.1:63011 weight=5 down;
    # backup, 备用服务器,在其他服务器出现故障时提供服务
    server 127.0.0.1:63011 weight=5 backup;
    }   

其他配置

  • ip_hash: 判断来源的的ip地址,相同的ip会下发到相同的服务器。但是若用户的ip地址变化则无法保持会话。比如用户在使用手机时从一个ip地址变换到另一个ip地址。
  • least_conn: 将用户请求分配到接收请求次数最少的服务器
  • fair: 根据后端服务器的响应时间转发请求
  • url_hash: 定向流量转发。根据用户访问的url转发到相应服务器。常用于访问固定资源。如根据url定位到用户要访问的文件在哪台服务器上。
相关推荐
瀚高PG实验室8 小时前
nginx中配置数据库连接
运维·数据库·nginx·瀚高数据库
小句11 小时前
Nginx 配置完整指南
运维·nginx
学不完的11 小时前
Zrlog面试问答及问题解决方案
linux·运维·nginx·unity·游戏引擎
学不完的12 小时前
ZrLog 博客系统部署指南(无 War 包版,Maven 构建 + 阿里云镜像优化)
java·linux·nginx·阿里云·maven
伟大的大威12 小时前
彻底解决 Nginx Proxy Manager 反代 MinIO 报 SignatureDoesNotMatch (S3 签名不匹配) 的终极方案
运维·nginx·minio
秦渝兴12 小时前
从手工高可用到全容器化:我的 Keepalived+Nginx+Tomcat+MySQL 项目迁移实战
linux·运维·mysql·nginx·容器·tomcat
yiyaozjk12 小时前
RabbitMQ HAProxy 负载均衡
rabbitmq·负载均衡·ruby
桌面运维家12 小时前
DNS负载均衡:架构、优化与故障排查指南
运维·架构·负载均衡
学不完的12 小时前
ZrLog 高可用反向代理架构
linux·运维·nginx·架构·负载均衡
半路_出家ren12 小时前
Nginx基础学习
运维·网络·网络协议·学习·nginx·网络安全