点评
因为UDP数据传输的无连接特性,最简单的UDP数据传输就是一次数据交互一个UDP包搞定,这样就不用管分包问题(因为不像TCP,UDP传输时如果分包则是不能保证顺序的,这会带来很多问题)。所以你一次交互的数据如果太多的话,用UDP实现就很可能并不优雅。
(移动端即时通讯/IM 学习和讨论QQ群:http://www.52im.net/portal.php?mod=topic&topicid=2)
前言
在进行UDP编程的时候,我们最容易想到的问题就是,一次发送多少bytes好?
当然,这个没有唯一答案,相对于不同的系统,不同的要求,其得到的答案是不一样的,我这里仅对像ICQ一类的发送聊天消息的情况作分析,对于其他情况,你或许也能得到一点帮助。
网络原理
首先,我们知道,TCP/IP通常被认为是一个四层协议系统:包括链路层、网络层、运输层、应用层 。UDP属于运输层,下面我们由下至上一步一步来看。
结论1:局域网环境下,建议将UDP数据控制在1472字节以下
以太网(Ethernet)数据帧的长度必须在46-1500字节之间,这是由以太网的物理特性决定的,这个1500字节被称为链路层的MTU(最大传输单元)。但这并不是指链路层的长度被限制在1500字节,其实这这个MTU指的是链路层的数据区,并不包括链路层的首部和尾部的18个字节。
所以,事实上这个1500字节就是网络层IP数据报的长度限制。因为IP数据报的首部为20字节,所以IP数据报的数据区长度最大为1480字节。而这个1480字节就是用来放TCP传来的TCP报文段或UDP传来的UDP数据报的。
又因为UDP数据报的首部8字节,所以UDP数据报的数据区最大长度为1472字节。这个1472字节就是我们可以使用的字节数。
当我们发送的UDP数据大于1472的时候会怎样呢? 这也就是说IP数据报大于1500字节,大于MTU,这个时候发送方IP层就需要分片(fragmentation)。把数据报分成若干片,使每一片都小于MTU,而接收方IP层则需要进行数据报的重组。这样就会多做许多事情,而更严重的是,由于UDP的特性,当某一片数据传送中丢失时,接收方无法重组数据报,将导致丢弃整个UDP数据报。
因此,在普通的局域网环境下,我建议将UDP的数据控制在1472字节以下为好。
结论2:Internet编程时,建议将UDP数据控制在548字节以下
进行Internet编程时则不同,因为Internet上的路由器可能会将MTU设为不同的值。如果我们假定MTU为1500来发送数据,而途经的某个网络的MTU值小于1500字节,那么系统将会使用一系列的机制来调整MTU值,使数据报能够顺利到达目的地,这样就会做许多不必要的操作。
鉴于Internet上的标准MTU值为576字节,所以我建议在进行Internet的UDP编程时, 最好将UDP的数据长度控件在548字节(576-8-20)以内。
ps:这句话貌似有问题,unix网络编程第一卷里说:ipv4协议规定ip层的最小重组缓冲区大小为576!所以,建议udp包不要超过这个大小,而不是因为internet的标准MTU是576!
全站即时通讯技术资料分类
[1] 网络编程基础资料:
《 TCP/IP详解 - 第11章·UDP:用户数据报协议》
《 TCP/IP详解 - 第17章·TCP:传输控制协议》
《 TCP/IP详解 - 第18章·TCP连接的建立与终止》
《 TCP/IP详解 - 第21章·TCP的超时与重传》
《 技术往事:改变世界的TCP/IP协议(珍贵多图、手机慎点)》
《 通俗易懂-深入理解TCP协议(上):理论基础》
《 通俗易懂-深入理解TCP协议(下):RTT、滑动窗口、拥塞处理》
《 理论经典:TCP协议的3次握手与4次挥手过程详解》
《 理论联系实际:Wireshark抓包分析TCP 3次握手、4次挥手过程》
《 计算机网络通讯协议关系图(中文珍藏版)》
《 UDP中一个包的大小最大能多大?》
《 P2P技术详解(一):NAT详解——详细原理、P2P简介》
《 P2P技术详解(二):P2P中的NAT穿越(打洞)方案详解》
《 P2P技术详解(三):P2P技术之STUN、TURN、ICE详解》
《 通俗易懂:快速理解P2P技术中的NAT穿透原理》
《 高性能网络编程(一):单台服务器并发TCP连接数到底可以有多少》
《 高性能网络编程(二):上一个10年,著名的C10K并发连接问题》
《 高性能网络编程(三):下一个10年,是时候考虑C10M并发问题了》
《 高性能网络编程(四):从C10K到C10M高性能网络应用的理论探索》
《 不为人知的网络编程(一):浅析TCP协议中的疑难杂症(上篇)》
《 不为人知的网络编程(二):浅析TCP协议中的疑难杂症(下篇)》
《 不为人知的网络编程(三):关闭TCP连接时为什么会TIME_WAIT、CLOSE_WAIT》
《 不为人知的网络编程(四):深入研究分析TCP的异常关闭》
《 不为人知的网络编程(五):UDP的连接性和负载均衡》
《 不为人知的网络编程(六):深入地理解UDP协议并用好它》
《 不为人知的网络编程(七):如何让不可靠的UDP变的可靠?》
《 网络编程懒人入门(一):快速理解网络通信协议(上篇)》
《 网络编程懒人入门(二):快速理解网络通信协议(下篇)》
《 网络编程懒人入门(三):快速理解TCP协议一篇就够》
《 网络编程懒人入门(四):快速理解TCP和UDP的差异》
《 网络编程懒人入门(五):快速理解为什么说UDP有时比TCP更有优势》
《 网络编程懒人入门(六):史上最通俗的集线器、交换机、路由器功能原理入门》
《 网络编程懒人入门(七):深入浅出,全面理解HTTP协议》
《 网络编程懒人入门(八):手把手教你写基于TCP的Socket长连接》
《 技术扫盲:新一代基于UDP的低延时网络传输层协议——QUIC详解》
《 让互联网更快:新一代QUIC协议在腾讯的技术实践分享》
《 现代移动端网络短连接的优化手段总结:请求速度、弱网适应、安全保障》
《 聊聊iOS中网络编程长连接的那些事》
《 移动端IM开发者必读(一):通俗易懂,理解移动网络的“弱”和“慢”》
《 移动端IM开发者必读(二):史上最全移动弱网络优化方法总结》
《 IPv6技术详解:基本概念、应用现状、技术实践(上篇)》
《 IPv6技术详解:基本概念、应用现状、技术实践(下篇)》
《 从HTTP/0.9到HTTP/2:一文读懂HTTP协议的历史演变和设计思路》
《 脑残式网络编程入门(一):跟着动画来学TCP三次握手和四次挥手》
《 脑残式网络编程入门(二):我们在读写Socket时,究竟在读写什么?》
《 脑残式网络编程入门(三):HTTP协议必知必会的一些知识》
《 脑残式网络编程入门(四):快速理解HTTP/2的服务器推送(Server Push)》
>> 更多同类文章 ……
[2] 有关IM/推送的通信格式、协议的选择:
《 Protobuf通信协议详解:代码演示、详细原理介绍等》
《 一个基于Protocol Buffer的Java代码演示》
《 简述传输层协议TCP和UDP的区别》
《 为什么QQ用的是UDP协议而不是TCP协议?》
《 移动端即时通讯协议选择:UDP还是TCP?》
《 如何选择即时通讯应用的数据传输格式》
《 强列建议将Protobuf作为你的即时通讯应用数据传输格式》
《 全方位评测:Protobuf性能到底有没有比JSON快5倍?》
《 移动端IM开发需要面对的技术问题(含通信协议选择)》
《 简述移动端IM开发的那些坑:架构设计、通信协议和客户端》
《 理论联系实际:一套典型的IM通信协议设计详解》
《 58到家实时消息系统的协议设计等技术实践分享》
《 详解如何在NodeJS中使用Google的Protobuf》
《 技术扫盲:新一代基于UDP的低延时网络传输层协议——QUIC详解》
《 金蝶随手记团队分享:还在用JSON? Protobuf让数据传输更省更快(原理篇)》
《 金蝶随手记团队分享:还在用JSON? Protobuf让数据传输更省更快(实战篇)》
>> 更多同类文章 ……
[3] 有关IM/推送的心跳保活处理:
《 应用保活终极总结(一):Android6.0以下的双进程守护保活实践》
《 应用保活终极总结(二):Android6.0及以上的保活实践(进程防杀篇)》
《 应用保活终极总结(三):Android6.0及以上的保活实践(被杀复活篇)》
《 Android进程保活详解:一篇文章解决你的所有疑问》
《 Android端消息推送总结:实现原理、心跳保活、遇到的问题等》
《 深入的聊聊Android消息推送这件小事》
《 为何基于TCP协议的移动端IM仍然需要心跳保活机制?》
《 微信团队原创分享:Android版微信后台保活实战分享(进程保活篇)》
《 微信团队原创分享:Android版微信后台保活实战分享(网络保活篇)》
《 移动端IM实践:实现Android版微信的智能心跳机制》
《 移动端IM实践:WhatsApp、Line、微信的心跳策略分析》
>> 更多同类文章 ……
[4] 有关WEB端即时通讯开发:
《 新手入门贴:史上最全Web端即时通讯技术原理详解》
《 Web端即时通讯技术盘点:短轮询、Comet、Websocket、SSE》
《 SSE技术详解:一种全新的HTML5服务器推送事件技术》
《 Comet技术详解:基于HTTP长连接的Web端实时通信技术》
《 新手快速入门:WebSocket简明教程》
《 WebSocket详解(一):初步认识WebSocket技术》
《 WebSocket详解(二):技术原理、代码演示和应用案例》
《 WebSocket详解(三):深入WebSocket通信协议细节》
《 WebSocket详解(四):刨根问底HTTP与WebSocket的关系(上篇)》
《 WebSocket详解(五):刨根问底HTTP与WebSocket的关系(下篇)》
《 WebSocket详解(六):刨根问底WebSocket与Socket的关系》
《 socket.io实现消息推送的一点实践及思路》
《 LinkedIn的Web端即时通讯实践:实现单机几十万条长连接》
《 Web端即时通讯技术的发展与WebSocket、Socket.io的技术实践》
《 Web端即时通讯安全:跨站点WebSocket劫持漏洞详解(含示例代码)》
《 开源框架Pomelo实践:搭建Web端高性能分布式IM聊天服务器》
《 使用WebSocket和SSE技术实现Web端消息推送》
《 详解Web端通信方式的演进:从Ajax、JSONP 到 SSE、Websocket》
《 MobileIMSDK-Web的网络层框架为何使用的是Socket.io而不是Netty?》
《 理论联系实际:从零理解WebSocket的通信原理、协议格式、安全性》
《 微信小程序中如何使用WebSocket实现长连接(含完整源码)》
>> 更多同类文章 ……
[5] 有关IM架构设计:
《 浅谈IM系统的架构设计》
《 简述移动端IM开发的那些坑:架构设计、通信协议和客户端》
《 一套海量在线用户的移动端IM架构设计实践分享(含详细图文)》
《 一套原创分布式即时通讯(IM)系统理论架构方案》
《 从零到卓越:京东客服即时通讯系统的技术架构演进历程》
《 蘑菇街即时通讯/IM服务器开发之架构选择》
《 腾讯QQ1.4亿在线用户的技术挑战和架构演进之路PPT》
《 微信后台基于时间序的海量数据冷热分级架构设计实践》
《 微信技术总监谈架构:微信之道——大道至简(演讲全文)》
《 如何解读《微信技术总监谈架构:微信之道——大道至简》》
《 快速裂变:见证微信强大后台架构从0到1的演进历程(一)》
《 17年的实践:腾讯海量产品的技术方法论》
《 移动端IM中大规模群消息的推送如何保证效率、实时性?》
《 现代IM系统中聊天消息的同步和存储方案探讨》
《 IM开发基础知识补课(二):如何设计大量图片文件的服务端存储架构?》
《 IM开发基础知识补课(三):快速理解服务端数据库读写分离原理及实践建议》
《 IM开发基础知识补课(四):正确理解HTTP短连接中的Cookie、Session和Token》
《 WhatsApp技术实践分享:32人工程团队创造的技术神话》
《 微信朋友圈千亿访问量背后的技术挑战和实践总结》
《 王者荣耀2亿用户量的背后:产品定位、技术架构、网络方案等》
《 IM系统的MQ消息中间件选型:Kafka还是RabbitMQ?》
>> 更多同类文章 ……
[6] 有关IM安全的文章:
《 即时通讯安全篇(一):正确地理解和使用Android端加密算法》
《 即时通讯安全篇(二):探讨组合加密算法在IM中的应用》
《 即时通讯安全篇(三):常用加解密算法与通讯安全讲解》
《 即时通讯安全篇(四):实例分析Android中密钥硬编码的风险》
《 传输层安全协议SSL/TLS的Java平台实现简介和Demo演示》
《 理论联系实际:一套典型的IM通信协议设计详解(含安全层设计)》
《 微信新一代通信安全解决方案:基于TLS1.3的MMTLS详解》
《 来自阿里OpenIM:打造安全可靠即时通讯服务的技术实践分享》
>> 更多同类文章 ……
[7] 有关实时音视频开发:
《 即时通讯音视频开发(一):视频编解码之理论概述》
《 即时通讯音视频开发(二):视频编解码之数字视频介绍》
《 即时通讯音视频开发(三):视频编解码之编码基础》
《 即时通讯音视频开发(四):视频编解码之预测技术介绍》
《 即时通讯音视频开发(五):认识主流视频编码技术H.264》
《 即时通讯音视频开发(六):如何开始音频编解码技术的学习》
《 即时通讯音视频开发(七):音频基础及编码原理入门》
《 即时通讯音视频开发(八):常见的实时语音通讯编码标准》
《 即时通讯音视频开发(九):实时语音通讯的回音及回音消除概述》
《 即时通讯音视频开发(十):实时语音通讯的回音消除技术详解》
《 即时通讯音视频开发(十一):实时语音通讯丢包补偿技术详解》
《 即时通讯音视频开发(十二):多人实时音视频聊天架构探讨》
《 即时通讯音视频开发(十三):实时视频编码H.264的特点与优势》
《 即时通讯音视频开发(十四):实时音视频数据传输协议介绍》
《 即时通讯音视频开发(十五):聊聊P2P与实时音视频的应用情况》
《 即时通讯音视频开发(十六):移动端实时音视频开发的几个建议》
《 即时通讯音视频开发(十七):视频编码H.264、V8的前世今生》
《 简述开源实时音视频技术WebRTC的优缺点》
《 良心分享:WebRTC 零基础开发者教程(中文)》
>> 更多同类文章 ……
[8] IM开发综合文章:
《 移动端IM开发者必读(一):通俗易懂,理解移动网络的“弱”和“慢”》
《 移动端IM开发者必读(二):史上最全移动弱网络优化方法总结》
《 从客户端的角度来谈谈移动端IM的消息可靠性和送达机制》
《 现代移动端网络短连接的优化手段总结:请求速度、弱网适应、安全保障》
《 腾讯技术分享:社交网络图片的带宽压缩技术演进之路》
《 小白必读:闲话HTTP短连接中的Session和Token》
《 IM开发基础知识补课:正确理解前置HTTP SSO单点登陆接口的原理》
《 移动端IM中大规模群消息的推送如何保证效率、实时性?》
《 移动端IM开发需要面对的技术问题》
《 开发IM是自己设计协议用字节流好还是字符流好?》
《 请问有人知道语音留言聊天的主流实现方式吗?》
《 IM消息送达保证机制实现(一):保证在线实时消息的可靠投递》
《 IM消息送达保证机制实现(二):保证离线消息的可靠投递》
《 如何保证IM实时消息的“时序性”与“一致性”?》
《 一个低成本确保IM消息时序的方法探讨》
《 IM单聊和群聊中的在线状态同步应该用“推”还是“拉”?》
《 IM群聊消息如此复杂,如何保证不丢不重?》
《 谈谈移动端 IM 开发中登录请求的优化》
《 移动端IM登录时拉取数据如何作到省流量?》
《 浅谈移动端IM的多点登陆和消息漫游原理》
《 完全自已开发的IM该如何设计“失败重试”机制?》
《 通俗易懂:基于集群的移动端IM接入层负载均衡方案分享》
《 微信对网络影响的技术试验及分析(论文全文)》
《 即时通讯系统的原理、技术和应用(技术论文)》
《 开源IM工程“蘑菇街TeamTalk”的现状:一场有始无终的开源秀》
《 QQ音乐团队分享:Android中的图片压缩技术详解(上篇)》
《 QQ音乐团队分享:Android中的图片压缩技术详解(下篇)》
《 腾讯原创分享(一):如何大幅提升移动网络下手机QQ的图片传输速度和成功率》
《 腾讯原创分享(二):如何大幅压缩移动网络下APP的流量消耗(上篇)》
《 腾讯原创分享(三):如何大幅压缩移动网络下APP的流量消耗(下篇)》
《 如约而至:微信自用的移动端IM网络层跨平台组件库Mars已正式开源》
《 基于社交网络的Yelp是如何实现海量用户图片的无损压缩的?》
《 腾讯技术分享:腾讯是如何大幅降低带宽和网络流量的(图片压缩篇)》
《 腾讯技术分享:腾讯是如何大幅降低带宽和网络流量的(音视频技术篇)》
《 为什么说即时通讯社交APP创业就是一个坑?》
《 字符编码那点事:快速理解ASCII、Unicode、GBK和UTF-8》
《 全面掌握移动端主流图片格式的特点、性能、调优等》
>> 更多同类文章 ……
[9] 开源移动端IM技术框架资料:
《 开源移动端IM技术框架MobileIMSDK:快速入门》
《 开源移动端IM技术框架MobileIMSDK:常见问题解答》
《 开源移动端IM技术框架MobileIMSDK:压力测试报告》
《 开源移动端IM技术框架MobileIMSDK:Android版Demo使用帮助》
《 开源移动端IM技术框架MobileIMSDK:Java版Demo使用帮助》
《 开源移动端IM技术框架MobileIMSDK:iOS版Demo使用帮助》
《 开源移动端IM技术框架MobileIMSDK:Android客户端开发指南》
《 开源移动端IM技术框架MobileIMSDK:Java客户端开发指南》
《 开源移动端IM技术框架MobileIMSDK:iOS客户端开发指南》
《 开源移动端IM技术框架MobileIMSDK:Server端开发指南》
>> 更多同类文章 ……
[10] 有关推送技术的文章:
《 iOS的推送服务APNs详解:设计思路、技术原理及缺陷等》
《 信鸽团队原创:一起走过 iOS10 上消息推送(APNS)的坑》
《 Android端消息推送总结:实现原理、心跳保活、遇到的问题等》
《 扫盲贴:认识MQTT通信协议》
《 一个基于MQTT通信协议的完整Android推送Demo》
《 IBM技术经理访谈:MQTT协议的制定历程、发展现状等》
《 求教android消息推送:GCM、XMPP、MQTT三种方案的优劣》
《 移动端实时消息推送技术浅析》
《 扫盲贴:浅谈iOS和Android后台实时消息推送的原理和区别》
《 绝对干货:基于Netty实现海量接入的推送服务技术要点》
《 移动端IM实践:谷歌消息推送服务(GCM)研究(来自微信)》
《 为何微信、QQ这样的IM工具不使用GCM服务推送消息?》
《 极光推送系统大规模高并发架构的技术实践分享》
《 从HTTP到MQTT:一个基于位置服务的APP数据通信实践概述》
《 魅族2500万长连接的实时消息推送架构的技术实践分享》
《 专访魅族架构师:海量长连接的实时消息推送系统的心得体会》
《 深入的聊聊Android消息推送这件小事》
《 基于WebSocket实现Hybrid移动应用的消息推送实践(含代码示例)》
《 一个基于长连接的安全可扩展的订阅/推送服务实现思路》
《 实践分享:如何构建一套高可用的移动端消息推送系统?》
《 Go语言构建千万级在线的高并发消息推送系统实践(来自360公司)》
《 腾讯信鸽技术分享:百亿级实时消息推送的实战经验》
《 百万在线的美拍直播弹幕系统的实时推送技术实践之路》
《 京东京麦商家开放平台的消息推送架构演进之路》
《 了解iOS消息推送一文就够:史上最全iOS Push技术详解》
>> 更多同类文章 ……
[11] 更多即时通讯技术好文分类:
http://www.52im.net/forum.php?mod=collection&op=all