一、背景
今天业务方调用我们的网关服务报错:
Connection prematurely closed BEFORE response
二、原因分析
三、解决方案
第一步:
增加 SCG 服务的JVM启动参数,调整连接获取策略。
将连接池获取策略由默认的 FIFO(先进先出)变更为 LIFO(后进先出)。
基于 LRU(最近最少使用)算法思想,LIFO 策略可确保当前最活跃的"热点连接"优先被复用,而长期未被使用的空闲连接将自然沉淀至队列末端,便于后续回收机制处理。
-Dreactor.netty.pool.leasingStrategy=lifo
第二步:
修改 SCG服务的空闲连接回收阈值
设置空闲连接的存活时间(maxIdleTime)需满足:
空闲时间阈值 < 后端服务连接超时时间(connectTimeout)。
使连接池的回收动作先于后端服务的强制断连,防止获取到即将被后端主动关闭的"僵尸连接",避免出现请求中途因连接被重置导致的异常
spring:cloud:gateway:httpclient:pool:maxIdleTime: 10000(根据需要调整)
设置之后观察线上环境,没有再发生报错