大家好,我是冰河~~
经过四个多月的坚持,《分布式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+套精美简历模板,助力小伙伴们跳槽面试、升职加薪,加入星球,猛戳如下链接获取。
- 简历模板:https://t.zsxq.com/193DYfk3U
五、如何学习
1.加入 冰河技术 知识星球(文末有知识星球优惠券,IM即时通讯系统完结了,即将涨价),才能查看星球专栏文章,学习专栏视频课程,查看置顶消息,申请加入项目,才能看到项目代码和技术小册,如果未申请加入项目,点击项目链接,你会发现是404页面。
2.专栏的每一章会对应一个代码分支,需要切换对应的分支学习对应的视频和文章的代码分支,同时,分布式IM即时通讯系统的每个服务模块都对应着一个单独的代码仓库,大家对照学习即可。
3.学习过程中最好按照章节顺序来学习,每一章前后都是比较连贯的,并且每一章的代码实现也有先后顺序,这样按照从前往后的顺序学习,最终你会实现一个完整的分布式IM即时通讯系统。
注意:学习的过程,不是复制粘贴代码的过程,赋值粘贴代码是没有任何意义的,最好的学习方式就是自己动手实现代码,然后思考、总结。
4.代码结构:master分支是最新的全量代码,专栏中每一个章节和视频都会对应一个代码分支,切换到章节对应的代码分支后,即可根据当前章节和视频学习对应的代码实现,不然,在master分支中看到的是全量的代码。
5.对应代码实现上的问题,可以在专栏对应的源码提issuse
6.冰河会为《分布式IM即时通讯系统》专栏录制完整的视频课程。
六、提交作业
在学习秒杀系统的过程中,为了有助于大家更好的消化吸收《分布式IM即时通讯系统》的知识,冰河会为大家布置相应的作业。当然,也是为了希望在学习的过程中,留下你真实的足迹,让我们一起努力,突破自身技术瓶颈。
1.代码作业
- 作业空间:https://gitcode.net/BingheProjects/im-projects-startball
- 空间说明:为知识星球的用户提供项目代码提交空间,方便针对项目进行技术交流,你可以把自己实现的《分布式IM即时通讯系统》源码提交到空间中,按照
项目名称-用户星球编号-作者名称
的格式创建仓库,例如bh-im-server-1-binghe
。
2.文字打卡
- 大家可以在 冰河技术 知识星球中,提交文字作业也可以进行文字打卡。
主要按照如下方式进行总结:
1.今天你学了哪些章节?
2.遇到的问题是什么?
3.你是怎么解决问题的?
4.今天的收获是什么?
基于大家的打卡或者作业反馈的问题,冰河会在后续以文章和直播的形式统一解决大家学习过程中的疑问。
七、获取源码
分布式IM即时通讯系统不仅可以用在真实的聊天场景中、还能接入多种真实的消息推送场景。这些真实场景的项目设计与落地实现,在冰河的知识星球除了分布式IM即时通讯系统外,还有其他5个项目,像Sekill分布式秒杀系统、手写RPC、简易商城系统等等,这些项目的需求、方案、架构、落地等均来自互联网真实业务场景,让你真正学到互联网大厂的业务与技术落地方案,并将其有效转化为自己的知识储备。
值得一提的是:冰河自研的比某些开源网关项目性能更优的生产级网关项目即将启动,你还在等啥?不少小伙伴经过星球硬核技术和项目的历练,早已成功跳槽加薪,实现薪资翻倍,而你,还在原地踏步,抱怨大环境不好。2024年抛弃焦虑和抱怨,我们一起塌下心来沉淀硬核技术和项目,让自己的薪资更上一层楼。
好了,今天就到这儿吧,我是冰河,我们下期见~~