TCP组件设计篇(详细设计)

绝学无忧,唯之与阿,相去几何?善之与恶,相去若何?人之所畏,不可不畏。荒兮其未央哉!众人熙熙如享太牢、如春登台。我独泊兮其未兆,如婴儿之未孩;儡儡(lěi,羸弱)兮若无所归。众人皆有馀,而我独若遗。我愚人之心也哉!沌沌兮。俗人昭昭,我独昏昏;俗人察察,我独闷闷。众人皆有以,而我独顽且鄙。我独异於人,而贵食母。     ------《道德经-第二十章》

功能定义:

1:基于SSL TCP连接

2:支持多种解码器(String,XML,JSON,Protobuf)

非功能性功能定义:

1:心跳机制(只有在Client端长时间没有接收到消息或者发送消息情况下才发起心跳)

2:重连机制(重连机制包含重连次数和重连间隔时间)

3:白名单(V1.0不支持)

4:消息缓存重发机制(V1.0不支持)

5:手动拆包(V1.0不支持)

依赖第三方组件

1:Netty

2:FastJson

3:GoogleProtobuf

4:EventBus

5:Guava

各个组件使用场景

1:Netty:处理TCP通信,并且将接收到的消息转发给EventBus

2:FastJson:JSON格式解码

3:GoogleProtobuf:Protobuf格式解码

4:EventBus:事件总线,将消息转发给业务层

5:Guava:缓存

常量的定义:

1:内置消息类型(1:心跳 2:注册 3:连接成功 4:转发)

2:解码类型(1:String  2:JSON 3:XML 4:Protobuf)

消息定义

1:整体消息定义

整体消息

2:消息Header定义

消息Header

流程说明:

1:链路建立:

当客户端与服务端链路建立成功,由客户端发起注册请求信息,请求信息定义如下:

注册消息

服务端接收到客户端的注册消息之后,如果Client ID校验已经通过(因为使用SSL认证,这边只做Client ID是否重复操作),返回注册成功应答消息给客户端,应用层链路建立成功。返回消定义如下

注册返回

2:心跳机制

在业务处于低谷时期,如果发生网络闪断,连接被Hang住等网络问题,由于没有业务消息,应用进程很难发现。但是等到白天业务高峰期间是,会发生大量的网络通信失败,这就会严重导致一段时间内进程内无法处理业务消息,为了解决这个问题,在网络空闲的时候采用心跳机制来检测链路的互通性,一旦发现网络故障,理解关闭链路,主动重连。

常用的设计方式为:做一个定时任务,间隔一段时间发送心跳,这样做其实在有业务交互的场景下非常浪费资源。

本次设计方法:

1)只有在网络处于空闲状态持续达到某一个时间(所谓网络空闲指的是一段时间没有读写消息),这个时候客户端就要发送Ping 心跳信息到服务端。

2)当在下一个时间段的到来之前业务之间消息来往,则不需要发送心跳,直到下一个网络空闲时候才发送心跳

3)当服务端很长时间没有接收到客户端发送的心跳或者业务消息的时候,服务端则强制关闭客户端连接,客户端则必须重新连接。

3:重连机制

如果链路出现中断,等待间隔时间以后,由客户端重新发起连接,如果连接失败记录连接失败次数,再次等待间隔时间发起连接,如果一直没有连接成功,当失败次数大于定义的次数的时候停止重新连接。如果连接成功则将连接失败次数设置为0.

4:消息缓存重发

不管对于客户端还是服务端,当发现链路中断之后,在链路恢复之前,必须要将消息缓存起来,保证消息不能丢失,等待链路回复之后,重新发送这些消息。考虑到内存溢出的情况,消息缓存队列必须设置上限,当达到上限之后,要不然移除前面的消息或者不容许新的消息被添加到消息队列中。

Netty Handler加载顺序

服务端Handler加载顺序

服务端Handler加载顺序图

说明:

1)LoggingHandler:Netty内置Handler,日志输出

2)SslHandler:Netty内置Handler,处理SSL连接

3)NettyServerRegisterHandler:自定义Handler,处理注册消息

4)NettyServerHeartBeatHandler:自定义Handler,处理心跳消息

5)NettyServerHandler:自定义Handler,处理业务消息,并且将消息发送给业务

客户端Handler加载顺序

客户端Handler加载顺序图

说明:

1)LoggingHandler:Netty内置Handler,日志输出

2)SslHandler:Netty内置Handler,处理SSL连接 

3)NettyClientHandler:自定义Handler,处理业务消息

核心类设计

解码器设计类图:

解码器设计类图

说明:

Netty内置了String,Protobuf等一些解码器,因为本次开发组件是内部使用,所以自定义了私有协议栈。那么就必须自定义了解码器。

消息类定义

Message类
Message Header

流程说明:

1:由Netty接收到Client发过来的数据提交给自定义解码器(MessageDecoder)

2:MessageDecoder将byte[]转换为Message对象。

3:Netty将Message对象提交给业务Handler。

4:业务Handler将Message提交给EventBus。

5:EventBus根据MessageType找到当前消息对应的业务Event。

6:EventBus根据DecoderType找到当前消息体内的需要解码的类型

7:Decoder将Message中的Body转换为业务对象,提交给业务Event。

客户端和服务端联调测试用例(本测试只是测试功能)

测试用例
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,458评论 6 513
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 94,030评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,879评论 0 358
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,278评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,296评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 52,019评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,633评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,541评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 46,068评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,181评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,318评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,991评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,670评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,183评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,302评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,655评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,327评论 2 358

推荐阅读更多精彩内容

  • 该文章为转载,原文章请点击 1. 背景 1.1. Netty 3.X系列版本现状 根据对Netty社区部分用户的调...
    Pramyness阅读 1,977评论 1 14
  • 前奏 https://tech.meituan.com/2016/11/04/nio.html 综述 netty通...
    jiangmo阅读 5,860评论 0 13
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,226评论 25 707
  • 课程的学习是在网易云课堂找的,下面是我的一些纪录,课堂地址:http://study.163.com/course...
    飞翼_U阅读 380评论 0 0
  • 他妈的,为什么,我什么我卢屹就该经历这些,磨难的最后是什么,妈蛋的还是失败,为什么?
    卢屹阅读 236评论 2 1