为什么qq用的UDP为主,而TCP为辅助

一.TCP和UDP的区别 
 
这两种传输协议也用于不同的业务和不同的硬件终端。 


1、类似于图像、声音等对可靠性要求没有那么高的业务可以用UDP,他们不需要准确存储对准确性无要求但要求速度快。 

     类似于文本、程序、文件等要求可靠的数据最好就用TCP,但会牺牲一些速度。 

2、对系统资源的要求:TCP较多,UDP少。 

3、程序结构:UDP程序结构较简单,TCP复杂。 

4、流模式与数据报模式: TCP保证数据正确性,UDP可能丢包; 

                                     TCP保证数据顺序,UDP不保证 


为什么qq用的UDP为主,而TCP为辅助_第1张图片
二.用途 

1、TCP是面向连接的,有比较高的可靠性,一些要求比较高的服务一般使用这个协议,如FTP、Telnet、SMTP、HTTP、POP3等

    而UDP是面向无连接的,使用这个协议的常见服务有DNS、SNMP、QQ等。

 

UDP是一种面向无连接的通信协议,该协议使得数据传输的速度得到大幅度的提高。视频聊天语音聊天基本都是用UDP协议。


三、QQ以UDP为主,TCP为辅

      QQ即使传文件也是以UDP为主,主要是从服务器的角度来考虑:  

     首先每一个客户实际上都适合服务器交互,再由服务器转发给正在通信的用户,如果每一个QQ从一上线到下线的这段时间全部采用TCP长连接,这对服务器的负担很大,而如果采用TCP短连接,频繁的连接断开也会造成网络负担,二采用UDP则可以避开上述麻烦,减少服务的负担。


    不管UDP还是TCP,最终登陆成功之后,QQ都会有一个TCP连接来保持在线状态。这个TCP连接的远程端口一般是80,采用UDP方式登陆的时候,端口是8000。 UDP协议是无连接方式的协议,它的效率高,速度快,占资源少,但是其传输机制为不可靠传送,必须依靠辅助的算法来完成传输控制。QQ采用的通信协议以UDP为主,辅以TCP协议。由于QQ的服务器设计容量是海量级的应用,一台服务器要同时容纳十几万的并发连接,因此服务器端只有采用UDP协议与客户端进行通讯才能保证这种超大规模的服务。  

    QQ客户端之间的消息传送也采用了UDP模式,因为国内的网络环境非常复杂,而且很多用户采用的方式是通过代理服务器共享一条线路上网的方式,在这些复杂的情况下,客户端之间能彼此建立起来TCP连接的概率较小,严重影响传送信息的效率。而UDP包能够穿透大部分的代理服务器,因此QQ选择了UDP作为客户之间的主要通信协议。  

      采用UDP协议,通过服务器中转方式。因此,现在的IP侦探在你仅仅跟对方发送聊天消息的时候是无法获取到IP的。大家都知道,UDP 协议是不可靠协议,它只管发送,不管对方是否收到的,但它的传输很高效。但是,作为聊天软件,怎么可以采用这样的不可靠方式来传输消息呢?于是,腾讯采用了上层协议来保证可靠传输:如果客户端使用UDP协议发出消息后,服务器收到该包,需要使用UDP协议发回一个应答包。如此来保证消息可以无遗漏传输。之所以会发生在客户端明明看到“消息发送失败”但对方又收到了这个消息的情况,就是因为客户端发出的消息服务器已经收到并转发成功,但客户端由于网络原因没有收到服务器的应答包引起的


注: 对于QQ,QQ2003以前是只使用UDP协议的,其服务器使用8000端口,侦听是否有信息传来,客户端使用4000端口,向外发送信息(这也就不理解在一般的显IP的QQ版本中显示好友的IP地址信息中端口常为4000或其后续端口的原因了),即QQ程序既接受服务又提供服务,在以后的QQ版本中也支持使
TCP协议了。


参考资料

http://www.360doc.com/content/14/0715/10/12928831_394511484.shtml

http://javapub.iteye.com/blog/681138

https://www.zhihu.com/question/20292749

你可能感兴趣的:(Unix网络编程)