TCP协议(摘自百度百科)

TCP:Transmission Control Protocol 传输控制协议 TCP是一种面向连接(连接导向) 的、可靠的、基于字节流的运输层(Transport layer)通信协议,由IETF的RFC 793说明(specified)。在简化的计算机网络 OSI模型 中, 它完成第四层传 输层 所指定的功能,UDP是同一层内另一个重要的传输协议

 

因特网协议 族 (Internet protocol suite)中,TCP层是位于IP层之上,应用层之下的中间层。不同主机的应用层之间经常需要可靠的、像管道一样的连接,但是IP层不提供这样的流机 制,而是提供不可靠的包交换。

  应用层向TCP层发送用于网间传输的、用8位字节表示的数据流,然后TCP把数据流分割成适当 长度的报文段(通常受该计算机连接的网络的数据链路层的最大传送单元(MTU)的限制)。之后TCP把结果包传给IP层,由它来通过网络将包传送给接收端 实体的TCP层。TCP为了保证不发生丢包,就给每个字节一个序号,同时序号也保证了传送到接收端实体的包的按序接收。然后接收端实体对已成功收到的字节 发回一个相应的确认(ACK);如果发送端实体在合理的往返时延(RTT)内未收到确认,那么对应的数据(假设丢失了)将会被重传。TCP用一个校验和函 数来检验数据是否有错误;在发送和接收时都要计算校验和。
  首先,TCP建立连接之后,通信双方都同时可以进行数据的传输,其次,他是全双工的;在保证可 靠性上,采用超时重传和捎带确认 机制。
  在流量控制上,采用滑动窗口协议 ,协议中规定,对于窗口内未经确 认的分组需要重传。
  在拥塞控制 上,采用慢启动算法。

什么是TCP/IP?

  TCP/IP(Transmission Control Protocol/Internet Protocol) 即传输控制协议/网间协议 ,是一个工业标准的协议集 ,它 是为广域网(WAN)设计的。它是由ARPANET网的研究机构发展起来的。
  有时我们将TCP/IP描述为互联网协议 集\"InternetProtocolSuite \",TCP和IP是其中的两个协议(后面将会介绍)。由于TCP和IP是大家熟悉的协议,以至于用TCP/IP或IP/TCP这个词代替了整个协议集。 这尽管有点奇怪,但没有必要去争论这个习惯。例如,有时我们讨论NFS是基于TCP/IP时,尽管它根本没用到TCP(只用到IP,和另一种交互式 协议UDP而不是TCP)。
  TCP/IP的标准在一系列称为RFC的文档中公布。文档由技术专家、特别工作组、或RFC编 辑修订。公布一个文档时,该文档被赋予一个RFC编号,如RFC959(FTP的说明文档)、RFC793(TCP的说明文档)、RFC791(IP的说 明文档)等。最初的RFC一直保留而从来不会被更新,如果修改了该文档,则该文档又以一个新号码公布。因此,重要的是要确认你拥有了关于某个专题的最新 RFC文档。通常在RFC的开头部分,有相关RFC的更新(update)、修改(errata)、作废(obsolete)信息,提示读者信息的时效 性。详情请阅读网站RFC-editor[5]

TCP所支持的服务类型

  不管怎样,TCP/IP是一个协议集。为应用提供一些\"低级\"功能,这些包括 IP、TCP、UDP。其它是执行特定任务的应用协议,如计算机间传送文件、发送电子邮件、或找出谁注册到另外一台计算机。因此, 最重要的\"商业\"TCP/IP服务有:
  *FTP 文件传送(File Transfer)
  文件传送协议FTP(File TransferProtocol)允许用户从一台计算机到另一台取得文件,或发送文件到另外一台计算机。从安全性方面考虑,需要用户指定一个使用其它计 算机的用户名和口令。它不同于NFS(Network File System)和Netbios协议。一旦你要访问另一台系统中的文件,任何时刻都要运行FTP。而且你只能拷贝文件到自己的机器中去来使用它。RFC 959中有关于FTP的详尽说明。
  * RLogin 远程登录(Remote login)
  网络终端协议TELNET允许用户登录到网络上任一计算机上。你可启动一个远程进程连接到指定 的计算机,直到进程结束,期间你所键入的内容被送到所指定的计算机。值得注意的是,这时你实际上是与你的计算机进行对话。TELENET程序使得你的计算 机在整个过程中不见了,所敲的每一个字符直接送到所登录的计算机系统。一般的说,这种远程连接是通过类式拨号连接的,也就是,拨通后,远程系统提示你输入 注册名和口令,退出远程系统,TELNET程序也就退出,你又与自己的计算机对话了。微电脑中的TELNET工具一般含有一个终端仿真程序。
  * SMTP POP3 电子邮件(Mail)
  允许你发送消息给其它计算机的用户。通常,人们趋向于使用指定的一台或两台计算机。计算机邮件系统 只 需你简单地往另一用户的邮件文件中添加信息,但随之产生问题,使用的微电脑的环境不同,还有重要的是宏(MACRO)不适合于接受计算机邮件。为了发送电 子邮件,邮件软件希望连接到目的计算机,如果是微电脑,也许它已关机,或者正在运行另一个应用程序呢?出于这种原因,通常由一个较大的系统来处理这些邮 件,也就是一个一直运行着的邮件服务器 。邮件软件成为用户从邮件服务器取回邮 件的一个界面。
  任何一个的TCP/IP工具提供上述这些服务。这些传统的应用功能在基于TCP/IP的网络中 一直扮演非常重要的角色。目前情况有点变化,这些功能使用也发生变化,如老系统的改造,计算机的发展等,出现了各种安装版本,如:微电脑、工作站、小型 机、和巨型机等。这些计算机好像在一起完成指定的任务,尽管有时看来像是只用到某个指定的计算机,但它是通过网络得到其它计算机系统的服务。服务器 Server是为网络上其它提供指定服务的系统,客户Client是得到这种服务的另外计算机系统。(值得注意的是,服务/客户机不一定是不同的计算机, 有可能是同一计算机中的不同运行程序)。以下是几种目前计算机上典型的一些服务,这些服务可在TCP/IP网络上调用。
  * NFS 网络文件系统(Network File System)
  这种访问另一计算机的文件的方法非常接近于流行的FTP。网络文件系统提供磁盘或设备服务,而 无需特定的网络实用程序来访问另一系统的文件。可以简单地认为它是一个外加的磁盘驱动器。这种额外\"虚拟\"磁盘驱动器就是其它计算机系统的磁盘。这非 常有用。你只需加大几台计算机的磁盘容量,就可使网络上其他用户访问它,且不说所带来的经济效益,它还能够让几台工作的计算机共享相同的文件。它也使得系 统维护和备份易如反掌,因为再不必为大量的不同机器上的文件的升级和备份而担心。
  * 远程打印(Remote Printing)
  允许你使用其它计算机上的打印机,好像这些打印机直接连到你的计算机上。
  * 远程执行(Remote Execution)
  允许你请求运行在不同计算机上的特殊程序。当你在一个很小的计算机上运行一个需要大机系统资源 的程序时,这时候远程执行非常有用。
  * 名字服务器(Name Servers)
  在一个大的系统安装过程中,需要用到大量的各种名字,包括用户名、口令,姓名、网络地址、帐号 等,管理这些是非常令人乏味的。因此将这些数据形成数据库,放到一个小系统中去,其它系统通过网络来访问这些数据。
  * 终端服务器(Terminal Servers)
  很多的终端连接安装不再直接将终端连到计算机,取而代之的是,将他们连接到终端服务器上。终端 服务器是一个小的计算机,它只需知道怎样运行TELNET(或其它一些完成远程登录的协议)。如果你的终端想连上去,只用键入要连的计算机名就可。通常有 可能同时有几个这种连接,这时终端服务器采用快速开关技术来切换。
  上述所描述的一些协议是由Berkeley, Sun,或其它组织定义的。因此,它们不是互联网协议集(InternetProtocol Suite)的一部分, 只是使用到TCP/IP的工具,如同一般的TCP/IP应用协议。因为协议的定义不一致,并且商业支持的TCP/IP工具广泛应用,也许会把这些协议作为 互联协议集中的一部分。上述列出的只是基于TCP/IP部分服务的一些简单例子,但包含了一些\"主要\"的应用。

TCP的服务流程

  TCP协议提供的是可靠的、面向连接的传输控制协议,即在传输数据前要先建立逻辑连接,然后 再传输数据,最后释放连接3个过程。TCP提供端到端 、全双工通信;采用字节流方式,如果字 节流太长,将其分段;提供紧急数据传送功能。
  尽管TCP和UDP都使用相同的网络层(IP),TCP却向应用层提供与UDP完全不同的服 务。
  TCP提供一种面向连接的、可靠的字节流服务。
  面向连接意味着两个使用TCP的应用(通常是一个客户和一个服务器)在彼此交换数据之前必须先 建立一个TCP连接。这一过程与打电话很相似,先拨号振铃,等待对方摘机说“喂”,然后才说明是谁。
  在一个TCP连接中,仅有两方进行彼此通信。广播和多播 不能用于TCP。
  TCP通过下列方式来提供可靠性:
  o应用数据被分割成TCP认为最适合发送的数据块。这和UDP完全不同,应用程序产生的数据报 长度将保持不变。由TCP传递给IP的信息单位称为报文段或段(segment)TCP如何确定报文段的长度。
  o当TCP发出一个段后,它启动一个定时器,等待目的端确认收到这个报文段。如果不能及时收到 一个确认,将重发这个报文段。o当TCP收到发自TCP连接另一端的数据,它将发送一个确认。这个确认不是立即发送,通常将推迟几分之一秒
  oTCP将保持它首部和数据的检验和。这是一个端到端的检验和,目的是检测数据在传输过程中的 任何变化。如果收到段的检验和有差错,TCP将丢弃这个报文段和不确认收到此报文段(希望发端超时并重发)。
  o既然TCP报文段作为IP数据报来传输,而IP数据报的到达可能会失序,因此TCP报文段的 到达也可能会失序。如果必要,TCP将对收到的数据进行重新排序,将收到的数据以正确的顺序交给应用层。
  o既然IP数据报会发生重复,TCP的接收端必须丢弃重复的数据。
  oTCP还能提供流量控制。TCP连接的每一方都有固定大小的缓冲空间。TCP的接收端只允许 另一端发送接收端缓冲区所能接纳的数据。这将防止较快主机致使较慢主机的缓冲区溢出。
  两个应用程序通过TCP连接交换8bit字节构成的字节流。TCP不在字节流中插入记录标识 符。我们将这称为字节流服务(bytestreamservice)。如果一方的应用程序先传10字节,又传20字节,再传50字节,连接的另一方将无法 了解发方每次发送了多少字节。收方可以分4次接收这80个字节,每次接收20字节。一端将字节流放到TCP连接上,同样的字节流将出现在TCP连接的另一 端。
  另外,TCP对字节流的内容不作任何解释。TCP不知道传输的数据字节流是二进制数据,还是 ASCII字符、EBCDIC字符或者其他类型数据。对字节流的解释由TCP连接双方的应用层解释。
  这种对字节流的处理方式与Unix操作系统对文件的处理方式很相似。Unix的内核对一个应用 读或写的内容不作任何解释,而是交给应用程序处理。对Unix的内核来说,它无法区分一个二进制文件与一个文本文件。
  TCP是因特网中的传输层协议,使用三次握手协议 建立连接。当主动方发出SYN连 接请求后,等待对方回答SYN,ACK。这种建立连接的方法可以防止产生错误的连接,TCP使用的流量控制协议是可变大小的滑动窗口协议。第一次握手:建 立连接时,客户端发送SYN包(SEQ=x)到服务器,并进入SYN_SEND状态,等待服务器确认。第二次握手:服务器收到SYN包,必须确认客户的 SYN(ACK=x+1),同时自己也送一个SYN包(SEQ=y),即SYN+ACK包,此时服务器进入SYN_RECV 状态。第三次握手:客户端收 到服务器的SYN+ACK包,向服务器发送确认包ACK(ACK=y+1),此包发送完毕,客户端和服务器时入Established状态,完成三次握 手。

TCP所提供服务的主要特点

  (1)面向连接的传输;
  (2)端到端的通信;
  (3)高可靠性,确保传输数据的正确性,不出现丢失或乱序;
  (4)全双工方式传输;
  (5)采用字节流方式,即以字节为单位传输字节序列;
  (6)紧急数据传送功能。

TCP的重传策略

  TCP协议用于控制数据段是否需要重传的依据是设立重发定时器。在发送一个数据段的同时启动 一个重发定时器,如果在定时器超时前收到确认就关闭该定时器,如果定时器超时前没有收到确认,则重传该数据段。
  这种重传策略的关键是对定时器初值的设定。目前采用较多的算法是Jacobson于1988年 提出的一种不断调整超时时间间隔的动态算法。其工作原理是:对每条连接TCP都保持一个变量RTT,用于存放当前到目的端往返所需要时间最接近的估计值。 当发送一个数据段时,同时启动连接的定时器,如果在定时器超时前确认到达,则记录所需要的时间(M),并修正RTT的值,如果定时器超时前没有收到确认, 则将RTT的值增加1倍。

TCP的端口号

  TCP段结构中端口地址都是16比特,可以有在0~65535范围内的端口号 。对于 这65536个端口号有以下的使用规定:
  (1)端口号小于256的定义为常用端口,服务器一般都是通过常用端口号来识别的。任何 TCP/IP实现所提供的服务都用1~1023之间的端口号,是由IANA来管理的;
  (2)客户端只需保证该端口号在本机上是惟一的就可以了。客户端口号因存在时间很短暂又称临时 端口号;
  (3)大多数TCP/IP实现给临时端口号分配1024~5000之间的端口号。大于5000 的端口号是为其他服务器预留的。

TCP协议是如何确保数据传输高可靠性


   为了保证可靠性,发送的报文都有递增的序列号。序呈和确认号用来确保传输的可靠性。此外,对每个报文都设立一个定时器,设定一个最大时延。对那些超过最 大时延仍没有收到确认信息的报文就认为已经丢失,需要重传。

如何重置TCP/IP协议

  在Windows Server 2003(简称Windows 2003)的连接属性对话框中,如果点击“Internet协议 (TCP/IP)选项, “卸载”按钮为灰色,是不可用的。这是因为TCP/IP协议 是Windows Server 2003的核心组件,不能删除。
  如果我们需要将TCP/IP重置到原始状态,该怎么办呢?此时,我们可以借助“netsh”命 令行工具来解决这一问题。在“运行”对话框中输入“cmd”,打开“命令提示符 ”窗口,然后输入命令行“netsh int ip reset resetlog.txt”或“netsh int ip resetc:\resetlog.txt”并按回车键。其中的“reset”命令可以重写与TCP/IP相关的注册表项“System \CurrentControlSet\Services\Tcpip\Parameters\”和“System\CurrentControlSet \Services\DHCP\Parame ters\”,运行以上命令的结果与删除并重新安装TCP/IP的效果相同。
  此外,两个命令行的不同之处仅仅在于“resetlog.txt”日志文件的存储位置有所区 别。前者是将日志文件创建在当前文件夹中,而后者则指定了具体的保存路径。
  在WindowsXP的网络组件列表里,Internet 协议 (TCP/IP)的"卸载"按钮是灰色不可选状态。这是因为传输控制协议/Internet 协议(TCP/IP) 堆栈是 Microsoft XP/ 2003 的核心组件(TCP/IP协议是WindowsXP的默认协议),不能删除。所以Windows XP不允许卸载TCP/IP协议。如果在特殊情况下需要重新安装TCP/IP协议,如何操作?
  解决方法
  在这种情况下,如果需要重新安装 TCP/IP 以使 TCP/IP 堆栈恢复为原始状态。可以使用 NetShell 实用程序重置 TCP/IP 堆栈,使其恢复到初次安装操作系统时的状态。具体操作如下:
  1、单击 开始 --> 运行,输入 "CMD" 后单击 "确定";
  2、在命令行模式输入命令
  netsh int ip reset C:\resetlog.txt
  (其中,Resetlog.txt记录 命令结果的日志文件,一定要指定, 这里指定了Resetlog.txt 日志文件及完整路径。)
  运行结果可以查看C:\resetlog.txt (咨询中可根据用户实际操作情况提供)
  运行此命令的结果与删除并重新安装 TCP/IP 协议的效果相同。
  注意
  本操作具有一定的风险性,请在操作前备份重要数据,并根据操作熟练度酌情使用。

TCP公司简介[以下为非计算机类]

  TechnicalConsumerProducts,INC之英文缩写 TCP,是美国大型跨国光源公司,主要生产经营各种优质节能光源、灯具及相关照明电器产品。1997年,全球第一支高品质螺旋型节能灯在美国TCP公司问 世,一经推出即得到国际照明行业的高度评价,并受到美国消费者的普遍欢迎。TCP公司当年即荣获全美节能灯销售第一的桂冠。随着TCP不断追求技术创新, 产品品质不断提升,其数百款光源产品均通过了国际能效认证机构ENERGYSTAR(能源之星)的认证,多年保持美国销量第一的殊荣,产品行销全球许多国 家。TCP也成为美国、加拿大等北美地区最著名的光源品牌之一。
  上个世纪末,TCP来到中国,在上海市及江苏省投资数亿兴建了多家现代照明生产基地,员工总数 已超过14000人,工程技术人员占15%。TCP全资控股的上海振欣电子工程有限公司,镇江强凌电子有限公司、扬州强凌电子有限公司以及淮安强凌电子有 限公司每天有超过140万只的高品质节能灯光源出口到美国等西方发达国家。2004年,美国TCP(上海)天灿宝照明电器有限公司成立,其专门负责高品质 的TCP光源及灯具产品在中国国内的销售和服务。在前期市场导入阶段,TCP在上海、北京已取得成功的销售业绩,数百家大型机构抢先分享了TCP照明科 技。
  TCP“让照明成为享受”的理念,正走向中国日益发展的新生活。
  制造理念:高品质、高可靠性、高一致性、低价位
  企业精神:诚信、发展、创新、超越
  企业座右铭:你想要一个稳定的世界,必须创造一个世界。
  品牌战略:做世界上最好的节能光源,让照明成为享受。
  产品战略:让所有使用白炽灯的地方都可以用节能灯代替。
  营销战略:以上海、北京、广州为中心,逐步建立遍布全国的营销组织网络。
  
  TCP射孔

  油管传输射孔

TCP协议和UDP协议的区别

  1,TCP协议面向连接,UDP协议面向非连接
  2,TCP协议传输速度慢,UDP协议传输速度快
  3,TCP协议保证数据顺序,UDP协议不保证
  4,TCP协议保证数据正确性,UDP协议可能丢包
  5,TCP协议对系统资源要求多,UDP协议要求少

你可能感兴趣的:(tcp)