为什么tcp端口号6(TCP/UDP端口号的用处)

      最后更新:2022-11-27 05:08:05 手机定位技术交流文章

      数据段的 TCP 报头中为什么包含端口号?

      TCP(Transmission Control Protocol)传输控制协议 TCp协议位于第四层。其代表的含义是传输控制协议(Transmission Control protocol)。TCP 在端点间建立连接或虚拟电路进行可靠通信。当一个数据包被封装之后,第三层当然有个Ip协议头,紧接着就是这个TCp协议头。TCp协议头成为了Ip协议头中的“数据”。就像其它协议都有自己的术语一样,TCp协议也有自己的专门术语,如以太网帧、Ip数据报和现在的TCp段等。你可以把它们都当作数据包。但是,当它们之间在进行通讯的时候,一定要使用正确的术语。由于大多数网络应用程序都在同一台机器上运行,计算机上必须能够确保目的地机器上的软件程序能从源地址机器处获得数据包,以及源计算机能收到正确的回复。这是通过使用 TCP 的“端口号”完成的。网络 IP 地址和端口号结合成为唯一的标识 , 我们称之为“套接字”或“端点”。TCp协议是一种端对端的协议。使用TCp没有任何广播或类似的概念。TCP 通过面向连接的、端到端的可靠数据报发送来保证可靠性。TCP 在字节上加上一个递进的确认序列号来告诉接收者发送者期望收到的下一个字节。如果在规定时间内,没有收到关于这个包的确认响应,重新发送此包。TCP 的可靠机制允许设备处理丢失、延时、重复及读错的包。超时机制允许设备监测丢失包并请求重发。要用TCp协议与另一台计算机通信,两台机之间必须像打电话一样连接在一起,每一端都都为通话做好准备。“流传输”(Stream delivery)是谈到TCp时的另一个常用词语。这个短语的含义是TCp协议主要用来处理数据流,可以正确处理乱序的数据包。TCp协议甚至还允许存在丢失的或者损坏的数据包,最终它可以再次得到这些数据包。你很可能听一位程序员在谈论“流”的概念。他指的是这样一个事实:数据到底是在什么时候发送的是很难说清楚的,你也可以在TCp流中发送非结构化数据。TCp协议以它自己的方式缓存数据。不过,其缓存过程对程序员和用户是透明的。 关于流数据传输 ,TCP 交付一个由序列号定义的无结构的字节流。 这个服务对应用程序有利,因为在送出到 TCP 之前应用程序不需要将数据划分成块, TCP 可以将字节整合成字段,然后传给 IP 进行发送。TCp协议每发送一个数据包将会收到一个确认信息。这种发送/应答模式是提供可靠的协议的唯一方法:你必须让对方知道你否收到了数据。当然,这也会造成一些性能损失,而人们需要改善系统效率不高的状况。所以引入了“捎带确认(piggybacking ACKs)”的方法。TCp协议之所以是全双工的就是因为这个“捎带确认”信息,因为它允许双方同时发送数据。这是通过在当前的数据包中携带以前收到的数据的确认信息方式实现的。从提高网络利用率的角度看,这比单纯发送一个通知对方“信息已收到”的数据包要好得多。最后,还有一个批量确认的概念:也即一次确认一个以上的数据包,表示“我收到了包括这个数据包在内的全部数据包”。在Ip协议中,我们处理的单个数据包是一个更大的数据报的一部分。请记住,一个TCp段就是一个单个的TCp数据包。TCp是一个数据流,因此,除了“连接”之外,没有任何需要真正担心的其它概念。最大报文段长度(MSS)是在连接的时候协商的,但是,它总是在不断地改变。默认的最大报文段长度是536字节,这是576字节(Ip协议保证的最小数据包长度)减去用于Ip头的20个字节和用于TCp头的20个字节以后的长度。TCp协议要设法避免在Ip级别上的分段。因此,TCp协议总是从536字节开始的。TCp协议最有魅力的功能仍然保留着。这就是滑动窗口协议。这个窗口实际上是已经发出的“没有签收确认的”数据总数。这个窗口可以根据意愿放大和缩小。这是很有趣的。下一讲将介绍这方面的内容。一个TCp数据包的头是20个字节,就像一个Ip数据包一样。如果使用一些选项,Ip和TCp数据包头都可以放大。TCp头不包含Ip地址,它仅需要知道要连接哪一个端口。不过,你不要被这弄晕了。TCp工作时要一直跟踪状态表中的端对端的连接。这个状态表包含Ip地址和端口。这就是说,只是TCp头不需要Ip信息,因为它来自于Ip头。把一个数据包设想为一个字节跟着一个字节的数据流是很容易的。很多人都想要一个显示TCp头的表格。但是,这常会把事情搞乱。TCp头从第一位开始依次是下面这些内容:�6�1源端口,16位:用于这次连接的本地TCp端口。�6�1目的地端口,16位:通讯目标机器的TCp端口。�6�1序列号,32位:用来跟踪数据包顺序的号码。�6�1确认编号,32位:我们确认的以前收到的序列号。�6�1头长度,4位:报头中的32位字(words)的数量。如果不使用选项,这个值设定为5。�6�1保留,6位:为将来的使用保留的字节。�6�1标记,一共6位:每一个标记一个字节(开或者关)-URG:紧急字段指针。-ACK:本数据包是(或者包含)一个确认信息。-pSH:推送功能(没有使用)。-RST:重置,或者中断本次连接。-SYN:同步数据包,也就是开始连接。-FIN:最后一个数据包,开始挂断序列。�6�1窗口尺寸,16位:从接收方将收到的确认字段开始。�6�1校验和,16位:TCp头和数据的校验和。�6�1应急指针,16位:指向跟在URG数据后面的数据的序列号的偏移值。�6�1选项:MSS、窗口比例等等。我们在关于TCp协议的下一讲中将重点介绍这个部分。 TCp连接的两端使用两对Ip地址和端口识别这个连接,并且向监听这个端口的应用程序发送数据。
      socket通讯实际是进程通讯,区别只是在不同机器而已,一个数据包到达一台设备上以后需要知道是哪个进程的收发的,端口号就告诉你数据包该给哪个进程
      数据段的 TCP 报头中为什么包含端口号?

      理解 TCP(一):端口

      TCP 的包是不包含 IP 地址信息的,那是 IP 层上的事,但是有源端口和目的端口。就是说,端口这一东西,是属于 TCP 知识范畴的。我们知道两个进程,在计算机内部进行通信,可以有管道、内存共享、信号量、消息队列等方法。而两个进程如果需要进行通讯最基本的一个前提是能够唯一的标识一个进程,在本地进程通讯中我们可以使用「PID(进程标识符)」来唯一标识一个进程。但 PID 只在本地唯一,如果把两个进程放到了不同的两台计算机,然后他们要通信的话,PID 就不够用了,这样就需要另外一种手段了。解决这个问题的方法就是在运输层使用「协议端口号 (protocol port number)」,简称「端口 (port)」.我们知道 IP 层的 ip 地址可以唯一标识主机,而 TCP 层协议和端口号可以唯一标识主机的一个进程,这样我们可以利用:「ip地址+协议+端口号」唯一标示网络中的一个进程。在一些场合,也把这种唯一标识的模式称为「套接字 (Socket)」。这就是说,虽然通信的重点是应用进程,但我们只要把要传送的报文交到目的主机的某一个合适的端口,剩下的工作就由 TCP 来完成了。TCP 用一个 16 位端口号来标识一个端口,可允许有 65536 ( 2的16次方) 个不同的端口号,范围在 0 ~ 65535 之间。端口号根据服务器使用还是客户端使用,以及常见不常见的维度来区分,主要有以下类别:下面展开来说说。熟知端口号:取值范围:0 ~ 1023。可以在www.iana.org查到,服务器机器一接通电源,服务器程序就运行起来,为了让因特网上所有的客户程序都能找到服务器程序,服务器程序所使用的端口就必须是固定的,并且总所众所周知的。一些常见的端口号:|应用程序 | FTP | TELNET | SMTP | DNS | TFTP | HTTP | HTTPS | SNMP || ---| --- | --- |--- |--- |--- |--- |--- |--- |--- |--- |--- ||熟知端口号|21| 23 | 25 | 53 | 69 |80|443| 161 |登记端口号:取值范围:1024 ~ 49151。这类端口没有熟知的应用程序使用,但是需要登记,以防重复取值范围:49152 ~ 65535。这类端口仅在客户端进程运行时才动态选择。又叫 短暂端口号,表示这种端口的存在时间是短暂的,客户进程并不在意操作系统给它分配的是哪一个端口号,因为客户进程之所以必须有一个端口号,是为了让传输层的实体能够找到自己。PS:在 /etc/services 文件中可以查看所有知名服务使用的端口。《后台开发 核心技术与应用实践》《计算机网络》
      理解 TCP(一):端口

      sniffer捕获数据中,显示ip:Protocol=6(TCP),答案说是邮件传输协议端口,后来又发现ICMP:Protocol=1(ICMP)

      不是端口,是协议号。。。 他的答案是错的。邮件传输协议的端口号是:25POP3的端口号是110_______________________________TCP的协议号是 6 UDP的协议号是17ICMP的协议号是1 ip的协议号是0 这此常用的协议号要记住!
      protocol 1 这个不是端口是 标识协议的 协议号。 0HOPOPT IPv6 Hop-by-Hop Option [RFC1883]1ICMP Internet Control Message[RFC792]2IGMP Internet Group Management[RFC1112]3GGPGateway-to-Gateway[RFC823]4IP IP in IP (encapsulation) [RFC2003]5ST Stream [RFC1190,RFC1819]6TCPTransmission Control[RFC793]7CBTCBT[Ballardie]8EGPExterior Gateway Protocol[RFC888,DLM1] 9IGPany private interior gateway[IANA]
      sniffer捕获数据中,显示ip:Protocol=6(TCP),答案说是邮件传输协议端口,后来又发现ICMP:Protocol=1(ICMP)

      网络协议号是不是就是“端口号”比如TCP(6)UDP(17)是不是的?谢谢

      不是,一般来说协议号指复的是一个协议在IP包头中的一个字段。所说的是端口百号度 只是应用层的协议在传输层的一个代号。IP头中的协议号用来说明IP报文中承载的是哪种协议(一般是传输层协议,比如6 TCP,17 UDP;但也可能是网络层协议,比如1 ICMP;也可能是应用层协议,比如89 OSPF)。目的主机收到IP包后,根据IP协议号确定送给哪个模块(TCP/UDP/ICMP...)处理,送给TCP/UDP模块的报文根据端口号确定送给哪个应用程序处理。扩展资料协议号和端口号的区别:ip协议是网络层协议,三层的,协议号标识上层是什么协议,eg:17号表示是上层即传输层是udp协议,6号表示上层即传输层是tcp协议,89标识上层是ospf协议等等。tcp端口号表示是什么应用,eg:80 http服务,23 telnet服务,53 dns服务。udp端口原理和tcp是一样的。端口是传输层服务访问点TSAP,端口的作用是让应用层的各种应用进程都能将其数据通过端口向下交付给传输层,以及让传输层知道应当将其报文段中的数据向上通过端口交付给应用层的进程。端口号存在于UDP和TCP报文的首部,而IP数据报则是将UDP或者TCP报文做为其数据部分,再加上IP数据报首部,封装成IP数据报。而协议号则是存在这个IP数据报的首部。
      协议号,是IP协议中指协议的序号,端口号不等于协议号,比如网页服务是使用了6号协议TCP协议中的80号端口
      不是 一般来说协议号指的是一个协议在IP包头中的一个字段 你所说的是端口号 只是应用层的协议在传输层的一个代号如果想了解协议号 可以去查看RFC 1700文档或者 简单看看这个帖子http://tieba.baidu.com/p/1784668302
      网络协议号是不是就是“端口号”比如TCP(6)UDP(17)是不是的?谢谢

      为什么在TCP首部中最开始的4个字节是TCP端口号?

      在ICMP的差错报文中要包含紧随IP头部后面的8个字节的内容,让在TCP头部最开始的4个字节回是TCP的端口号,就可以在ICMP的差错报文的上述8个字节中有TCP的源端口和目的端口。当发送IP分组的源收到ICMP差错报文时需要用这两个端口来确定是哪个应用的网络通信出了差错。在一台机器上,一个进程对应一个端口。端口的作用就是用来唯一标识这个进程。源端口标识发起通信的那个进程,目的端口标识接受通信的那个进程。有了端口号,接受到报文后才能够知道将报文发送到哪个进程。扩展资料:1、应用层与TCP之间:应用层向 TCP 层发送用于网间传输的数据流,这些数据流是 8 位字节,TCP收到后会把数据流分割成适当长度的报文段。2、TCP层和IP层:TCP 把适当长度的报文段传给 IP 层,为了保证不发生丢包,TCP会把每个包命名一个序号,接收端按照序号接收。3、接收端实体成功收到的包会再发回一个确认ACK;如果发送端实体在响应时间内没有收到该确认,就会进行重传。
      在ICMP的差错报文中要包含紧随IP头部后面的8个字节的内容,让在TCP头部最开始的4个字节是TCP的端口号,就可以在ICMP的差错报文的上述8个字节中有TCP的源端口和目的端口。当发送IP分组的源收到ICMP差错报文时需要用这两个端口来确定是哪个应用的网络通信出了差错
      还有为什么的?人家规定的。
      为什么在TCP首部中最开始的4个字节是TCP端口号?

      本文由 在线网速测试 整理编辑,转载请注明出处,原文链接:https://www.wangsu123.cn/news/46720.html

          热门文章

          文章分类