0

0

Java面试——TCP三次握手与四次挥手详解

月夜之吻

月夜之吻

发布时间:2026-03-19 09:58:02

|

363人浏览过

|

来源于php中文网

原创

TCP三次握手影响connect()阻塞时机,四次挥手决定TIME_WAIT状态;Socket编程需理解连接生命周期对阻塞、复用及Netty执行时机的影响。

java面试——tcp三次握手与四次挥手详解

Java面试中问TCP三次握手和四次挥手,本质不是考你背网络协议细节,而是看你是否理解Socket编程背后的连接生命周期,以及它如何影响ServerSocketInputStream阻塞、连接复用(如HTTP/1.1 keep-alive)、甚至Netty的ChannelHandler执行时机。

为什么connect()会阻塞?三次握手到底卡在哪一步

Java里调用new Socket(host, port)时,底层会触发connect()系统调用。这个调用在默认阻塞模式下,要等到三次握手完成(即收到服务端发来的SYN+ACK,并回传ACK)才返回。如果中间丢包、服务端没监听、防火墙拦截,就会卡在SYN超时重传阶段(Linux默认约21秒)。

常见误判:以为“连不上”是代码写错了,其实是网络层或服务端未就绪。

  • 可通过Socket.setSoTimeout(int)设置连接超时,但注意:这是对connect()本身的超时控制,不是后续读写的超时
  • 非阻塞模式需配合Selector使用,configureBlocking(false)connect()立即返回,再轮询isConnectionPending()finishConnect()
  • 抓包验证时,看到客户端只发了SYN、没收到SYN+ACK,基本可定位为服务端问题或网络中断

close()之后为什么还有TIME_WAIT?四次挥手中哪个包决定状态迁移

调用socket.close()时,JVM会触发底层close()系统调用,发起FIN报文(主动关闭方),进入FIN_WAIT_1状态。对方回ACK后进FIN_WAIT_2;等对方也发FIN,本地方回ACK,才进入TIME_WAIT——这个2MSL等待期由操作系统强制执行,Java无法绕过。

立即学习Java免费学习笔记(深入)”;

MedPeer自然科学基金
MedPeer自然科学基金

科研申报与成果分析的智能数据引擎

下载

关键点:TIME_WAIT是**主动关闭方**的状态,且必须由它发出最后一个ACK。如果应用频繁创建短连接(如每个HTTP请求都新建Socket),大量TIME_WAIT会占满本地端口(65535个),导致java.net.BindException: Address already in use

  • 避免方式:复用Socket(如HTTP连接池)、启用SO_LINGER(慎用,可能丢数据)
  • SO_LINGER设为0时,close()会直接发RST,跳过四次挥手,但对方read()会立刻抛IOException
  • Linux可通过/proc/sys/net/ipv4/tcp_tw_reuse允许TIME_WAIT套接字被快速重用(仅对客户端有效)

Java里哪些操作会隐式触发挥手?shutdownOutput()close()的区别

socket.close()会同时关闭读写流,发送FIN,走完整四次挥手。socket.shutdownOutput()则只关闭输出方向:清空发送缓冲区,发FIN,但输入流仍可用——此时对方write()不会失败,但read()会返回-1(表示EOF)。

这个特性常用于半关闭场景,比如HTTP上传大文件时,客户端先shutdownOutput()告诉服务端“数据发完了”,继续监听服务端响应;而close()一调,双方都断了,响应可能收不到。

  • shutdownInput()基本不用:它只是让本地read()立即返回-1,不发任何报文,对连接状态无影响
  • 一旦调用shutdownOutput(),再往OutputStream写就会抛SocketException: Socket is closed
  • Netty中ctx.close()对应FIN,ctx.writeAndFlush(Unpooled.EMPTY_BUFFER).addListener(ChannelFutureListener.CLOSE)才是优雅半关闭
Socket socket = new Socket("example.com", 80);
OutputStream out = socket.getOutputStream();
out.write("GET / HTTP/1.1\r\nHost: example.com\r\n\r\n".getBytes());
socket.shutdownOutput(); // 发FIN,但还能读响应
InputStream in = socket.getInputStream();
int b;
while ((b = in.read()) != -1) { // 正常读取响应体
    System.out.write(b);
}
socket.close(); // 最终释放资源

真正容易被忽略的是:TIME_WAIT不是Java问题,是TCP协议栈行为;而面试追问“怎么优化”,其实在考你是否分得清应用层控制(复用连接)和内核参数调优(tcp_tw_reuse)的边界。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1111

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

621

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

356

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

235

2025.08.29

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

451

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

606

2023.08.10

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

507

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

458

2023.11.14

bootstrap安装教程
bootstrap安装教程

本专题整合了bootstrap安装相关教程,阅读专题下面的文章了解更多详细操作教程。

22

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号