IM项目:进阶版即时通讯项目---项目总览

2024-09-02 18:44

本文主要是介绍IM项目:进阶版即时通讯项目---项目总览,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 写在前面
  • 相关文档
  • 相关架构
    • 网关服务
    • 用户管理
    • 好友管理
    • 文件管理
    • 消息管理
    • 转发管理
    • 语音转换

写在前面

之前用Qt已经完成过一个即时通讯的项目,具体如下:

Qt项目:C++全栈聊天项目总结

在这个项目的引导下,接触到了如何使用grpc协议来进行RPC调用,之后又对于项目进行了一些其他的改造,主要的侧重点在于对于服务的分布式部署,然后服务和服务之间使用的就是这个rpc协议来进行调用

但是上一个项目并不完善,在很多部分都有可以优化的地方,比如服务注册,服务注册,在这个项目中,服务和服务并不知道对方的存在,只是从配置文件中进行简单的读取,然后根据读取出的ip地址和端口号来进行调用,后来随着学习,了解到了一些服务注册中心,例如Zookeeper,Ectd这些服务

因此做了这个新的项目,这个项目主要是对于上一个项目进行一个进阶的补充,也在一些地方进行优化,比如引入了elasticsearch进行更加高级的文档存储和搜索的服务器,以及ODB进行数据库对象的操作等。总的来说,这个项目比上一个项目更加规范,逻辑更加紧密

相关文档

由于项目比较大,将内容写在一篇博客并不现实,所以这里提供链接,对于相关模块感兴趣可以跳转到对应的博客查看,本篇主要进行一个整体架构的逻辑梳理,希望能迅速帮助读者理解项目的大体逻辑

IM项目:进阶版即时通讯项目—语音识别和验证码服务

IM项目:进阶版即时通讯项目—文件存储和消息转发

IM项目:进阶版即时通讯项目—消息存储

IM项目:进阶版即时通讯项目—用户管理(纯业务)

IM项目:进阶版即时通讯项目—好友管理和网关服务

相关架构

网关服务

作为网关,负责和客户端进行直接对接,并在鉴别权限之后,即可分发到对应的服务进行处理,接收到相应后,再返回给客户端,同时包含有用户身份验证的功能,避免被恶意请求所攻击,如果不带有这些字段,那么不予提供任何服务

那对应的提供又分成两种通信,分别是HTTP协议和WebSocket协议

  1. Http协议:传统的业务必然使用Http协议就可以,而实际上也有像这种httplib这样的,非常好用的http库,所以在项目中,绝大多数的服务都是借助Http来进行通信的,这样就能满足对应的接口了
  2. WebSocket协议:在聊天室项目中,也有一些服务是Http做不到的,需要服务器主动推送资源,而这对于Http协议来说是做不到的,即使在Http后续的优化中引入了主动推送部分资源的功能,但是也依旧不能满足需要。所以就引入了这个WebSocket协议

这也是和前面的项目的第一个不太一样的地方,在上一个项目中,并没有使用对应的WebSocket协议,而是直接基于TCP协议进行了一个自己程度的封装,因为TCP协议本身是一个全双工的协议,所以在Qt中直接使用一个TCP的长连接来对于消息的传输。而在这个项目中,直接使用WebSocket来进行服务,可以向客户端发送数据

网关服务基本就这些内容,下面主要说说网关服务背后的这些微服务的点

用户管理

用户管理服务,主要进行用户信息的各项操作,对比第一个版本的项目来说,这里不一样的点主要是多了一个短信验证服务,接入了阿里云的短信认证,可以发送短信,也多了更多的用户信息的修改,多了上传头像的功能,在之前的项目中,并没有对于头像的支持,因为没有含有对应的文件管理系统,所以头像这样的文件资源就没有进行一个合适的存储

好友管理

这个模块基本类似,含有获取列表,申请好友,处理请求,删除好友,用户搜索,获取聊天会话这些内容,和上个项目的改进主要体现在了引入了elasticsearch来进行模糊的搜索,elasticsearch也可以理解为是一个可以提供模糊搜索的数据库,在一些特殊的场景下搜索的效率是要比MySQL高的

文件管理

这是新加的模块,但其实也比较简单,就是一个单纯的文件的上传和下载,直接使用C++内部封装的文件流的读取和下载即可

消息管理

主要的功能是,获取历史消息和消息搜索

转发管理

借助RabbitMQ来完成转发服务,关于RabbitMQ在我的项目中也有介绍到,这里选该队列主要考虑到主题式的分发可能更加适合于当前的场景

语音转换

这里主要是借助的是百度云的SDK,直接调用其接口即可,在上面进行了一些二次的封装

这篇关于IM项目:进阶版即时通讯项目---项目总览的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1130760

相关文章

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基

springboot项目如何开启https服务

《springboot项目如何开启https服务》:本文主要介绍springboot项目如何开启https服务方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录springboot项目开启https服务1. 生成SSL证书密钥库使用keytool生成自签名证书将

将Java项目提交到云服务器的流程步骤

《将Java项目提交到云服务器的流程步骤》所谓将项目提交到云服务器即将你的项目打成一个jar包然后提交到云服务器即可,因此我们需要准备服务器环境为:Linux+JDK+MariDB(MySQL)+Gi... 目录1. 安装 jdk1.1 查看 jdk 版本1.2 下载 jdk2. 安装 mariadb(my

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

springboot项目中常用的工具类和api详解

《springboot项目中常用的工具类和api详解》在SpringBoot项目中,开发者通常会依赖一些工具类和API来简化开发、提高效率,以下是一些常用的工具类及其典型应用场景,涵盖Spring原生... 目录1. Spring Framework 自带工具类(1) StringUtils(2) Coll

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加