# 即时通讯系统-唛盟im后端 **Repository Path**: maimengcloud/mdp-im-backend ## Basic Information - **Project Name**: 即时通讯系统-唛盟im后端 - **Description**: 唛盟im:涵盖消息发布、消息订阅、消息存储、群聊、私聊、公告推送、群组管理、群员管理、禁言、朋友圈等一站式即时通讯解决方案 - **Primary Language**: Java - **License**: MIT - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 168 - **Forks**: 5 - **Created**: 2024-08-14 - **Last Updated**: 2025-07-26 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README
唛盟im:涵盖消息发布、消息订阅、消息存储、群聊、私聊、公告推送、群组管理、群员管理、禁言、朋友圈等一站式即时通讯解决方案
## 快速导航 - [前端组件](https://gitee.com/maimengcloud/mdp-im-ui-web) - [后端服务](https://gitee.com/maimengcloud/mdp-im-backend) - [体验环境](https://maimengcloud.com/im/m1/) 登陆界面上选择演示账号登陆或者直接扫码登陆,无须注册 ## 📢 简介[唛盟im](/) 唛盟im:涵盖消息发布、消息订阅、消息存储、群聊、私聊、公告推送、群组管理、群员管理、禁言、朋友圈等一站式即时通讯解决方案 ## 📢 唛盟生态 💪唛盟生态遵循 “一个底座+N个专业子系统” 的架构,基于同一个底座的各个专业子系统可以任意组合形成一个大的业务系统。👉[聊聊唛盟生态1+n架构](https://www.bilibili.com/video/BV1BD421V7Bu/?spm_id_from=333.337.search-card.all.click&vd_source=93be23d03863773d50b81112985b9237) ### 底座 mdp-core [mdp-core](https://gitee.com/maimengcloud/mdp-core) ### N个专业子系统 以下专业子系统都是基于唛盟底座 + 唛盟低代码 搭建起来的,本工程为其中的研发项目管理子系统后端服务工程 | 唛盟子系统 | 说明 | 版本 | |------------------------------------------------------------------------------------|------------------|--------| | [低代码、0代码](https://gitee.com/maimengcloud/mdp-lcode-ui-web) | 低代码、0代码框架 | 3.0.0 | | [账户、权限、组织管理](https://gitee.com/maimengcloud/mdp-lcode-backend/tree/master/mdp-sys) | 账户、权限、组织管理,支持多租户 | 3.0.0 | | [数据模型](https://gitee.com/maimengcloud/mdp-dm-backend/tree/master/mdp-dm-backend) |表结构设计、表数据增删改查等ddl、dml操作,在线执行sql等 | 3.0.0 | | [第三方支付登录等](https://gitee.com/maimengcloud/mdp-tpa-backend) | 微信支付、支付宝支付、paypal支付、第三方登录 | 3.0.0 | | [统一认证中心](https://gitee.com/maimengcloud/mdp-oauth2-backend) | 短信、微信、账号登录 | 3.0.0 | | [统一流程中心](https://gitee.com/maimengcloud/mdp-workflow-backend) | 审批、代办、设计流程、监控流程等 | 3.0.0 | | [短信](https://gitee.com/maimengcloud/mdp-sms-ui-web) | 群发消息 | 3.0.0 | | [代码生成器](https://gitee.com/maimengcloud/mdp-code-generator) | 自动生成前后端代码 | 3.0.0 | | [研发项目管理](https://gitee.com/maimengcloud/xm-ui-web) | 产品管理、需求管理、任务计划、迭代、测试、效能等 | 3.0.0 | | [即时通讯](https://gitee.com/maimengcloud/mdp-im-ui-web) | 即时通讯、消息、聊天 | 3.0.0 | | [财务](https://gitee.com/maimengcloud/ac-core-ui-web) | 财务子系统,凭证、报销、会计记账、成本、结算 等 | 3.0.0 | | [协同办公](https://gitee.com/maimengcloud/oa-ui-web) | 办公用品、会议、车辆、资产、档案、用印、采购、绩效等功能 | 3.0.0 | ## 💪 内置功能、界面展示 本工程为后端服务,功能列表以前端介绍为准,请点以下链接可查阅 [内置功能](https://gitee.com/maimengcloud/mdp-im-ui-web) ## ⚙ 技术栈 | 框架 | 说明 | 版本 | |---------------------|----------------|----------| | spring boot | spring boot 框架 | 2.6.11 | | mybatis plus | 数据库操作框架 | 3.5.3.1 | | spring security | 安全框架 | 2.1.7 | | jsqlparse | sql解析引擎 | 4.7+ | | swagger | 接口说明框架 | 2.2.8 | | logback | 日志框架 | 1.2.3 | | jexl13 | 表达式引擎 | 3.1 | | flowable | 流程引擎-可换 | 6.4.2 | | spring cloud | cloud框架-可换 | 2020.0.0 | | spring cloud consul | cloud框架-可换 | 1.10+ | | spring cloud consul | cloud框架-可换 | 1.10+ | | spring oauth2 | 统一认证中心-可换 | 5.2.2 | | netty | socket通讯框架 | 4.1.24.Final | ## ⚙ 开发工具 | 插件名 | 功能 | |-------|-------------------------| | idea | java 开发工具 社区版、企业版都可 | | mysql | 数据库 mysql8以上,其它数据库请联系客服 | ## ⚙ 工程结构说明 | 子工程 | 功能 | |-------------------------|-------------------------------| | mdp-im-core-service-api | 即时通讯核心api抽象及一些公共工具 | | mdp-im-core-service | 核心服务 | | mdp-im-socket | socket服务启动、初始化等 | | | mdp-im-publish | 通讯模型之消息发布端 | | mdp-im-subscriber | 通讯模型之消息订阅端 | | mdp-im-rest-api | 控制层http接口 | | mdp-im-plugin | 通讯模型之消息处理插件,需要添加消息处理,在此工程添加插件 | | mdp-im-plugin-api | 通讯模型之消息处理插件抽象 | | mdp-im-bootstrap | 启动器-单体 | | mdp-im-bootstrap-cloud | 启动器-cloud | ## ⚙ 快速开始 ### 环境要求 数据库版本mysql8,jdk版本java-8-openjdk-amd64,部署时需要用到redis版本3.0.6以上 ### 开发 ```bash # 克隆开发底座项目 git clone https://gitee.com/maimengcloud/mdp-core.git # 安装开发底座依赖 mvn install # 克隆oauth2项目(非必须,接入认证中心才需要) git https://gitee.com/maimengcloud/mdp-oauth2-backend # 安装oauth2依赖 mvn install # 克隆cloud项目(非必须,部署cloud版本才需要) git https://gitee.com/maimengcloud/mdp-cloud-backend # 安装cloud依赖 mvn install # 克隆im项目 git clone https://gitee.com/maimengcloud/mdp-im-backend.git # 安装im依赖 mvn install # 导入数据库脚本 # 1.创建im库 [im.sql](./sql/im.sql) # 配置数据库链接链接(需要提前准备数据库) [application-prod.yml](./mdp-im-bootstrap/src/main/resources/application-prod.yml) # 启动服务 ⚠注意启动类放在test下面, 找到并运行[ImApplication.java](./mdp-im-bootstrap/src/main/java/com/mdp/ImApplication.java) ``` http访问端口 http://localhost:7019 socket访问端口 127.0.0.1:3333 #### 修改socket端口 ```properties mdp.im.port=3333 ``` ### 发布 #### 服务器的目录结构 假设工作空间为/home/m1/ ``` /hom/m1/ ├── start-service => 唛盟一键启停脚本存放目录 ├── config => spring boot的外置配置文件存放目录 ├── lib => jar包存放目录 ├── conf => 其它配置文件存放目录 ├── consul => consul安装目录 ├── logs => 唛盟日志存放目录 ├── backup-log => 日志备份存放目录 ├── arcfile => 唛盟内容素材上传下载访问的目录(素材存放目录) ├── bin => 一些公共脚本目录,如日志定时清理脚本、微服务注销脚本 ``` #### 构建 ```bash # 构建 在mdp-im-backend下执行 mvn instal ``` #### 发布及启停服务 ```bash # 部署 指部署jar包到nexus私服,如果企业没有nexus私服,则忽略此步骤 在mdp-im-backend下执行 mvn deploy # 手工发布到测试环境或者生产环境 如果是单体应用则拷贝并推送到服务器上[mdp-im-bootstrap-3.0.0-RELEASE.jar](./mdp-im-bootstrap/target/im-bootstrap-3.0.0-RELEASE.jar) 如果是微服务则拷贝并推送到服务器上[mdp-im-cloud-bootstrap-3.0.0-RELEASE.jar](./mdp-im-cloud-bootstrap/target/im-cloud-bootstrap-3.0.0-RELEASE.jar) # 启动应用(单体、cloud对jar包的引用不同,需要根据情况修改下脚本bootstrap-im-00.sh,默认是单体)初次部署把./start-service/bootstrap-im-00.sh拷贝到服务器上 sh bootstrap-mdp-im-00.sh ``` ### 接入统一认证中心 1.如果部署了统一认证中心,需要做配置更改。 统一认证中心相关的配置项: ```properties mdp.jwt.connect-oauth2-server=true|false 如果不需要对接统一认证中心,connect-oauth2-server设为false,则对jwt token的解析将采用HS256算法解密,默认为true mdp.oauth2.server.uri=统一认证中心的访问地址 如http://127.0.0.1:7000,如果是cloud环境下可以设置为http://oauth2server ``` ```yaml mdp: jwt: connect-oauth2-server: true oauth2: server: uri: http://127.0.0.1:7000 ``` 2.本地起的后端服务pom.xml文件需要引入[mdp-client-oauth2](https://gitee.com/maimengcloud/mdp-core/tree/master/mdp-clients/mdp-client-oauth2) 或者[mdp-client-oauth2-cloud](https://gitee.com/maimengcloud/mdp-core/tree/master/mdp-clients/mdp-client-oauth2-cloud) 单体应用下: ```xml