系统设计,协议先行。 大部分人不了解协议的设计细节,更多使用已有协议进行应用层设计,例如: (1)使用HTTP,设计get/post/cookie参数,以及json包格式; (2)使用dubbo,而不用去深究内部的二进制包头包体细节; 无论如何,了解协议设计的原则,对深入理解系统通信非常有帮助。 一、协议的分层设计 画外音:后文主要讲语法设计。 协议设计通常分为三层:应用层协议、安全层协议、传输层协议。 二、应用层协议设计 应用层协议选型,常见的有三种:文本协议、二进制协议、流式XML协议。 文本协议 文本协议是指“贴近人类书面语言表达”的通讯传输协议,典型的协议是HTTP协议,一个HTTP协议的请求报文样例如下:
文本协议的特点是: 二进制协议 (1)定长包头; (2)可扩展变长包体; (3)一般每个字段有固定的含义,以IP协议为例,前4个bit表示协议版本号(Version); 二进制协议的特点是: (1)可读性差,难于调试; 画外音:打日志一般需要一个toString()函数增强可读性。 (2)扩展性不好,如果要扩展字段,旧版协议就不兼容了,所以设计时一般会有一个Version字段; 这是一个典型的16字节二进制定长包头的例子:
其中: (1)前4个字节表示版本号version; (2)接下来4个字节表示魔法数字magic_num,用来解决数据错位或丢包问题; 画外音:例如,约定好魔法数字是0x01020304,收到的报文,魔法数字匹配,认为是正常报文,否则认为是报文异常,断开连接。 (3)接下来4个字节表示命令号command,不同的命令号对应不同的变长包体; 这是一个实际的二进制变长包体:
它使用的是Google的Protobuf协议,容易看到: (1)请求报文传入的是用户名与密码; (2)响应包返回的是用户的uid; (2)自带压缩功能; (3)对二进制友好; (4)在工业界已广泛应用; 流式XML协议
从xml标签中大致可以判断这是一个romeo发给juliet的聊天消息。
(3)有效数据传输率超低,有大量的标签; (4)对二进制不友好 ,比如语音/视频等; 三、安全层协议设计 安全层协议设计,除了使用SSL,自行实现的话,常见的又有以下三种方案。 画外音:SSL秘钥管理是个问题。 固定密钥 画外音:安全性低,安全性基于程序员的职业操守。 一人一密 (1)固定加密算法; (2)加密秘钥使用“用户的某一特殊属性”,比如用户uid、手机号、qq号、用户密码等; 一次一密 四、传输层协议设计 架构师之路-分享可落地的技术文章 调研: 贵司的加密,是在代码中写死秘钥么? |
|
来自: 阁楼的猫s859sx > 《待分类》