Nginx集群与SpringCloud Gateway集成Nacos的配置指南

Nginx集群与SpringCloud Gateway集成Nacos的配置指南

最牛逼的SpringCloudAlibab微服务实战全栈开发

环境准备

  • Nginx 1.18+
  • JDK 8+
  • SpringCloud Gateway 2.2+
  • Nacos Server 1.4+

Nginx集群配置

安装与基础配置

在每台Nginx服务器上安装Nginx,修改nginx.conf主配置文件:

复制代码
worker_processes auto;
events {
    worker_connections 10240;
    use epoll;
}

http {
    upstream gateway_cluster {
        least_conn;
        server 192.168.1.101:9999 weight=5;
        server 192.168.1.102:9999 weight=5;
        keepalive 32;
    }
}

负载均衡策略

添加负载均衡参数:

复制代码
upstream gateway_cluster {
    server 192.168.1.101:9999 max_fails=3 fail_timeout=30s;
    server 192.168.1.102:9999 max_fails=3 fail_timeout=30s;
    hash $request_uri consistent;
}

高并发优化

http块中添加:

复制代码
sendfile on;
tcp_nopush on;
tcp_nodelay on;
keepalive_timeout 65;
client_max_body_size 20m;
gzip on;

SpringCloud Gateway配置

POM依赖

xml 复制代码
<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
    <version>2.2.5.RELEASE</version>
</dependency>
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-gateway</artifactId>
</dependency>

bootstrap.yml

yaml 复制代码
spring:
  application:
    name: api-gateway
  cloud:
    nacos:
      discovery:
        server-addr: 127.0.0.1:8848
        namespace: public
    gateway:
      routes:
        - id: user-service
          uri: lb://user-service
          predicates:
            - Path=/api/user/**
          filters:
            - StripPrefix=1

动态路由配置

创建DynamicRouteConfig.java

java 复制代码
@Configuration
public class DynamicRouteConfig {
    @Bean
    public RouteDefinitionWriter routeDefinitionWriter() {
        return new InMemoryRouteDefinitionRepository();
    }
}

Nacos服务注册发现

Nacos Server配置

修改application.properties

复制代码
server.port=8848
nacos.naming.empty-service.auto-clean=true
nacos.naming.clean.empty-service.interval=60000

服务提供者配置

在服务提供者的application.yml中添加:

yaml 复制代码
spring:
  cloud:
    nacos:
      discovery:
        cluster-name: DEFAULT
        ephemeral: true
        heart-beat-interval: 5000
        heart-beat-timeout: 15000

高并发调优

Gateway线程池配置

application.yml中增加:

yaml 复制代码
server:
  tomcat:
    max-threads: 1000
    min-spare-threads: 50

Nginx健康检查

配置主动健康检查:

复制代码
upstream gateway_cluster {
    zone gateway 64k;
    server 192.168.1.101:9999 slow_start=30s;
    server 192.168.1.102:9999 slow_start=30s;
    health_check interval=5s uri=/health timeout=3s;
}

熔断限流配置

Gateway熔断设置

添加Resilience4J依赖后配置:

yaml 复制代码
spring:
  cloud:
    gateway:
      routes:
        - id: circuitbreaker_route
          uri: lb://user-service
          predicates:
            - Path=/api/user/**
          filters:
            - name: CircuitBreaker
              args:
                name: myCircuitBreaker
                fallbackUri: forward:/fallback

Redis限流配置

集成Redis限流过滤器:

java 复制代码
@Bean
public RedisRateLimiter redisRateLimiter() {
    return new RedisRateLimiter(10, 20, 1);
}

监控与日志

Prometheus监控

添加监控端点:

yaml 复制代码
management:
  endpoints:
    web:
      exposure:
        include: prometheus,health,info
  metrics:
    tags:
      application: ${spring.application.name}

Nginx日志格式化

配置访问日志格式:

复制代码
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 buffer=32k flush=5s;

集群验证步骤

启动Nacos Server后依次启动各服务

通过Nginx访问网关接口验证负载均衡

检查Nacos控制台服务注册状态

使用JMeter进行压力测试,监控各节点资源使用情况

常见问题处理

服务未注册:检查Nacos地址和命名空间配置

502错误:验证Gateway服务是否健康

性能瓶颈:调整Nginx的worker_connections和Gateway线程数

路由失效:确认Nacos配置的自动刷新间隔

相关推荐
鸽鸽程序猿38 分钟前
【JavaEE】【SpringCloud】分布式事务 Alibaba Seata
分布式·spring cloud·java-ee
小马爱打代码1 小时前
Spring Boot:Sentinel 企业级熔断、降级与限流实战
spring boot·后端·sentinel
long3161 小时前
合并排序 merge sort
java·数据结构·spring boot·算法·排序算法
没有bug.的程序员1 小时前
Spring Cloud Sentinel:熔断降级规则配置与分布式流量防线实战终极指南
java·分布式·后端·spring cloud·sentinel·熔断规则·分布式流量防线
李慕婉学姐1 小时前
【开题答辩过程】以《基于SpringBoot Vue的校园后勤管理系统设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
vue.js·spring boot·后端
七夜zippoe1 小时前
API网关设计模式实战 Spring Cloud Gateway路由过滤限流深度解析
java·设计模式·gateway·路由·api网关
汪碧康1 小时前
一文讲解kubernetes的gateway Api的功能、架构、部署、管理及使用
云原生·容器·架构·kubernetes·gateway·kubelet·xkube
梵得儿SHI1 小时前
实战项目落地:微服务拆分原则(DDD 思想落地,用户 / 订单 / 商品 / 支付服务拆分实战)
spring cloud·微服务·云原生·架构·微服务拆分·ddd方法论·分布式数据一致性
咖啡啡不加糖1 小时前
Arthas 使用指南:Java 应用诊断利器
java·spring boot·后端
大佐不会说日语~1 小时前
Docker Compose 部署 Spring Boot 应用 502 Bad Gateway 问题排查与解决
spring boot·docker·gateway·maven·故障排查