资讯专栏INFORMATION COLUMN

tcp的认知和应用

chanthuang / 3377人阅读

摘要:表示首部的长度为字节除掉和刚好字节。差错控制,校验和的计算包括首部数据和其它填充字节。如果两次校验和一致说明数据是正确的,否则将认为数据被破坏,接收端将丢弃该数据。此时包的序号被设定为收到的确认号,而响应号则为。

什么是tcp tcp定义

tcp是网络七层模型当中传输层的协议,由IETF的RFC 793定义,是面向连接的、可靠的、基于字节流的通信协议。而传输层位于七层模型的中间,下面是网络层,上面的话有应用层,承上启下,地位还是很重要的。在传输层中还有一种协议udp(无连接、不保证可靠性)。相比来说tcp有以下特点

传输可靠,数据丢失有重传机制

数据分段打包传输,对每个数据编号,控制顺序

流量控制,避免拥塞,因为TCP连接双方有固定大小缓冲空间。TCP的接收端只允许另一端发送接收端缓冲区所能接纳的数据。

tcp数据包格式


针对上面图中的结构划分,下面进行下解释

source port 和 destination port 都是16位,计算机端口识别访问那个服务, 其中source port 是随机的,而destination port决定接受方由那个程序来接受并且因为是16位,所以说程序的最大端口号65535

sequence Number 是发送数据包中的第一个字节的序列号,假设当前的序列号为 s,发送数据长度为 l,则下次发送数据时的序列号为 s + l。在建立连接时通常由计算机生成一个随机数作为序列号的初始值

Acknowledgment Number 它等于下一次应该接收到的数据的序列号。可以认为这个位置以前所有的数据都已被正常接收。
header length TCP 首部的长度,单位为 4 字节。如果没有可选字段,那么这里的值就是 5。表示 TCP 首部的长度为 20 字节(除掉data和option,刚好20字节)。
reserved

URG表示Urgent Pointer字段有意义

ACK表示Acknowledgment Number字段有意义

PSH表示有 DATA数据传输

RST表示复位TCP连接

SYN表示SYN报文(在建立TCP连接的时候使用)

FIN表示没有数据需要发送了(在关闭TCP连接的时候使用)

Windows 表示接收缓冲区的空闲空间,16位,用来告诉TCP连接另一端自己能够接收的最大数据长度,流量控制的机制就基于此。
Checksum 差错控制,TCP校验和的计算包括TCP首部、数据和其它填充字节。在发送TCP数据段时,由发送端计算校验和,当到达目的地时又进行一次检验和计算。如果两次校验和一致说明数据是正确的,否则将认为数据被破坏,接收端将丢弃该数据。
Urgent 是紧急指针,16位,只有URG标志位被设置时该字段才有意义,表示紧急数据相对序列号(Sequence Number字段的值)的偏移。

tcp三次握手


说明 上面是一个我写的测试demo,是一个普通的http请求,下面我们抓包分析一下tcp三次握手的细节


说明 第一次握手client通过发送一个SYN标识位和Sequence Numbers(同步序列号)的数据段给server请求连接,通过该数据段告诉server希望建立连接

说明 第二次握手是server用一个确认应答ACK标志位和Acknowledgment Number告诉client收到了数据段,同时自己也发送一个syn包(syn标志位和Sequence Numbers)。

说明 第三次客户端收到服务器的SYN+ACK包,向服务器发送确认包ACK,此包发送完毕,客户端和服务器进入ESTABLISHED(TCP连接成功)状态,完成三次握手。
说明 三次握手完毕,链接通道建立成功,下面开始正式数据传输

针对上面整个过程下面再来一幅图详细总结说明下

客户端通过向服务器端发送一个SYN来表明希望建立连接,作为三次握手的一部分。客户端把这段连接的序号设定为随机数c。

服务器端应当为一个合法的SYN回送一个SYN/ACK。ACK的确认码应为c+1,SYN/ACK包本身又有一个随机产生的序号s。

最后,客户端再发送一个ACK。当服务端收到这个ACK的时候,就完成了三次握手,并进入了连接创建状态。此时包的序号被设定为收到的确认号c+1,而响应号则为s+1。

tcp四次断开


