|      1auto OP 贴个代码: public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) { log.info("==================进来了==================="); String luaScript = buildLuaScript(); ServerHttpRequest request = exchange.getRequest(); String path = request.getPath().value(); List<String> excludUrls = properties.getExcludUrls(); // 路径在不限流列表中,直接跳过 if (CollectionUtils.isNotEmpty(excludUrls) && excludUrls.contains(path)) { return chain.filter(exchange); } String ip = HostUtil.getRequesHost2(request); Thread.sleep(20000); Number count = redissonService.executeLua(luaScript, Collections.singletonList(path+"_"+ip), properties.getCount(), properties.getPeriod()); .....省略部分 } | 
|  |      2devswork      2021-12-07 16:19:04 +08:00 用自带的 RequestRateLimiterGatewayFilterFactory 进行限流 | 
|      3auto OP @devswork 默认用的 redistemplate ,项目中用的 redission ,两者一起用有点问题,所以换了种方案。 | 
|      4auto OP @devswork RequestRateLimiterGatewayFilterFactory 用的 redistemplate | 
|  |      5ouyc      2021-12-07 17:01:43 +08:00 看下 CPU 多少核心的,开始测试时核心是不是都跑满了 | 
|  |      6rapperx2      2021-12-07 17:17:35 +08:00 应该是 cpu 打满导致的 | 
|  |      7zt5b79527      2021-12-07 17:48:03 +08:00 @auto 同一个项目里 redistemplate 、redission 应该可以同时存在,只要别 A 存的数据 B 去取,就应该不影响 | 
|      8securityCoding      2021-12-08 00:09:42 +08:00 via Android lua 脚本发出来 | 
|      9auto OP @zt52875287 当时测试的时候,高并发下 RequestRateLimiterGatewayFilterFactory 用的 redistemplate 似乎一直占着 redis 连接,导致项目中其他地方使用的 redission 重试几次以后超时报错了。想过重写 RequestRateLimiterGatewayFilterFactory 的 RedisRateLimiter ,但是有点麻烦就换了种简单的方法 | 
|      10auto OP @ouyc 电脑 8 核的 cpu ,本地 springboot 自带的 tomcat 映射的线程数等于本机 cpu 核数? |