1.问题背景
最近在项目中做监控功能:
负责被监控端(C端)的实现
通讯方式使用Socket,连接方式是监控端(V端)主动连接
主要功能如下:
- 与监控端建立连接
- 执行监控端下发的指令
- 主动上送状态信息
2.出现原因
C端处理报文判断逻辑为CommandId(通过解析报文得到,表示V端指令编号,不同编号对应不同的策略类,通过枚举方案得到策略类,指令具体实现在策略实现类中,通过策略接口调用实现方法,本文重点为遇到的问题,不作详细描述),但是由于V端请求报文与响应报文CommandId相同,就会导致C端无法判断V端报文为请求报文还是响应报文
3.影响
C端上送给V端后,V端响应.
由于C端无法区分V端请求报文与响应报文
导致C端将V端响应报文当做请求报文处理
或者C端将V端请求报文当做响应报文处理
4.解决方案
- 建立两条连接(避开请求响应的区分),一条长连接(http,或者socket)用于接收V端请求,一条短连接用于上送V端
- 区分请求响应,通过对请求响应报文的区分来进行响应处理(添加字段...)
- 抽取处理请求与处理响应的方法(处理请求与处理响应轮换)一次请求一次响应(改动最小,但是存在问题尚未解决:如果C端在发送请求等待V端响应的过程中,V端向C端发来请求,那么此时已经轮换为处理响应方法,就会将请求当作相应处理,响应回来之后又被轮换为处理请求,那就乱套了)
- 。。。