博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
TCP&UDP基础
阅读量:6515 次
发布时间:2019-06-24

本文共 2020 字,大约阅读时间需要 6 分钟。

TCP

TCP/IP是一种网络通讯协议,而socket则是TCP/IP网络最为通用的API,即一种应用程序接口,称为套接字。TCP是面向连接的协议,在进行数据收发前必须连接,且在收发时必须保持该连接。在TCP层,有个FLAGS字段,这个字段有以下几个标识:SYN, FIN, ACK, PSH, RST, URG。其中SYN(synchronous)表示要求建立连接,ACK(acknowledgement)表示应答,FIN(finish)表示要求关闭连接,PSH(push)表示有数据传输,RST(reset)表示连接重置,URG(urgent)表示紧急。

1. TCP的三次握手连接:

第一次握手:客户端发送SYN包(SYN = 1)到服务器,随机生成Sequence number = X,并进入SYN_SEND状态,等待服务器确认;

第二次握手:服务器收到SYN包,必须确认客户的SYN(SYN = 1),同时自己也发送一个ACK包(ACK = X+1),即SYN+ACK包,同时随机生成一个Sequence number = Y,此时服务器进入SYN_RECV状态;

第三次握手:客户端收到服务器的SYN + ACK包,向服务器发送确认包ACK(ACK = Y+1),同时随机生成一个Sequence number = Z,此包发送完毕,客户端和服务器进入ESTABLISHED状态,完成三次握手。

其中握手过程中传送的包里不包含数据,三次握手完毕后,客户端与服务器才正式开始传送数据。

2. TCP的四次挥手断开连接

第一次挥手:主动方发送FIN + ACK包到被动方,随机生成Sequence number = X,并进入FIN_WAIT_1状态,等待被动方确认;

第二次挥手:被动方接收到主动方的FIN + ACK包后,并返回ACK(ACK = X + 1)包,并随机生成Sequence number = Z发送给主动方,并进入CLOSE_WAIT状态,此时主动方接收到信息后随即进入FIN_WAIT_2状态;

第三次挥手:被动方发送FIN+ACK(ack = X + 1)包给主动方,并随机生成Sequence number = Y,并进入LAST_ACK状态;

第四次挥手:主动方接收到被动方的FIN+ACK包以后,向被动方发送ACK(ack = Y+1)包,随即自身进入TIME_WAIT状态,被动方接收到ACK包后进入CLOSED状态,紧接着主动方等待2MSL后也进入CLOSED状态,至此连接断开。

 

 

UDP

UDP(User Datagram Protocol)用户数据报协议,它在OSI模型的传输层,OSI模型的传输层有UDP协议,TCP协议和刚开发出来的一种新的协议SCTP。如果网络中两个主机上的应用程序要相互通信,其一要知道彼此主机的IP,其二要知道主机中运行程序可监听的端口。因为同一主机上的程序使用网络是通过端口号来区分的。因此为了使用UDP,我们需要一对套接字地址:客户端套接字地址和服务器套接字地址。

UDP提供无连接服务。客户端向服务端发送数据时不必先建立连接。客户端创建一个套接字并向服务器发送一个数据报,然后客户端可以立即用这个套接字向另外一个服务器发送其它数据。不能确保UDP数据报最终到达目的地。UDP对接收的数据报不发生确认,发送端不知道数据是否被正确接收,也不会重发数据。UDP传输数据较TCP快,占用系统资源少。

TCP和UDP的区别

1. TCP是面向链接的,虽然说网络的不安全不稳定特性决定了多少次握手都不能保证连接的可靠性,但TCP的三次握手在最低限度上(实际上也很大程度上保证了)保证了连接的可靠性。而UDP不是面向连接的,UDP传送数据前并不与对方建立连接,对接收到的数据也不发送确认信号,发送端不知道数据是否会正确接收,当然也不用重发,所以说UDP是无连接的、不可靠的一种数据传输协议。

2. 也正由于1所说的特点,使得UDP的开销更小数据传输速率更高,因为不必进行收发数据的确认,所以UDP的实时性更好。知道了TCP和UDP的区别,就不难理解为何采用TCP传输协议的MSN比采用UDP的QQ传输文件慢了,但并不能说QQ的通信是不安全的,因为程序员可以手动对UDP的数据收发进行验证,比如发送方对每个数据包进行编号然后由接收方进行验证啊什么的,即使是这样,UDP因为在底层协议的封装上没有采用类似TCP的“三次握手”而实现了TCP所无法达到的传输效率。

3. 人们通常用电话连线来说明TCP协议,而UDP协议,则常常用邮递来做比喻。

 

TCP

UDP

是否连接

面向连接

面向非连接

传输可靠性

可靠

不可靠

应用场合

传输大量数据

少量数据

速度

转载于:https://www.cnblogs.com/ChenZhongzhou/p/5804672.html

你可能感兴趣的文章
国外黑客成功在iPhone7上越狱iOS10
查看>>
写个软件来防止服务器网站CPU百分百
查看>>
工业物联网底层数据平台 Tulip 获1300万美元A轮融资
查看>>
2017年中国智慧城市PPP模式发展情况分析
查看>>
治理校园网络安全离不开威胁情报大数据
查看>>
和联想玩耍的超融合厂商不只一两家
查看>>
网络安全保卫战不容有失
查看>>
看透CRM五大理念,用好经营利器
查看>>
Facebook将指导计算机学习用户发表的任何内容
查看>>
丢三落四:企业上云却忘记了云安全
查看>>
智能城市里,“公共电话亭”的存在意味着什么?
查看>>
要求将个人数据存于境内服务器:俄政府决定封杀LinkedIn
查看>>
Equinix公司在香港的数据中心增加了1400个机架
查看>>
别说你不知道大数据基金
查看>>
关于性能比较的应用误区
查看>>
协同是商业智能的未来
查看>>
服务器如何进行加密设置
查看>>
追寻能源本质:储存的进化
查看>>
Linux学习—fork用法
查看>>
JVM分代垃圾回收策略的基础概念
查看>>