时间:2021-05-20
1.问题描述
内部系统之间通过Nginx来实现路由转发。
但最近发现有一个系统,经常报502错误,每天达到上百次,完全无法忍受。
2. 原因排查
于是进行排查, 发现配置人员把连接超时时间(server.tomcat.connection-timeout)的单位,理解为秒,实际上是毫秒。
SpringBoot的部分配置如下:
# Tomcatserver: tomcat: uri-encoding: UTF-8 max-threads: 1000 min-spare-threads: 30 connection-timeout: 60 # 错误在这里 port: 18080 servlet: context-path: / max-http-header-size: 102400原来配置的值为 60,如果建立客户端连接的过程中,恰好碰到GC,并且加上GC的暂停时间总共达到60ms以上,Tomcat一看,超时了,就会导致建立连接失败,然后Nginx给客户端返回502错误。
3. 解决办法
修改连接超时时间,例如修改为【server.tomcat.connection-timeout=6000】, 如下所示:
# Tomcatserver: tomcat: uri-encoding: UTF-8 max-threads: 1000 min-spare-threads: 30 connection-timeout: 6000 port: 18080 servlet: context-path: / max-http-header-size: 102400问题解决。
当然,502错误也不止这个原因,需要排查Nginx链路。
总结
到此这篇关于Spring Boot连接超时导致502错误实战案例的文章就介绍到这了,更多相关SpringBoot连接超时导致502错误内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
502BadGateway是指错误网关,无效网关,在互联网中表示一种网络错误。网络连接超时,我们向服务器发送请求,由于服务器当前链接太多,导致服务器方面无法给于
前期工作1.导入mybatis整合依赖org.mybatis.spring.bootmybatis-spring-boot-starter2.1.42.连接数据
mysql数据库存储引擎为MyISAM的时候,在大访问量的情况下数据表有可能会出现被锁的情况,这就会导致用户连接网站时超时而返回502,此时就需要MySQL数据
1.什么是spring-boot-devtoolsspring-boot-devtools是spring-boot项目开发时的一个热部署工具,安装了spring
一)spring-boot-starter命名规则自动配置模块命名规则:xxx-spring-boot,如:aspectlog-spring-boot启动器命名