对于网关的理解-Gateway

因为在使用微服务的时候,会有多端请求。会产生以下问题:

1.客户端需要记住每一个微服务的url

2.主机端口也会直接暴露

3.每一个微服务都需要认证

4.存在跨域问题

所以网关可以解决统一访问、隐藏真实的服务器地址、网关进行统一认证、解决跨域问题、限流等问题。

所以网关只需要处理网址,基本上只需要处理配置文件和启动类

复制代码
spring:
  cloud:
    gateway:
      globalcors:
        cors-configurations:
          '[/**]': #匹配向网关发送的所有请求
            allowedOrigins: "*" #任何一个服务器都允许跨域操作
            allowedMethods:
              - POST
              - GET
              - DELETE
              - PUT

      routes:  #  路由
        - id: chessgame   #自定义路由唯一标识
          uri: lb://USER  #  网关管理的访问地址
          predicates:  #  过滤的路径(只有路径匹配了url请求,网关才会处理请求)
            - Path=/user/**
          filters:  # 可以对于url的请求进行拦截处理
            - PrefixPath=/api #所有请求到网关的路径前添加这段内容
            - StripPrefix=1 #忽略请求路径中的设定数值内容路径层级数量  #在真是使用时就关闭忽略
            #网关限流配置
#            - name: RequestRateLimiter #限流工具类的名称
#              args:
#                key-resolver: "#{@ipKeyResolver}"   # 使用 SpEL表达式按名称引用 bean
#                #每秒钟只能处理一个请求,测试效果明显
#                redis-rate-limiter.replenishRate: 1 #令牌桶每秒填充速率
#                redis-rate-limiter.burstCapacity: 1 #令牌桶总容量

将启动类发送到注册中心去

XML 复制代码
  <!--网关,与web有冲突的-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
        </dependency>
    <!--实现令牌桶-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-redis-reactive</artifactId>
        </dependency>

使用gateway的限流工具需要进行在启动类中添加bean

java 复制代码
   /***
     * IP地址进行限流
     *@return
     */
    @Bean(name="ipKeyResolver")
    public KeyResolver userKeyResolver(){
        return new KeyResolver(){
            @Override
            public Mono<String> resolve(ServerWebExchange exchange){
                //获取远程客户端IP
                String hostName = exchange.getRequest().getRemoteAddress().getAddress().getHostAddress();
                return Mono.just(hostName);
            }
        };
    }
相关推荐
longerxin20202 分钟前
阿里云AlmaLinux操作系统允许root登录配置步骤
linux·服务器·阿里云
xuanwenchao15 分钟前
ROS2学习笔记 - 2、类的继承及使用
服务器·笔记·学习
Byron Loong37 分钟前
【网络】Python 怎么做TCP通讯
网络·python·tcp/ip
孙同学_1 小时前
【项目篇】高并发服务器 - HTTP服务器组件拆解,从Util到HttpServer
运维·服务器·http
裕工实验室1 小时前
功率模块为什么一定要用陶瓷PCB?从结构到选材一篇讲清(附DPC / DBC / AMB选型逻辑)
网络·硬件工程·pcb工艺·材料工程
Sherry Wangs1 小时前
服务器 CUDA版本升级指南
运维·服务器
CQU_JIAKE1 小时前
4.17[Q]
java·linux·服务器
SilentSamsara1 小时前
HTTP/1.1 到 HTTP/3:每代协议解决了什么问题
网络·网络协议·tcp/ip·http·https
上海云盾-小余2 小时前
DDoS 攻击应急响应全流程:从告警触发到业务恢复的黄金 15 分钟
服务器·安全·游戏·ddos
LXY_BUAA2 小时前
《ubuntu22.04》_新系统的配置_20260418
linux·运维·服务器