一次web服务失去响应记录
现象:线上服务无法对接口进行响应,接口全部超时,但是Java进程还是在运行中,jvm GC日志正常。
jstack命令查看线程情况:
大量线程处于BLOCKED状态,等待锁0x00000000cbc9b9c8的释放;
该锁被持有的线程:scheduling-1,是一个异步线程。
通过观察上图,发现锁在getAccessToken方法中被获取,该方法是一个同步方法,由于socket连接长时间阻塞,导致锁无法释放。
代码修改方案:设置http connectionTimeout 和 readTimeout
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架