IM项目的整体架构

目录

1.引言

2.项目架构

3.使用到的框架/库

4.结语


1.引言

这个项目会涉及到不少的第三方库或者中间件,很能锻炼人。在开始编写项目代码之前,首先对整体的架构有个了解。

2.项目架构

这个项目采用的是微服务架构,整体上分为七个子服务。分别是:

  1. 用户管理子服务: 主要用来管理用户数据,包括用户的登录注册、信息查询、 修改用户信息(比如头像、昵称、签名等)。
  2. 好友管理子服务:主要用来管理好友数据和聊天会话数据,包括添加好友、删除好友、创建聊天会话、删除聊天会话、获取聊天会话成员等操作。
  3. 文件管理子服务:主要用来管理系统中文件类型的数据,比如用户的头像、文件类型的消息等,提供单文件的上传和下载接口和多文件的上传和下载接口。
  4. 消息管理子服务:主要用来管理用户的消息,包括历史消息的获取、查询、持久化保存等。
  5. 转发管理子服务:主要用来告诉网关子服务消息的转发对象,同时将消息封装,添加必要信息后发送到消息队列,供消息管理子服务消费。
  6. 语音识别子服务:调用百度的语音识别SDK,将语音转换成文字。
  7. 网关子服务:主要用来和客户端进行直接交互,将客户端的请求转发到对应的子服务上进行处理,然后将处理结果返回给客户端。

3.使用到的框架/库

**gflags:**一个由谷歌开发的命令行参数解析库,主要用于解析程序运行时的命令行参数。

**gtests:**由谷歌开发的单元测试框架,用于单元测试。

**spdlog:**一个高性能的日志库,在项目中用于日志输出,但是由于日志输出没有带上文件名和行号,不好定位错误代码,因此在项目中封装了再使用。

**protobuf:**语言无关、平台无关的序列化协议。用于结构化数据的序列化和反序列化,相比于XML、JSON等格式,具有更小的体积、更快的速度、更强的兼容性。

**brpc:**百度研发的高性能RPC框架,具有高并发、低延迟的特性。

**Redis:**高性能的内存级数据库,项目中用于存储和管理用户的登录会话。

**MySQL:**关系型数据库,用于项目中业务数据的存储。

**ODB:**一个C++的对象关系映射系统,将C++类映射到数据库表,类的成员变量映射到表的字段。对象的创建、修改、查询、删除操作自动转换为对应的SQL语句。

**etcd:**一个开源的分布式存储系统,可以为存储的键值设置租约和续约,项目中用于搭建注册中心。

**cpp-httplib:**用于搭建HTTP服务器------接收客户端的HTTP请求。

**WebSocketpp:**用于搭建WebSocket服务器------和客户端之间建立持久化连接,并且服务器可以主动推送消息给客户端。

**语音云平台:**调用百度的语音识别SDK。

**短信云平台:**由于政策限制,采用固定的验证码。

**CMake:**项目构建工具。

**Docker:**项目部署工具。

4.结语

路漫漫其修远兮,吾将上下而求索!


相关推荐
春天花会开13120 小时前
Kubernetes 高可用架构实战指南
架构
码云之上20 小时前
万星入坞·其三:SDK 轻量组件如何优雅地"点亮"
性能优化·架构·前端框架
枫叶林FYL20 小时前
【强化学习】3 双系统持续强化学习:快速迁移与元知识整合架构手册
人工智能·机器学习·架构
AI科技星20 小时前
哥德巴赫猜想1+1基于平行素数对等腰梯形网格拓扑与素数渐近密度的大偶数满填充完备性证明
人工智能·线性代数·架构·概率论·学习方法
小短腿的代码世界21 小时前
信号路由风暴:Qt算法交易系统的高频信号分发架构
qt·算法·架构
2301_7807896621 小时前
手游遇到攻击为什么要用SDK游戏盾手游遇到攻击为什么要用 SDK 游戏盾?
安全·web安全·游戏·架构·kubernetes·ddos
中小企业实战军师刘孙亮1 天前
小微企业生存发展指南:从求稳到扩张的实战策略-佛山鼎策创局破局增长咨询
架构·产品运营·音视频·制造·业界资讯
sanduo1121 天前
什么是优秀的部署架构?
架构
国科安芯1 天前
ASP7A84AS与主流架构兼容替代及系统级电源完整性解决方案的深度研究
单片机·嵌入式硬件·架构
JZC_xiaozhong1 天前
研发体系集成架构:打通OA与PLM的核心参考
大数据·架构·流程自动化·数据集成与应用集成