分布式websocket IM即时通讯聊天开源项目如何启动

前言

自己之前分享了分布式websocket的视频有同学去fork项目了,自己启动一下更方便理解项目嘛。然后把项目启动需要的东西全部梳理出来。支持群聊单聊,表情包以及发送图片。 支持消息可靠,消息防重,消息有序。同时基础架构有分布式权限,分布式唯一id,分布式websockt, 分布式事务等常见的分布式技术。

已经分享的文章
git项目地址 【IM即时通信系统(企聊聊)】点击可跳转

分布式websocket即时通信(IM)系统构建指南【第七期】
分布式websocket即时通信(IM)系统保证消息可靠性【第八期】
分布式websocket IM聊天系统相关问题问答【第九期】
什么?websocket也有权限!这个应该怎么做?【第十期】
分布式ID是什么,以美团Leaf为例改造融入自己项目【第十一期】
IM聊天系统为什么需要做消息幂等?如何使用Redis以及Lua脚本做消息幂等【第12期】
微信发送一条消息经历哪些过程。企业微信以及钉钉的IM架构对比【第13期】
微信群为什么上限是500人,IM设计系统中的群聊的设计难点【第14期】
【分布式websocket】RocketMQ发送消息保证消息最终一致性需要做哪些处理?【第15期】

【分布式websocket】群聊中的各种难点以及解决推拉结合【第16期】

【分布式webscoket】未读消息如何设计?解决缓存与数据库数据一致性!推送未读消息流程【第17期】

IM系统客户端消息存储在手机电脑浏览器分别存储在什么地方?对消息加密策略?如何保证服务端消息和客户端消息一致性【第18期】
【分布式websocket 】前端vuex管理客户端消息crud!使用localStorage来存储【第19期】

sql脚本

yan-v3.sql 是其中涉及到的表结构。

表结构主要是yan_im开头的表。sys开头的主要是用户中心的模块。主要使用他来进行用户登录和注册。

每个表的大概作用

leaf_allc 是美团leaf的表。用于生成分布式唯一id。

用户中心使用的用户表为sys_user表。注册的用户在这个里面;

yan_im_user 存储着用户信息。

聊天消息主要存储在yan_im_user_chat这张表里面。

前置东西

Naocs,Redis,RocketMQ Mysql8 Maven npm

如图所示,主要要安装Naocs,Reids和Rocketmq。有了这三个中间件。就可以启动项目了。

前端

需要 npm run serve 来运行:

后端需要启动的服务;

后台需要至少四个服务。

文件服务需要使用到阿里云oss配置,需要自己去阿里云申请。但是这个服务也不影响一些基础的聊天消息发送服务。

相关推荐
hweiyu0018 分钟前
Maven 私库
java·maven
Super Rookie26 分钟前
Spring Boot 企业项目技术选型
java·spring boot·后端
写不出来就跑路31 分钟前
Spring Security架构与实战全解析
java·spring·架构
ZeroNews内网穿透1 小时前
服装零售企业跨区域运营难题破解方案
java·大数据·运维·服务器·数据库·tcp/ip·零售
sleepcattt1 小时前
Spring中Bean的实例化(xml)
xml·java·spring
lzzy_lx_20892 小时前
Spring Boot登录认证实现学习心得:从皮肤信息系统项目中学到的经验
java·spring boot·后端
Dcs2 小时前
立即卸载这些插件,别让它们偷你的资产!
java
小七mod2 小时前
【Spring】Java SPI机制及Spring Boot使用实例
java·spring boot·spring·spi·双亲委派
亿.62 小时前
【Java安全】RMI基础
java·安全·ctf·rmi
ruan1145143 小时前
Java Lambda 类型推断详解:filter() 方法与 Predicate<? super T>
java·开发语言·spring·stream