下面描述下整个过程,过程和三次握手机制一样,也是用一些标志位来实现断开的过程,详细步骤过程不在图形化,因为需要四幅步骤图,太占篇幅了,下面根据上面的流程图大致解释说明一下。

client发送FIN标志位,表示出要断开连接的请求的含义

server进行响应,发送ack标识,表示确认收到断开连接请求

server 发送FIN标志位,提出反方向的关闭要求

client 发送ack标志位,标识确认收到的主机B的关闭连接请求

tcp应用场景

适合对传输数据要求比较可靠的地方,例如常见的ftp,http,https,smtp等等这些应用层的协议都是基于tcp的封装;还有实战中常见套接字编程,可以用来开发浏览器通信模块,以及p2p的下载工具等等,这些底层都是都是基于tcp协议。

如何使用tcp

协议只是一个规范,实现形式有多种,具体而言在node当中使用的话如下形式

let net = require("net");
let path = require("path");
let ws = require("fs").createWriteStream(path.join(__dirname, "msg.txt"));
let server = net.createServer(function (socket) {
    socket.pipe(ws, { end: false });

});
server.listen(8080);
创建一个tcp服务器监听8080端口,并将接受的数据存储到msg.txt文件中,上面的socket是一个双工流,既可写又可以读,下面是测试的输出结果


说明 上面只是一个简单的实例,更多用法,可以参考node当中net模块

参考链接
https://zh.wikipedia.org/wiki...
http://nodejs.cn/api/
http://www.freebuf.com/column...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/107392.html

相关文章

  • HTTP1.1 Keep-Alive到底算不算长连接?

    摘要:在基础架构部沉浸了半年,有一些认知刷新想和童靴们交代一下,不一定全面,仅代表此时的认知,也欢迎筒靴们提出看法。本文聊一聊口嗨用语长连接短连接,文章会按照下面的思维导图来讲述在基础架构部沉浸了半年,有一些认知刷新想和童靴们交代一下, 不一定全面,仅代表此时的认知, 也欢迎筒靴们提出看法。本文聊一聊口嗨用语:长连接、短连接, 文章会按照下面的思维导图来讲述:

    shleyZ 评论0 收藏0
  • Easyswoole 源码学习个人解析 目录

    摘要:易用稳定,本次想通过对的学习和个人解析,吸收框架的思想和设计知识,加强自己对的认知和理解。当然,笔者能力水平有限,后续的文章如有错误,还请指出和谅解。目录如下后续添加文章都会记录在此服务启动过程以及主体设计流程源码解析 前言 swoole是什么?官网的原话介绍是这样的: Swoole 使用纯 C 语言编写,提供了 PHP 语言的异步多线程服务器,异步 TCP/UDP 网络客户端,异步 ...

    CoXie 评论0 收藏0
  • 阿里之路+Java面经考点

    摘要:我的是忙碌的一年,从年初备战实习春招,年三十都在死磕源码,三月份经历了阿里五次面试,四月顺利收到实习。因为我心理很清楚,我的目标是阿里。所以在收到阿里之后的那晚,我重新规划了接下来的学习计划,将我的短期目标更新成拿下阿里转正。 我的2017是忙碌的一年,从年初备战实习春招,年三十都在死磕JDK源码,三月份经历了阿里五次面试,四月顺利收到实习offer。然后五月怀着忐忑的心情开始了蚂蚁金...

    姘搁『 评论0 收藏0
  • Node.js 是什么?我为什么选择它?

    摘要:单线程使用单线程来运行,而不是向之类的其它服务器,每个请求将生产一个线程,这种方法避免了上下文切换和内存中的大量执行堆栈,这也是和其它服务器为解决上一个年,著名的并发连接问题而采用的方法。 showImg(https://segmentfault.com/img/remote/1460000019968794?w=1080&h=675);当我们学习一项新的事物的时候,我们首先要知道它来...

    Joyven 评论0 收藏0
  • 手把手教你如何进行内网渗透

    摘要:前面已经说了,内网渗透主要是基于口令的攻击。进程间通信主要方式有共享内存消息队列管道等。进程间通信是在多任务操作系统或联网的计算机之间运行的程序和进程所用的通信技术。 ...

    Hegel_Gu 评论0 收藏0

发表评论

0条评论

chanthuang

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<