# 《分布式IM系统》总结-分布式IM即时通讯系统整体专栏总结

作者:冰河
星球:http://m6z.cn/6aeFbs (opens new window)
博客:https://binghe.gitcode.host (opens new window)
文章汇总:https://binghe.gitcode.host/md/all/all.html (opens new window)
源码获取地址:https://t.zsxq.com/0dhvFs5oR (opens new window)
专栏内容汇总地址:https://articles.zsxq.com/id_i652r0adp3gu.html (opens new window)

沉淀,成长,突破,帮助他人,成就自我。

  • 本节难度:★★☆☆☆
  • 本节重点:对分布式IM即时通讯系统的整体专栏内容进行回顾和总结,以及对后续的规划进行简要的总结和概括,掌握分布式IM即时通讯系统涉及到的核心技术和知识点,掌握单聊消息与群聊消息在分布式IM即时通讯系统中的流转过程,掌握好友关系与群组和群成员的核心设计,掌握大前端UI与后端服务的整体交互流程设计和实现。

大家好,我是冰河~~

经过四个多月的坚持,《分布式IM即时通讯系统》终于接近尾声了,也感谢大家这四个多月以来的坚持和陪伴,也相信大家在《分布式IM即时通讯系统》专栏中,学到了不少知识和技术。接下来,我们就一起对《分布式IM即时通讯系统》专栏做个总结。

# 一、核心需求

截止到目前,我们已经设计和实现了分布式IM即时通讯系统专栏最核心的内容, 我们来回顾下分布式IM即时通讯系统的核心需求。

分布式IM即时通讯系统本质上就是对线上聊天和用户的管理,针对聊天本身来说,最核心的需求就是:发送文字、表情、图片、文件、语音、视频、消息缓存、消息存储、消息未读、已读、撤回,离线消息、历史消息、单聊、群聊,多端同步,对接OpenAI大模型,以及其他一些需求。

对用户管理来说,存在的需求包含:添加好友、查看还有列表、删除好友、查看好友信息、创建群聊、加入群聊、查看群成员信息、@群成员、退出群聊、修改群昵称、拉人进群、踢人出群、解散群聊、填写群公告、修改群备注以及其他用户相关的需求等。

# 二、总体概述

分布式IM即时通讯系统是一个整体采用DDD架构设计、前后端分离的、高性能、高度可扩展的、可直接部署运行的IM即时通讯平台,涵盖:即时通讯后端服务、即时通讯SDK、大后端平台、大前端UI和OpenAI接入服务。其中,大后端平台又分为用户微服务、好友微服务、群组微服务和消息微服务。

在分布式IM即时通讯系统专栏中,完成了20个大的篇章,共103篇文章,如下图所示。


可以这么说,在分布式IM即时通讯系统中,我们已经完整实现了即时通讯最基础和最核心的功能,支持好友和群组关系,支持单聊和群聊,支持发送文本消息、表情消息、图片消息、文件消息、语音消息和双向视频呼叫。并且在单聊消息流程和群聊消息流程中,接入了OpenAI大模型。

在分布式IM即时通讯系统的整体架构设计和实现中,共分为即时通讯后端服务、即时通讯SDK、大后端平台、大前端UI和OpenAI接入服务。其中,大后端平台又分成了用户微服务、好友微服务、群组微服务和消息微服务。每个部分都是高度可扩展、可独立部署运行的,并且每一部分都支持集群化部署。


通过《分布式IM即时通讯系统》专栏,让大家从需求设计、原型设计、架构设计、编码实现、项目优化、项目部署、极致优化等多个层面真正掌握高并发、高性能、高可用、高可扩展和高可维护项目的架构设计与实际落地方案。

另外,每一篇专栏的内容,冰河都会为其录制对应的视频课程进行加持。


通过文章+视频+小册+源码+答疑的方式进行全方位学习,还有比这更爽的事情吗?

# 三、技术选型

在技术选型上,除了采用SpringBoot等基础框架外,也会采用容器化方案。为了尽量降低技术门槛,在整个分布式IM即时通讯系统的技术选型中,主要采用市面上比较主流的技术框架和方案,具体技术选型如下所示。

  • 开发框架:SpringBoot、SpringCloud、SpringCloud Alibaba、Dubbo。
  • 缓存:Redis分布式缓存+Guava本地缓存。
  • 数据库:MySQL、TiDB、HBase。
  • 流量网关:OpenResty+Lua。
  • 业务网关:SpringCloud Gateway + Sentinel。
  • 持久层框架:MyBatis、Mybatis-Plus。
  • 服务配置、服务注册与发现:Nacos。
  • 消息中间件:RocketMQ。
  • 网络通信:Netty。
  • 文件存储:Minio。
  • 日志可视化治理:ELK。
  • 容器化管理:Swarm、Portainer。
  • 监控:Prometheus、Grafana。
  • 前端:Vue。
  • 单元测试:Junit。
  • 基准测试:JMH。
  • 压力测试:JMeter。

