网络编程之“三次握手四次断开”

简介:       TCP的三次握手四次断开,你了解吗?作为一系统运维人员,如果您掌握了这个原理,就如虎添翼;作为一名系统开发人员,如果您不精通,当你写高并发、高性能的服务器软件时,会感觉内力不足。

      TCP的三次握手四次断开,你了解吗?作为一系统运维人员,如果您掌握了这个原理,就如虎添翼;作为一名系统开发人员,如果您不精通,当你写高并发、高性能的服务器软件时,会感觉内力不足。

客户端和服务端建立TCP连接时,需要完成那些过程?如下图:
                 

说明:

1) 客户端首先和服务端交互三个报文,建立连接。

2) 客户端首先和服务端交互四个报文,断开连接。
模拟场景:

客户端向服务端发送字符串Hello,server!  服务端接收到以后,再讲字符串发送会客户端。
          

1.客户端通过7500端口向服务端的20000端口发送一个SYN同步请求包,展开第一次握手,其中Flags [S]表求数据包的类型为SYN, 即同步请求包,seq字段标识数据包序列号。

2.服务端发送ACK确认包,同时附代一个SYN请求包,在确认客户端同步请求的同时 向客户端发送同步请求,其中Flags [S.]中的点号表示这是个确认包(ACK),S表示它同时又是一个SYN请求包。因为TCP是双工通信协议,连接建立之后双方可以同时收发数据,所以双 方都发送了SYN包请求同步。

3.客户端发送ACK包确认服务端的SYN同步请求,可以看到此时Flags中只有一个小数点,表示这个包只是用来做确认的。

到此为止,三次握手过程就结束了,双方如果都收到了ACK包,则都进入到ESTABLISHED状态,表明此时可以进行数据发送了。

4. 客户端向服务端发送一个数据包,包中的内容就是一个字符串,可以看到此时的Flags标识中有个字母P,意为PUSH DATA,就是发送数据的意思。Length=12,hello,server!

5. 服务端发送ACK确认包,其中Flags[.]中的点表示这是个确认包。

6. 服务端发送ACK确认包,其中Flags[P.]中的点表示这是个确认包,P意为PUSH DATA,发送数据的意思.length=129.

   #define BUFFER_SIZE 128

strncpy(dataBuffer,"Hello,server!",strlen("Hello,server"));

   int errSend = send(sockClient,dataBuffer,strlen(dataBuffer),0);

7. 客户端发送FIN,准备断开连接。

8. 服务器收到FIN包后,对其作出反应,发送ACK包,确认这一方向的连接将关闭,

9. 等服务器的应用程序做好关闭准备时,服务器反方向发送FIN包,请求关闭连接请求,

10. 客户机对服务器发送的请求进行确认,并发送ACK

数据传输的过程:

建立连接后,TCP 协议提供全双工的通信服务,但是一般的客户端/服务器程序的流程是由客户端主动发起请求,服务器被动处理请求,一问一答的方式。因此,服务器从 accept()返回后立刻调用read(),读socket就像读管道一样,如果没有数据到达就阻塞等待,这时客户

端调用write()发送请求给服务 器,服务器收到后从read()返回,对客户端的请求进行处理,

在此期间客户端调用read()阻塞等待服务器的应答,服务器调用write()将处理结 果发回给客

户端,再次调用read()阻塞等待下一条请求,客户端收到后从read()返回,发送下一条请求,

如此循环下去。

如果客户端没 有更多的请求了,就调用close()关闭连接,就像写端关闭的管道一样,服务

器的read()返回0,这样服务器就知道客户端关闭了连接,也调用 close()关闭连接。注意,

任何一方调用close()后,连接的两个传输方向都关闭,不能再发送数据了。如果一方调用

shutdown()则连接处于半关闭状态,仍可接收对方发来的数据。


相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
目录
相关文章
|
网络协议 开发工具
网络编程之 listen()函数的使用与三次握手的理解
listen()函数 在进入我们的函数讲解前大家再回顾一下编写服务器端的流程
575 0
|
网络协议 安全 Java
网络编程、网络编程的三要素、TCP/UDP通信、三次握手和四次挥手
网络编程、网络编程的三要素、TCP/UDP通信、三次握手和四次挥手
297 1
网络编程、网络编程的三要素、TCP/UDP通信、三次握手和四次挥手
|
Ubuntu 网络协议 Windows
ubuntu 16.04无法连接网络;双系统无法上网;连接已断开,你现在处于断开状态
ubuntu 16.04无法连接网络;双系统无法上网;连接已断开,你现在处于断开状态
550 0
|
缓存 网络协议 程序员
网络编程(一)计算机网络体系结构介绍(tcp三次握手,四次挥手)
网络编程(一)计算机网络体系结构介绍(tcp三次握手,四次挥手)
262 0
|
网络协议 Java 数据安全/隐私保护
什么是网络编程?Java如何实现?三次握手和四次挥手?
什么是网络编程?Java如何实现?三次握手和四次挥手?
194 0
|
网络协议 Oracle Java
【Java】从Java代码到网络编程,三次握手又该如何理解
文章目录 1 网络编程的相关概念 1.1 网络、网络通信与IP地址 1.2 IPv4与IPv6 1.3 域名和端口号 2 网络协议 2.1 网络通信协议 2.2 TCP和UDP 2.3 三次握手 写在最后
【Java】从Java代码到网络编程,三次握手又该如何理解
|
Kubernetes 前端开发 应用服务中间件
k8s网络诊断之记一次ingress websocket长链接被断开的问题排查
某用户反馈通过ingress建立的websocket长链接,总是会被断开,影响他们的研发平台的使用,导致业务上线受阻
4395 0
|
存储 NoSQL Redis
Redis主从复制的时候网络断开怎么解决
Redis主从复制的时候网络断开怎么解决
506 0
Redis主从复制的时候网络断开怎么解决
断开现有的网络共享映射_彭世瑜
断开现有的网络共享映射_彭世瑜
244 0
断开现有的网络共享映射_彭世瑜
|
Shell Linux Docker
Docker 根据网络名称批量断开与之相连的容器shell实现
Docker 根据网络名称批量断开与之相连的容器shell实现
343 0