您现在的位置是:数据库 >>正文
详解Tomcat配置参数connectionTimeout意义
数据库8111人已围观
简介环境:springboot2.5.12application.yml配置复制server: port: 8081 ...
环境 :springboot2.5.12
application.yml配置
复制server: port: 8081 tomcat: maxThreads: 10 maxConnections: 10 acceptCount: 1 connectionTimeout: 30001.2.3.4.5.6.7.测试1:
在controller中休眠10s>connectionTimeout
复制@RestController @RequestMapping("/test") public class TestController { @GetMapping("/index") public Object index() { try { System.out.println(Thread.currentThread().getName()) ; TimeUnit.SECONDS.sleep(10) ; } catch (InterruptedException e) { e.printStackTrace(); } return "success" ; } }1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.发现程序能正常地响应 。详解
结论:connectionTimeout参数与具体的配置请求响应时间是没有关系的服务器租用。
测试2:
通过HttpURLConnection发送请求
复制public class HttpURLConnectionDemo { public static void main(String[] args) throws Exception { HttpURLConnection con = (HttpURLConnection) new URL("http://localhost:8081/test/index").openConnection() ; con.setDoInput(true) ; con.setDoOutput(true) ; long start = System.currentTimeMillis() ; InputStream is 参数= con.getInputStream() ; Scanner scan = new Scanner(is) ; while(scan.hasNext()) { System.out.println("接收到内容 :" + scan.next() + "\n耗时 :" + (System.currentTimeMillis() - start)) ; } scan.close() ; con.disconnect() ; con = null ; } }1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.结果 :
图片
结论 :connectionTimeout参数与什么样的客户端做连接请求没关系 。免费模板
测试3:
通过Socket建立连接
复制public class TomcatConnectionTimeoutDemo { public static void main(String[] args) throws Exception { Socket socket = new Socket("127.0.0.1",意义 8081) ; long start = System.currentTimeMillis() ; InputStream is = socket.getInputStream() ; is.read() ; System.out.println(System.currentTimeMillis() - start ) ; } }1.2.3.4.5.6.7.8.9.10.11.运行结果:
图片
差不多3s后程序结束了,也就是详解连接断开了 。高防服务器接着测试:
复制public class TomcatConnectionTimeoutDemo { public static void main(String[] args) throws Exception { Socket socket = new Socket("127.0.0.1",配置 8081) ; long start = System.currentTimeMillis() ; final OutputStream os = socket.getOutputStream() ; new Thread(() -> { Scanner scan = new Scanner(System.in) ; while(scan.hasNext()) { String content = scan.next() ; System.out.println("准备发送:" + content) ; try { os.write(content.getBytes()) ; os.flush() ; } catch (IOException e) { e.printStackTrace() ; } } }).start() ; InputStream is = socket.getInputStream() ; is.read() ; System.out.println(System.currentTimeMillis() - start ) ; } }1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.结果1(什么也不做) :
图片
结果2(控制台不停的输入内容):
图片
程序一开始运行,控制台不停地输入内容,建站模板参数发现程序一直正常 ,意义当停留3秒后在输入内容,详解发现程序又断开了。源码下载配置
结论 :connectionTimeout参数是参数说当客户端与服务器连接以后,如果客户端不输入任何内容,亿华云意义那么超过了connectionTimeout设置的详解时间后连接会被断开。
配置Tags:
转载:欢迎各位朋友分享到网络,但转载请说明文章出处“信息技术视野”。http://www.bziz.cn/news/257d8999653.html
相关文章
攻击者在勒索活动中利用公开的 .env 文件入侵云账户
数据库近日,一场大规模勒索活动利用可公开访问的环境变量文件.env)入侵了多个组织,这些文件包含与云和社交媒体应用程序相关的凭据。“在这次勒索活动中存在多种安全漏洞,包括暴露环境变量、使用长期凭证以及缺乏最 ...
【数据库】
阅读更多网络安全中的人工智能:优点和缺点
数据库我们可以使用人工智能,以比人类更快的速度自动执行复杂的重复性任务。人工智能技术可以对复杂、重复的输入进行逻辑排序。这就是人工智能被用于人脸识别和自动驾驶汽车的原因。但这种能力也为人工智能网络安全铺平了 ...
【数据库】
阅读更多2022年最热门的10大网络安全岗位
数据库由于网络攻击事件频出,因此全球各地的企业组织都在进一步加强安全团队建设。具相关调查数据显示,2013年到2021年,全球网络安全职位的需求量猛增了350%。在此形势下,不仅传统的网络安全职位如渗透测试 ...
【数据库】
阅读更多