授人以鱼,不如授人以渔。后续我会把监控平台、容器化管理、日志可视化、大数据等等内容单独拿出来讲,每项技术、每个框架单独写个小项目实操,这样安排的话,相信大家会对这部分内容有更加深刻的理解,后续无论是哪个项目,只要是涉及到监控、容器化、链路追踪、日志可视化、大数据相关的内容时,大家都可以参考这部分内容进行实现。

所以,通过分布式IM即时通讯系统,可以学习到微服务领域和DDD架构领域的主流核心技术。

# 四、适应人群

由于分布式IM即时通讯统是从需求立项开始,从零一步步搭建环境、设计原型、设计架构、编码开发、运行调试和上线部署的,使用到的技术也是带着大家直接上手的。所以,整个专栏从小白到有一定开发经验的中高级工程师,有一定基础的架构师都可以学习。如果你当前或者长期受如下问题困扰,那你就更需要学习《分布式IM即时通讯系统》专栏了。

  • 在校大学生,想在毕业设计时,写一个有亮点的项目让导师眼前一亮。
  • 应届毕业生,找实习或工作时,想让自己的项目更具竞争力。
  • 一直在小公司做CRUD,并发编程没接触过,更别提如何高并发实际项目了。
  • 公司项目没什么并发,在线人数也不多,学了很多并发编程相关的知识不知道怎么用。
  • 学了很多并发编程的知识,也知道一些概念,能说出一些简单的方案,但是没实际项目经验。
  • 自我感觉掌握了一些高并发编程的技术方案,但是如果真正做项目时,还是不知道如何下手。
  • 简历上写了熟悉并发编程,在面试过程中,面试官一般会问秒杀系统,实时消息推动系统,IM即时通讯系统,或者其他高并发项目实战问题,不知道怎么回答。
  • 在大厂工作多年,参与了一些系统的建设与研发,但是也没机会参与像秒杀系统,IM即时通讯系统这样高并发、大流量的系统的整个建设过程。
  • 其他问题。。。

可以看到,如果小公司的小伙伴受限于业务,接触不到高并发、大流量的业务场景,大厂的小伙伴由于某些原因没有被分到高并发、大流量业务部门。没有系统性落地成实际高并发项目的经验,这样的小伙伴更需要学习《分布式IM即时通讯系统》。

如果小伙们是在线大学生,想让自己的毕业设计项目更加具备亮点,如果是应届毕业生,找实习或者工作时,想让自己的项目更具竞争力,都可以学习《分布式IM即时通讯系统》。

另外,冰河在星球分享了1000+套精美简历模板,助力小伙伴们跳槽面试、升职加薪,加入星球,猛戳如下链接获取。

# 五、如何学习

1.加入 冰河技术 知识星球(文末有知识星球优惠券,IM即时通讯系统完结了,即将涨价),才能查看星球专栏文章,学习专栏视频课程,查看置顶消息,申请加入项目,才能看到项目代码和技术小册,如果未申请加入项目,点击项目链接,你会发现是404页面。

2.专栏的每一章会对应一个代码分支,需要切换对应的分支学习对应的视频和文章的代码分支,同时,分布式IM即时通讯系统的每个服务模块都对应着一个单独的代码仓库,大家对照学习即可。

3.学习过程中最好按照章节顺序来学习,每一章前后都是比较连贯的,并且每一章的代码实现也有先后顺序,这样按照从前往后的顺序学习,最终你会实现一个完整的分布式IM即时通讯系统。

注意:学习的过程,不是复制粘贴代码的过程,赋值粘贴代码是没有任何意义的,最好的学习方式就是自己动手实现代码,然后思考、总结。

4.代码结构:master分支是最新的全量代码,专栏中每一个章节和视频都会对应一个代码分支,切换到章节对应的代码分支后,即可根据当前章节和视频学习对应的代码实现,不然,在master分支中看到的是全量的代码。

5.对应代码实现上的问题,可以在专栏对应的源码提issuse

