本文引用了后端技术指南针公众号“浅谈RPC那些事儿1”和即时通讯网的“即时通讯新手入门:快速理解RPC技术——基本概念、原理和用途”两篇文章的部分内容。
本文已同步发布于“即时通讯技术圈”公众号,链接是:https://mp.weixin.qq.com/s/0RXTUWHXDmMddsPVWej2Qg
1、引言
经常有开发者在纠结怎么开发IM集群,虽然真正的使用人数,可能用个人电脑单机都能支撑。
你也许会说,明明不需要用到IM集群,干吗要自找麻烦?答曰:“老板说这个得有!”、“万一产品做成了,用户量达到百万、千万级呢?”,各种回答,反此种种。总之,IM集群就是得整一个(先甭管用不用的上...)。
当然,玩笑归玩笑,真正要做到可投入到生产级别的IM集群系统,难度还是相当大的。必竟IM这种长连接应用相比传统Http这种短连接应用太不标准。
我们以一个典型的IM聊天消息传输为例:
假设存在两个正在聊天的用户(用户A和用户B),当A连接的是IM集群中的IM实例1、B连接的是IM集群中的IM实例2,此时当用户A向用户B发送一条聊天消息时,这条消息应该如何传递呢?
我们梳理一下上面这个例子的消息流转过程:
- 1)IM聊天消息首先会由用户A发往IM实例1;
- 2)IM实例1会将此条消息转交给IM实例2;
- 3)IM实例2会将此条消息最终投递给连接在本实例上的用户B。
如上述流程所示,这就是一个IM集群系统中典型的聊天消息投递过程。
那么,这其中涉及到一个关键步骤:即第2)步中如何实现“IM实例1会将此条消息转交给IM实例2”?
此时,RPC技术出场了!
▲ 上图是个典型的分布式IM架构,注意中间的“RPC通信”字样(本图引用自《基于Go的马蜂窝旅游网分布式IM系统技术实践》)
本文将以通俗易懂的白话形式,帮你快速理解IM集群中的关键技术——RPC。
推荐阅读:另一篇RPC基础知识文章也值得一读《即时通讯新手入门:快速理解RPC技术——基本概念、原理和用途》。
2、相关文章
▼ 以下两篇文章有助于您对RPC和IM集群有个初步的概念:
▼ IM开发干货系列文章(本文是其第24篇):
《IM消息送达保证机制实现(一):保证在线实时消息的可靠投递》
《一种Android端IM智能心跳算法的设计与实现探讨(含样例代码)》
《IM开发基础知识补课(一):正确理解前置HTTP SSO单点登陆接口的原理》
《IM开发基础知识补课(二):如何设计大量图片文件的服务端存储架构?》
《IM开发基础知识补课(三):快速理解服务端数据库读写分离原理及实践建议》
《IM开发基础知识补课(四):正确理解HTTP短连接中的Cookie、Session和Token》
《IM群聊消息究竟是存1份(即扩散读)还是存多份(即扩散写)?》
《IM开发基础知识补课(五):通俗易懂,正确理解并用好MQ消息队列》
《