标签:协议 Solon 异步 SocketD 响应 rpc RSocket
1. 简介
SocketD 是一种二进制的点对点通信协议,是一种新的网络通信第七层协议。旨在用于分布式应用程序中。从这个意义上讲,SocketD可以是RSocket等其他类似协议的替代方案。它的消息协议规范具有异步,背压的双向,多路复用,断线重连,基于消息等特性。暂时只提供Java实现,目前做为Solon rpc的sockte通道协议。
2. 背景
说到这里就有一些疑问了,为什么要搞这个协议?难道程序员吃饱了撑得搞点新东西折腾自己?上面提到了RSocket。如果你对这个规范不熟悉就可补下课。但它用起来还是比较复杂,尤其是类似RxJava的接口风格,感观上更利于做响应式计算。而SockteD更适应传统使用习惯,更专一的面向服务请求。
3. 特性
特性期实与RSocket非常像,这里简单总结一下:
- 具有语言无关性的二进制通信协议
- 异步非阻塞消息驱动通信,高性能
- 实现了网络通信的背压处理,在此基础上进行流量控制、连接恢复
- 天然支持双向通信。如:单链接双向RPC
- 更加适合分布式通信场景
4. SocketD三种交互模型
SocketD定义了三种交互模型来弥补Http协议的不足之处:
- Send(msg):只发送不响应。在不需要响应时非常有用,例如非关键事件日志记录。
- SendAndResponse(msg):发送并等待响应。类似Http的请求/响应模型。它是异步和多路复用的。
- SendAndCallback(msg, (msg2)->{}):发送并在有响应时回调。类似Ajax异步回调。
5. SocketD两种协议模型
容器消息,用于实现消息加密或压缩之类非业务处理。内容消息,用于承载业务内容。
6.部分演示示例
- Rpc 框架演示: solon_socketd_rpc
- Message 通读演示:solon_socketd_message
附:项目源码
标签:协议,Solon,异步,SocketD,响应,rpc,RSocket 来源: https://www.cnblogs.com/noear/p/14255823.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。