6.冰河会为《分布式IM即时通讯系统》专栏录制完整的视频课程。

# 六、提交作业

在学习秒杀系统的过程中,为了有助于大家更好的消化吸收《分布式IM即时通讯系统》的知识,冰河会为大家布置相应的作业。当然,也是为了希望在学习的过程中,留下你真实的足迹,让我们一起努力,突破自身技术瓶颈。

# 1.代码作业

  • 作业空间:https://gitcode.net/BingheProjects/im-projects-startball (opens new window)
  • 空间说明:为知识星球的用户提供项目代码提交空间,方便针对项目进行技术交流,你可以把自己实现的《分布式IM即时通讯系统》源码提交到空间中,按照 项目名称-用户星球编号-作者名称 的格式创建仓库,例如 bh-im-server-1-binghe

# 2.文字打卡

  • 大家可以在 冰河技术 知识星球中,提交文字作业也可以进行文字打卡。

主要按照如下方式进行总结:

1.今天你学了哪些章节?

2.遇到的问题是什么?

3.你是怎么解决问题的?

4.今天的收获是什么?

基于大家的打卡或者作业反馈的问题,冰河会在后续以文章和直播的形式统一解决大家学习过程中的疑问。

# 七、如何加入星球

分布式IM即时通讯系统不仅可以用在真实的聊天场景中、还能接入多种真实的消息推送场景。这些真实场景的项目设计与落地实现,在冰河的知识星球除了分布式IM即时通讯系统外,还有其他5个项目,像Sekill分布式秒杀系统、手写RPC、简易商城系统等等,这些项目的需求、方案、架构、落地等均来自互联网真实业务场景,让你真正学到互联网大厂的业务与技术落地方案,并将其有效转化为自己的知识储备。

值得一提的是:冰河自研的比某些开源网关项目性能更优的生产级网关项目即将启动,你还在等啥?不少小伙伴经过星球硬核技术和项目的历练,早已成功跳槽加薪,实现薪资翻倍,而你,还在原地踏步,抱怨大环境不好。2024年抛弃焦虑和抱怨,我们一起塌下心来沉淀硬核技术和项目,让自己的薪资更上一层楼。

星球优惠券

目前,领取5折优惠券,就可以跟冰河一起学习《简易商城脚手架项目》、《手撸RPC专栏》和《Spring6核心技术与源码解析》、《实战高并发设计模式》、《分布式IM即时通讯系统》和《分布式IM即时通讯系统》,从零开始介绍原理、设计架构、手撸代码。

花很少的钱就能学这么多硬核技术、中间件项目和大厂秒杀系统与分布式IM即时通讯系统,比其他培训机构不知便宜多少倍,硬核多少倍,如果是我,我会买他个十年!

加入要趁早,后续还会随着项目和加入的人数涨价,而且只会涨,不会降,先加入的小伙伴就是赚到。

另外,还有一个限时福利,邀请一个小伙伴加入,冰河就会给一笔 分享有奖 ,有些小伙伴都邀请了50+人,早就回本了!

# 八、其他方式加入星球

特别提醒: 苹果用户进圈或续费,请加微信 hacker_binghe 扫二维码,或者去公众号 冰河技术 回复 星球 扫二维码加入星球。

# 九、联系冰河

# 1.加群交流

本群的宗旨是给大家提供一个良好的技术学习交流平台,所以杜绝一切广告!由于微信群人满 100 之后无法加入,请扫描下方二维码先添加作者 “冰河” 微信(hacker_binghe),备注:星球编号

冰河微信

# 2.公众号

分享各种编程语言、开发技术、分布式与微服务架构、分布式数据库、分布式事务、云原生、大数据与云计算技术和渗透技术。另外,还会分享各种面试题和面试技巧。内容在 冰河技术 微信公众号首发,强烈建议大家关注。

公众号:冰河技术

# 3.视频号

定期分享各种编程语言、开发技术、分布式与微服务架构、分布式数据库、分布式事务、云原生、大数据与云计算技术和渗透技术。另外,还会分享各种面试题和面试技巧。

视频号:冰河技术

# 4.星球

加入星球 冰河技术 (opens new window),可以获得本站点所有学习内容的指导与帮助。如果你遇到不能独立解决的问题,也可以添加冰河的微信:hacker_binghe, 我们一起沟通交流。另外,在星球中不只能学到实用的硬核技术,还能学习实战项目

关注 冰河技术 (opens new window)公众号,回复 星球 可以获取入场优惠券。

知识星球:冰河技术