当前位置: 首页>編程日記>正文

Java之HTTP长连接

Java之HTTP长连接

一、问题描述

        某应用监控发现线程创建的总数持续上升,且线程的命名为“Keep-Alive-Timer”,存活时间为5秒,导致内存被占用。

二、问题原因

       该应用向外部服务频繁发起HTTP请求,并未使用HTTP长链接,HTTP客户端使用的JDK的默认实现。

三、问题分析以及解决

翻阅资料发现,JDK为了实现 1.HTTP keep-Alive 语义,2,复用SOCKET连接,3.提 升HTTP请求效率等目标。在创建HTTP请求时为HTTP连接维护了缓存,并且创建了 "Keep-Alive-Timer"来管理Socket连接。以下是官方文档中的一段话:

地址:https://docs.oracle.com/javase/8/docs/technotes/guides/net/http-keepalive.html

Demo

下面给出代码执行到17行时的时序图

1.向HttpURLConnection获取输出流。

2.创建HttpClient。

3.检查是否使用缓存(默认开启),从缓存中根据url获取HttpClient。

4.若缓存中没有HttpClient,调用构造函数创建HttpClient。

5.从HttpClient对象中获取输出流并返回。

然后再回来看以下Demo中的代码,看似没有问题,但其实并没有利用好复用Socket连接,默认情况下HttpURLConnect是使用长连接的除非设置"Connection:close",问题的代码在于第21行,关闭输入流,好像我们在编程的时候都应该在使用完资源的时候顺手释放资源,避免造成资源异常占用。但是我们看一段JDK中KeepAliveCache源码。

当我们向缓存(KeepAliveCache)中put一个元素的同时,他会创建一个Keep-Alive-Timer线程,那么这个线程具体做的哪些工作呢?看下面的代码

我们可以看到这个线程每5秒会执行一次:

1.他会遍历缓存中所有的key,拿到ClientVector对象,该对象继承自Stack。

2.接下去遍历所有ClientVector中所有的HttpClient检查该HttpClient对象的空闲时间,若空闲时间超过keep-alive的值,默认是5秒,则回收该客户端并且关闭Socket连接。

所以当我们在上面的Demo中主动的关闭输入流,那么他再创建HttpCleint时会检查当前连接是否可用,若不可用,则从新创建一个HttpClient,因此无法复用Socket连接

 

一个问题在上述描述中我没有提及,就是在何时我们会将HttpClient对象放入缓存中?

实际上是在我们关闭输入流的时候,该动作会调用KeepAliveStream的close方法,最终调用HttpCleint#finished()方法,将该对象放入缓存中。因此正确的使用应该如下图,默认使用长链接情况下,有兴趣可以去查看源码

四、总结

回到我们的问题描述,为什么说我们能看到有存活时间大约5秒的线程了,首先我们的应用中设置头"Connection:close“并且虚拟机默认开启缓存,因此当调用结束时,就会将HttpClient放入缓存中,并且创建"keep-aive-timer"线程。


https://www.fengoutiyan.com/post/14361.html

相关文章:

  • Java连接数据库登录注册
  • 长连接只能有一条连接吗
  • netty 百万级长连接
  • java数据库连接类
  • java长连接框架
  • tomcat长连接
  • java程序怎么连接数据库
  • 长连接系统
  • 鏡像模式如何設置在哪,圖片鏡像操作
  • 什么軟件可以把圖片鏡像翻轉,C#圖片處理 解決左右鏡像相反(旋轉圖片)
  • 手機照片鏡像翻轉,C#圖像鏡像
  • 視頻鏡像翻轉軟件,python圖片鏡像翻轉_python中鏡像實現方法
  • 什么軟件可以把圖片鏡像翻轉,利用PS實現圖片的鏡像處理
  • 照片鏡像翻轉app,java實現圖片鏡像翻轉
  • 什么軟件可以把圖片鏡像翻轉,python圖片鏡像翻轉_python圖像處理之鏡像實現方法
  • matlab下載,matlab如何鏡像處理圖片,matlab實現圖像鏡像
  • 圖片鏡像翻轉,MATLAB:鏡像圖片
  • 鏡像翻轉圖片的軟件,圖像處理:實現圖片鏡像(基于python)
  • canvas可畫,JavaScript - canvas - 鏡像圖片
  • 圖片鏡像翻轉,UGUI優化:使用鏡像圖片
  • Codeforces,CodeForces 1253C
  • MySQL下載安裝,Mysql ERROR: 1253 解決方法
  • 勝利大逃亡英雄逃亡方案,HDU - 1253 勝利大逃亡 BFS
  • 大一c語言期末考試試題及答案匯總,電大計算機C語言1253,1253《C語言程序設計》電大期末精彩試題及其問題詳解
  • lu求解線性方程組,P1253 [yLOI2018] 扶蘇的問題 (線段樹)
  • c語言程序設計基礎題庫,1253號C語言程序設計試題,2016年1月試卷號1253C語言程序設計A.pdf
  • 信奧賽一本通官網,【信奧賽一本通】1253:抓住那頭牛(詳細代碼)
  • c語言程序設計1253,1253c語言程序設計a(2010年1月)
  • 勝利大逃亡英雄逃亡方案,BFS——1253 勝利大逃亡
  • 直流電壓測量模塊,IM1253B交直流電能計量模塊(艾銳達光電)
  • c語言程序設計第三版課后答案,【渝粵題庫】國家開放大學2021春1253C語言程序設計答案
  • 18轉換為二進制,1253. 將數字轉換為16進制
  • light-emitting diode,LightOJ-1253 Misere Nim
  • masterroyale魔改版,1253 Dungeon Master
  • codeformer官網中文版,codeforces.1253 B
  • c語言程序設計考研真題及答案,2020C語言程序設計1253,1253計算機科學與技術專業C語言程序設計A科目2020年09月國家開 放大學(中央廣播電視大學)
  • c語言程序設計基礎題庫,1253本科2016c語言程序設計試題,1253電大《C語言程序設計A》試題和答案200901
  • 肇事逃逸車輛無法聯系到車主怎么辦,1253尋找肇事司機