本文要谈的IM通信协议指的是应用层通信“语言”,并非指传输层协议(如TCP、UDP)。IM通信协议的制定是IM开发中起点,也是贯穿设计、开发、运维始终的核心所在,通信协议设计的好坏,直接影响后绪环节的用户体验(数据流量、耗电量、通信速度)、兼容性(新老版本的无缝融合)、扩展性(后绪的版本升级怎么办)等,是个基础且极其重要的工作之一。

IM通信协议的分层设计

所谓“协议”是双方共同遵守的规则,例如:离婚协议,停战协议。

协议有语法、语义、时序三要素:

(1)语法:即数据与控制信息的结构或格式

(2)语义:即需要发出何种控制信息,完成何种动作以及做出何种响应

(3)时序:即事件实现顺序的详细说明

一套典型的IM通信协议设计分为三层:应用层、安全层、传输层。

IM应用层协议设计

应用层协议选型,常见的有三种:文本协议、二进制协议、流式XML协议。

文本协议

文本协议是指 “贴近人类书面语言表达”的通讯传输协议,典型的协议是http协议。一个http协议大致长成这样:

GET / HTTP/1.1

User-Agent: curl

Host: musicml.net

Accept: */*

文本协议的特点是:

a. 可读性好,便于调试

b. 扩展性也好(通过key:value扩展)

c. 解析效率一般(一行一行读入,按照冒号分割,解析key和value)

d. 对二进制的支持不好 ,比如语音/视频

IM中,MSN使用的是文本协议。

二进制协议

二进制协议是指binary协议,典型是ip协议。

二进制协议一般定长包头和可扩展变长包体 ,每个字段固定了含义 ,例如IP协议的前4个bit表示协议版本号 (Version)。

二进制协议有这样一些特点:

a. 可读性差,难于调试

b. 扩展性不好 ,如果要扩展字段,旧版协议就不兼容了,所以一般设计时会有一个Version字段

c. 解析效率超高(几乎没有解析代价)

d. 对二进制的支持不好 ,比如语音/视频

IM中,QQ使用的时二进制协议。

流式XML协议

IM的准标准协议xmpp就是使用流式XML,像gtalk,校内通这些im都是基于xmpp的。让我们来看一个xmpp协议的例子:

<message

to=’[url=mailto:romeo@example.net]romeo@example.net[/url]’

from=’[url=mailto:juliet@example.com]juliet@example.com[/url]’

type=’chat’

xml : lang=’en’>

<body>Wherefore art thou, Romeo?</body>

</message>

从xml标签中大致可以判断这是一个romeo发给juliet的聊天消息。xmpp协议可以实现跨域的互通。例如gtalk和校内通用户聊天。只要服务端实现了s2s服务(server to server) ,不过现在的im基本没有互通需求 ,所以这个服务基本没有人实现。即时通讯开发

XMPP协议有几个特点:

a.它是准标准协议,可以跨域互通

b.XML的优点,可读性好,扩展性好

c.解析代价超高(dom解析)

d.有效数据传输率超低(大量的标签)

个人旗帜鲜明的强烈不建议使用xmpp,特别是无线端im,如果要用,一定要自己做压缩 ,减少网络流量(用过xmpp的同学都清楚,发一个登录包需要多少交互,要浪费多少流量)。

IM安全层协议设计

im协议,消息的保密性非常重要 ,谁都不希望自己聊天内容被看到,所以安全层是必不可少的。

使用SSL

证书管理微微复杂,代价有点高。

自行加解密

自己来搞加解密,核心在于密钥的生成与管理,密钥管理方式有多种,主要有这么三种:

(1)固定密钥

服务端和客户端约定好一个密钥,同时约定好一个加密算法(eg:AES ),每次客户端im在发送前,就用约定好的算法,以及约定好的密钥加密再传输,服务端收到报文后,用约定好的算法,约定好的密钥再解密。这种方式,密钥和算法对程序员都是透明的。

(2)一人一密钥

简单说来就是每个人的密钥是固定的,但是每个人之间又不同,其实就是在固定密钥的算法中包含用户的某一特殊属性,比如用户uid、手机号、qq号等。

(3)动态密钥(一session一密钥)

动态密钥,一Session一密钥的安全性更高,每次会话前协商密钥。密钥协商的过程要经过2次非对称密钥的随机生成,1次对称加密密钥的随机生成,具体详情这里不展开,有兴趣的同学可以看下SSL密钥协商额过程。

IM传输层协议设计

可选的协议有TCP和UDP。现在的IM传输层基本都是使用TCP,有了epoll等技术后,多连接就不是瓶颈了,单机几十万链接没什么问题。

im即时通讯开发:IM通信协议设计详解相关推荐

  1. im即时通讯开发:消息模型、万人群、已读回执、消息撤回功能

    企业微信作为一款办公协同的产品,聊天消息收发是最基础的功能.消息系统的稳定性.可靠性.安全性尤其重要. 消息系统的构建与设计的过程中,面临着较多的难点.而且针对toB场景的消息系统,需要支持更为复杂的 ...

  2. im即时通讯开发的那些坑:架构设计、通信协议和客户端

    有过移动端开发经历的开发者都深有体会:移动端IM的开发,与传统PC端IM有很大的不同,尤其无线网络的不可靠性.移动端硬件设备资源的有限性等问题,导致一个完整的移动端IM架构设计和实现都充满着大量的挑战 ...

  3. 即时通讯音视频开发(十):实时语音通讯的回音消除技术详解

    前言 即时通讯应用中的实时音视频技术,几乎是IM开发中的最后一道高墙.原因在于:实时音视频技术 = 音视频处理技术 + 网络传输技术 的横向技术应用集合体,而公共互联网不是为了实时通信设计的.有关实时 ...

  4. Android 即时通讯开发小结(一)

    本文将基于 IM Andriod 开发的各种常见问题,结合网易云信即时通讯技术的实践,对 IM 开发做一个全面的总结. 客户端架构 作为一个 IM 软件,最重要的一个特性就是保证消息的达到率和实时性. ...

  5. im即时通讯开发:移动端需要面对的问题

    统一介绍下一个IM APP的方方面面,包括技术选型(包括通讯方式,网络连接方式,协议选择)和常见问题. P2P还是服务器中转? IM通讯方式无非两种选择:设备直连(P2P)和通过服务器中转. 1P2P ...

  6. Android 即时通讯开发小结(二)

    <Android 即时通讯开发小结>基于IM Andriod 开发的各种常见问题,结合网易云信即时通讯技术的实践,对 IM 开发做一个全面的总结. 相关推荐阅读:. Android即时通讯 ...

  7. 谈谈即时通讯开发平台

    由于即时通讯系统的复杂性和对服务器稳定性的很高要求,一般即时通讯系统开发至少需要1年左右的时间,而这还只是测试版,离"稳定"还有一定距离,而这时匆匆上马的不稳定的系统会让你失去用户 ...

  8. im即时通讯开发:高可用、易伸缩、高并发的IM群聊、单聊架构方案设计

    要实现一整套能用于大用户量.高并发场景下的IM群聊,技术难度远超IM系统中的其它功能,原因在于:IM群聊消息的实时写扩散特性带来了一系列技术难题. 举个例子:如一个2000人群里,一条普通消息的发出问 ...

  9. 基于Netty实现分布式IM即时通讯开发

    计算机编程的学习,能不能把知识学到手,讲究的是动手实践.在我编写的文章中,基本都是以实践代码验证结果为核心来讲述文章内容. 可能有人不知道 Netty 是什么,这里简单介绍下: Netty 是一个 J ...

最新文章

  1. 数据库索引的实现原理?
  2. Airbnb欺诈预测机器学习模型设计:准确率和召回率的故事
  3. boost::graph模块实现读写graphml的测试程序
  4. java 批量为图片添加图标水印和文字水印
  5. myeclipse中的项目如何切换svn地址
  6. 32位程序如何在64位系统上运行_32位支持:使用 GCC 交叉编译 | Linux 中国
  7. Java如何连接数据库
  8. 微信购物商城网站定制需要多少钱?电商网站建设开发方案(一)
  9. 正逆运动学解(三维)
  10. 全减器---Verilog实现(结构描述,数据流描述,行为描述,层次结构描述)
  11. java.lang maven_maven 项目出现 java.lang.ClassNotFoundException
  12. android高仿今日头条小视频转场切换效果
  13. 【栈】问题 B: Problem E
  14. Java SE菜鸟之异常
  15. 清华计算机系19级研究生状元,2019年各省市高考状元去向统计,清华姚班受青睐,多达五人考入...
  16. 怎么修改文件创建时间?
  17. 搭建zabbix监控系统
  18. LaTex 之 TexLive 2020 + TexStudio 的安装及其他软件推荐
  19. 工欲利其器: sqlyog 智能执行功能详解.(http://my.oschina.net/phpnew/blog/151194)
  20. SEM-X射线荧光固体制样方法,请收好!

热门文章

  1. 被讨厌的勇气:目的论
  2. linux环境下启动数据库
  3. MinGW安装教程——著名C/C++编译器GCC的Windows版本
  4. 什么是真假性胃酸缺乏综合征?
  5. 文件服务器查询文件修改记录,文件服务器修改记录
  6. 认识EIT造形---android 架构
  7. CSS样式规则的具体,css样式规则
  8. 赣州市光华职业学校计算机部,2019年赣州市中职学校技能竞赛正式开赛
  9. pip3将安装包放在了哪里
  10. 我去看Linkin Park演唱会