温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么解决RestTemplate未使用线程池的问题

发布时间:2021-06-22 15:26:10 来源:亿速云 阅读:488 作者:chen 栏目:开发技术

这篇文章主要讲解了“怎么解决RestTemplate未使用线程池的问题”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么解决RestTemplate未使用线程池的问题”吧!

一、问题描述

现场出现springboot服务卡死,无法打开页面现象。

初步分析为服务中使用RestTemplate通信框架,但未使用连接池,如果通信抛出异常(连接失败),连续运行一定时间,导致线程飙升,资源耗尽,服务程序宕机。

二、问题再现

模拟无法通信的微服务地址,修改连接2s/次,启动三个微服务demo进行通信,连续测试2小时,现象可再现:

详细如下图:

启动时线程数:

怎么解决RestTemplate未使用线程池的问题

连接异常提示:

怎么解决RestTemplate未使用线程池的问题

怎么解决RestTemplate未使用线程池的问题

线程飙升:

怎么解决RestTemplate未使用线程池的问题

大量未关闭线程:

怎么解决RestTemplate未使用线程池的问题

线程dump信息:

"http-nio-8081-exec-120" #216 daemon prio=5 os_prio=0 tid=0x000000002b0f9800 nid=0x4a28 runnable [0x0000000030349000]
   java.lang.Thread.State: RUNNABLE
       at java.net.SocketInputStream.socketRead0(Native Method)
        at java.net.SocketInputStream.socketRead(SocketInputStream.java:116)
    …
       at org.springframework.http.client.AbstractClientHttpRequest.execute(AbstractClientHttpRequest.java:53)
        at org.springframework.web.client.RestTemplate.doExecute(RestTemplate.java:737)
        at org.springframework.web.client.RestTemplate.execute(RestTemplate.java:672)
        at org.springframework.web.client.RestTemplate.getForObject(RestTemplate.java:313)

三、问题分析:

主动健康检查时,RestTemplate默认情况下不使用连接池,每次调用都会打开一个新的本地临时端口和一个新连接,如果通信异常,会导致连接不被回收,持续通信,它会不断新建线程,并且很快突破本地可用端口限制范围,导致服务卡死。

四、解决方案:

使用RestTemplate连接池,设置ReadTimeout、ConnectTimeout超时时间,进行连接回收。

五、回归验证:

修改后,验证如下:

初始线程:

怎么解决RestTemplate未使用线程池的问题

测试3小时结束时线程:

怎么解决RestTemplate未使用线程池的问题

线程池线程未增加,状态交替

怎么解决RestTemplate未使用线程池的问题

感谢各位的阅读,以上就是“怎么解决RestTemplate未使用线程池的问题”的内容了,经过本文的学习后,相信大家对怎么解决RestTemplate未使用线程池的问题这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI