中科院云平台架构师,专注于数字化、智能化,技术方向:云、Linux内核、AI、MES/ERP/CRM/OA、物联网、传感器、大数据、ML、微服务。
分类: 网络与安全
2014-11-04 19:57:26
(传输控制协议)和(拥护数据报协议)是传输层的俩个传输协议,它们俩个的最大区别就是是否面向连接。
包括了面向连接和可靠数据传输服务,在客户端和服务器端进行通信前,要先交换传输层控制信息,为双方的通信做好准备。在这个握手阶段后,我们就可以认为在这俩个进程间存在一个连接,且是一个全双工的连接,在消息发送完后,应用程序会告诉拆除这个连接。可靠的传输服务为了保障彼此通信能无差错地顺序传递所有数据。
当其中任何一个应用程序把一个字节流传如套接字时,它可以指望把同样的字节流传递到对方的套接字,中间不回丢失和重传。是因特网的一种公益服务,其目的是能调节数据传输过程中的一些问题,因此还要包含一个拥塞机制。拥塞机制在网络变得拥塞时阻止发送进程。确切地说,拥塞控制试图把每个连接限定在它所公平共享的网络带宽上。对于有最小带宽需求限制的实时音频或视频应用来说,阻止其带宽那就让它们不能正常工作,此外,我们能想象一下,在网络电话通话时,偶尔的不连续是可以容忍的,可见实时应用可以容忍丢失少部分数据,不需要完全可靠服务。
说了这么多,能提供的好的服务,再看一下其缺点吧,首先,不保证最小传输率,通俗点说,不允许发送进程以想要的速率发送数据,受到拥塞控制的调节,发送进程有可能被迫以一个较低的平均速率发送。其次,不提供任何延时保障,具体点说,发送进程把数据传入自己的套接字后,这个数据将最终到达其接受套接字,但是中间所经历的时间就不能保证了 ,花几秒或则几分钟都不一定。
是一个非面向连接的轻量级传输协议,具有一个最简单的服务模型。是无连接的,因此两个进程彼此通信之前没有握手过程。提供不可靠的数据传输服务,也就是说当一个进程往自己套接字发送一个消息时,不能保障这个消息回最终到达接受套接字。另外,就确实到达接收套节字的消息而言,他们的到达顺序也可能不是有序的。
不含拥塞控制机制,因此发送进程能够以任意速率往套接字发送数据,尽管不能保证所有数据都到达接收套接字,但是会有相当比列的数据到达。实时应用程序的开发人员往往选择在上运行他们的应用。与类似,也不提供任何延迟保证。
说了这么多,我们可以通过下表来体会一下上面说的真正含义。
应 用 |
应用层协议 |
用来支撑的传输协议 |
电子邮件 |
SMTP(RFC82) |
|
远程终端访问 |
Telenet |
|
WEB |
HTTP |
|
文件传送 |
FTP |
|
远程文件服务器 |
NFS |
或 |
流多媒体 |
专属 |
或 |
因特网电话 |
专属 |
一般为 |
在表中我们看到,电子邮件,远程终端访问,WEB和文件传送都使用协议,这些应用选择的主要原因是在于提供了可靠的数据传输服务,能够保证所有数据最终到达其目的地。我们还看到,因特网电话一般运行在协议上面,一个因特网电话应用的俩端都得以某个最小速率跨越网络发送数据;另外,因特网电话可以容忍数据丢失,从这个俩个条件来看,都适合,不需要可靠的传输服务。
总的来说,能保证传递全部数据,而不能,且他们都不提供延迟保证。他们不提供延迟保证,并不意味着时间敏感的应用不能运行在现在的因特网上,而是应用是通过一些其他的方法来保证这些需要。