关于一些TCP IP协议的解释ps:来自于网络的收集
发布日期:2021-06-29 04:56:04 浏览次数:3 分类:技术文章

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

两台机器之间该如何通信呢,就需要制定各种各样的协议了
TCP/IP协议族中有一个重要的概念是分层,TCP/IP协议按照层次分为以下四层。
应用层、:HTTP协议 FTP文件传输协议,DNS 域名系统
网络层、主要是处理网络上流动的数据包在众多的选项内选择一条传输路线
传输层、主要是 TCP(传输控制协议) UDP(用户数据协议) 协议的控制
数据链路层、处理网络连接的硬件部分
如果说IP协议是找到对方的详细地址。那么TCP协议就是把安全的把东西带给对方
为了确保信息能够确保准确无误的到达,TCP采用了著名的三次握手策略(three-way handshaking)
第一次握手:客户端发送syn包(syn=x)到服务器,并进入SYN_SEND状态,等待服务器确认;
第二次握手:服务器收到syn包,必须确认客户的SYN(ack=x+1),同时自己也发送一个SYN包(syn=y),即SYN+ACK包,此时服务器进入SYN_RECV状态;
第三次握手:客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK(ack=y+1),此包发送完毕,客户端和服务器进入ESTABLISHED状态,完成三次握手。
      握手过程中传送的包里不包含数据,三次握手完毕后,客户端与服务器才正式开始传送数据。理想状态下,TCP连接一旦建立,在通信双方中的任何一方主动关闭连接之前,TCP 连接都将被一直保持下去。
与建立连接的“三次握手”类似,断开一个TCP连接则需要“四次挥手”。
第一次挥手:主动关闭方发送一个FIN,用来关闭主动方到被动关闭方的数据传送,也就是主动关闭方告诉被动关闭方:我已经不会再给你发数据了(当然,在fin包之前发送出去的数据,如果没有收到对应的ack确认报文,主动关闭方依然会重发这些数据),但是,此时主动关闭方还可以接受数据。
第二次挥手:被动关闭方收到FIN包后,发送一个ACK给对方,确认序号为收到序号+1(与SYN相同,一个FIN占用一个序号)。
第三次挥手:被动关闭方发送一个FIN,用来关闭被动关闭方到主动关闭方的数据传送,也就是告诉主动关闭方,我的数据也发送完了,不会再给你发数据了。
第四次挥手:主动关闭方收到FIN后,发送一个ACK给被动关闭方,确认序号为收到序号+1,至此,完成四次挥手
DNS:DNS(Domain names System) 和HTTP协议一样是处于应用层的服务,提供域名到IP地址之间的解析服务。

转载地址:https://blog.csdn.net/zhang_linhua/article/details/73864207 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:安卓中关于Handler机制的浅谈
下一篇:关于OkHttp的用法

发表评论

最新留言

初次前来,多多关照!
[***.217.46.12]2024年04月18日 21时49分11秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章