nginx配置微服务的网关和负载均衡

本文介绍如何使用Nginx配置上游服务器作为微服务网关,并实现负载均衡。通过具体配置示例,详细解释了如何设置上游服务器、补充转发时丢失的host信息等问题,确保API接口和页面访问正常。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

nginx配置微服务的网关和负载均衡

利用Nginx配置上游服务器

配置位置:[http块]配置upstream:

nginx.conf源文件:

user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    include /etc/nginx/conf.d/*.conf;
}

拿出http块代码:

http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;
    
    ######配置聚焦看这里  
    ##上游服务器组 整个组起名字 servername
    upstream servername{
        
        ##每个服务器试用server标签 写上服务地址
        ##微服务网关gateway的访问 这里不要写http 直接ip:port
        server 192.168.31.173:88;
            
    }

    include /etc/nginx/conf.d/*.conf;
}

修改server块反向配置(负载均衡):

server块代码:

server {
    listen       80;
    server_name   gulimall1.com *.gulimall1.com;

    #charset koi8-r;
    #access_log  /var/log/nginx/log/host.access.log  main;

    #######修改聚焦 看这里
    location / {
        ###上游服务器组 整个组起名字 servername
    	proxy_pass   http://servername;
    }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ \.php$ {
    #    root           html;
    #    fastcgi_pass   127.0.0.1:9000;
    #    fastcgi_index  index.php;
    #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
    #    include        fastcgi_params;
    #}

    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    #    deny  all;
    #}
}


备注:
server_name gulimall1.com *.gulimall1.com; 反向代理多个域名写法

与server对应的gateway网关的配置路由配置文件application.yml:

    ## 增加gateway的路由规则  **.xxx.com 任意子域名定向访问值nacos的nacosServerName服务
        - id: host_route
          uri: lb://nacosServerName
          predicates:
            - Host=**.xxx.com,xxx.com
            
       断言规则:复杂的靠前写,简单的往后写。放置覆盖     

坑点:接口通讯 而页面没有成功。

至此api接口可以通讯!但是页面不能正常访问。

[server块] 配置 nginx代理转发至网关的时候会丢失请求的host信息(域名) proxy_set_header Host $host 。而gateway的断言规则

predicates:

-Host=**.xxx.com,xxx.com

是基于域名,导致gateway网关路由分发失败。api的断言规则正常。所以,api接口正常,页面木有打开。

中心作用点:gateway的路由断言规则

修改补充server的location反向代理配置:

    #######修改聚焦 看这里
    location / {
    	#######方向代理转发网关时补充头信息 
  		###补充转发是header的host信息 后续缺少什么这里补充
        proxy_set_header Host $host;
        
        ###上游服务器组 整个组起名字 servername
    	proxy_pass   http://servername;
    }

持此配置完成!

修改后的nginx.conf

user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;
   
    ######配置聚焦看这里  
    ##上游服务器组 整个组起名字 servername
    upstream servername{
        
         ##每个服务器试用server标签 写上服务地址
         ##微服务网关gateway的访问
        server 192.168.31.173:88;
            
    }

    include /etc/nginx/conf.d/*.conf;
}

修改后的server.conf

server {
    listen       80;
    server_name  xxx.com;

    #charset koi8-r;
    #access_log  /var/log/nginx/log/host.access.log  main;

    #######修改聚焦 看这里
    location / {
    	#######方向代理转发网关时补充头信息 
  		###补充转发是header的host信息 后续缺少什么这里补充
        proxy_set_header Host $host
        
        ##上游服务器组 整个组起名字 servername
    	proxy_pass   http://servername;
    }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ \.php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ \.php$ {
    #    root           html;
    #    fastcgi_pass   127.0.0.1:9000;
    #    fastcgi_index  index.php;
    #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
    #    include        fastcgi_params;
    #}

    # deny access to .htaccess files, if Apache's document root
    # concurs with nginx's one
    #
    #location ~ /\.ht {
    #    deny  all;
    #}
}

修改后的gateway断言规则application.yml

spring:
  cloud:
    gateway:
      globalcors:
        corsConfigurations:
          '[/**]':
            allowedOrigins: "*"
      routes:
              ##接口的断言规则
        - id: product_route
          uri: lb://nacosServerName
          predicates:
            - Path=/api/product/**
          filters:
            - RewritePath=/api/(?<segment>.*),/$\{segment}

        ##页面的断言规则
        ## 增加gateway的路由规则  **.xxx.com 任意子域名定向访问值nacos的nacosServerName服务
        - id: gulimall_host_route
          uri: lb://nacosServerName
          predicates:
            - Host=**.xxx.com,xxx.com
      
<think>嗯,用户问的是“NGINX负载均衡什么意思”。首先,我需要确认用户是否了解负载均衡的基本概念。可能用户是刚开始接触服务器配置或者想优化网站性能,所以需要从基础讲起。 NGINX作为反向代理负载均衡器,用户可能想知道它如何分配流量到多个服务器。我需要解释负载均衡的目的,比如提高可用性、处理高流量等。然后结合NGINX的具体配置,比如upstream模块,说明不同的策略如轮询、权重、IP哈希等。 用户可能在部署多个后端服务器,遇到性能问题或单点故障,所以想用负载均衡来分担压力。需要提到常见的应用场景,比如Web应用、API服务,以及如何通过配置实现这些。还要注意是否需要解释一些术语,比如反向代理、健康检查等,但用户可能已经有基础,所以保持简洁。 另外,用户可能对如何配置感兴趣,所以给出一个简单的例子会有帮助。同时,要说明不同策略的适用情况,比如session保持用ip_hash,性能优化用least_conn等。最后,可以提及监控故障排查,比如日志查看或后端服务器健康状态,这样用户知道如何维护负载均衡设置。 确保回答结构清晰,分点解释,避免技术术语过多,用易懂的中文表达。可能用户需要实际应用指导,所以提供配置示例策略选择建议会更好。总结负载均衡的好处,帮助用户理解为什么需要使用它。</think>--- **NGINX 负载均衡** 是通过将客户端请求分发到多个后端服务器,以提升系统性能、可靠性容错能力的技术。以下是分步解释: --- ### **一、核心概念** 1. **目标** - **提高并发处理能力**:通过多台服务器分担流量。 - **避免单点故障**:某台服务器宕机时,自动将请求转发到其他正常节点。 - **动态扩展**:按需增减后端服务器,适应流量变化。 2. **适用场景** - 高并发网站或API服务 - 微服务架构中的服务路由 - 文件下载、视频流等资源密集型应用 --- ### **二、NGINX 负载均衡配置** #### **1. 基础配置** 在 `nginx.conf` 中定义 `upstream` 模块,指定后端服务器组: ```nginx http { upstream backend_servers { # 定义服务器组名称 # 后端服务器列表 server 192.168.1.10:8080; # 服务器1 server 192.168.1.11:8080; # 服务器2 server 192.168.1.12:8080; # 服务器3 } server { listen 80; location / { proxy_pass http://backend_servers; # 将请求转发至服务器组 } } } ``` #### **2. 负载均衡策略** | 策略类型 | 配置示例 | 说明 | |-------------------|----------------------------------|----------------------------------------------------------------------| | **轮询(默认)** | `server 192.168.1.10:8080;` | 请求按顺序分配给每个服务器 | | **加权轮询** | `server 192.168.1.10:8080 weight=3;` | 权重越高,分配请求越多(适合性能不均的服务器) | | **IP哈希** | `ip_hash;` | 根据客户端IP分配固定服务器,维持会话一致性 | | **最少连接** | `least_conn;` | 优先将请求分配给当前连接数最少的服务器 | | **响应时间优先** | 需第三方模块(如`nginx-plus`) | 根据服务器响应时间动态分配 | --- ### **三、关键参数详解** ```nginx upstream backend_servers { server 192.168.1.10:8080 max_fails=3 fail_timeout=30s; # 允许失败3次,超时30秒后标记为不可用 server 192.168.1.11:8080 backup; # 标记为备用服务器(仅当主服务器全宕机时启用) keepalive 32; # 保持长连接数量,减少重复握手开销 } ``` --- ### **四、健康检查** 通过定期探测后端服务器状态,自动剔除故障节点: ```nginx upstream backend_servers { server 192.168.1.10:8080; server 192.168.1.11:8080; # 主动健康检查(需Nginx Plus或第三方模块) health_check interval=5s uri=/health_check; } ``` --- ### **五、实际案例** #### **场景**:电商网站大促期间流量激增 1. **部署**:3台Web服务器处理用户请求。 2. **配置**: ```nginx upstream web_servers { least_conn; # 使用
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

溜达的大象

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值