注册 🛠 开源即时通讯(IM)项目OpenIM源码部署指南 OpenIM

本文涉及的产品
对象存储 OSS,OSS 加速器 50 GB 1个月
简介: 注册🛠 开源即时通讯(IM)项目OpenIM源码部署指南OpenIM

OpenIM的部署涉及多个组件,并支持多种方式,包括源码、Docker和Kubernetes等。这要求在确保不同部署方式之间的兼容性同时,还需有效管理各版本之间的差异。确实,这些都是复杂的问题,涉及到深入的技术细节和精准的系统配置。我们的目标是简化部署流程,同时保持系统的灵活性和稳定性,以适应不同用户的需求。目前3.5版本已经简化了部署流程,而且这个版本会长期维护,欢迎大家使用。

  1. 环境及组件要求
    环境要求
    注意事项

详细说明

操作系统

Linux 系统

硬件资源

至少 4G 可用内存

Golang

v1.19 或更高

Docker

v24.0.5 或更高

Git

v2.17.1 或更高

存储组件要求
存储组件

建议版本

MongoDB

v6.0.2 或更高

Redis

v7.0.0 或更高

Zookeeper

v3.8

Kafka

v3.5.1

MySQL

v5.7 或更高

MinIO

最新版本

  1. 部署 OpenIM Server (IM)
    2.1 设置 OPENIM_IP

    如果服务器有外网IP

    export OPENIM_IP="外网IP"

    如果仅提供内网服务

    export OPENIM_IP="内网IP"
    复制
    2.2 ️ 部署组件 (mongodb/redis/zookeeper/kafka/MinIO等)
    git clone https://github.com/OpenIMSDK/open-im-server && cd open-im-server

    建议切换到release-v3.5及以后的release分支

    make init && docker compose up -d
    复制
    2.3 ️ 编译
    make build
    复制
    2.4 启动/停止/检测

    启动

    make start

    停止

    make stop

    检测

    make check
    复制
  2. 部署 App Server (Chat)
    3.1 ️ 部署组件(mysql)

    返回上一级目录

    cd ..

    克隆仓库 建议切换到release-v1.5及以后的release分支

    git clone https://github.com/OpenIMSDK/chat chat && cd chat

    部署mysql

    docker run -d --name mysql2 -p 13306:3306 -p 33306:33060 -v "$(pwd)/components/mysql/data:/var/lib/mysql" -v "/etc/localtime:/etc/localtime" -e MYSQL_ROOT_PASSWORD="openIM123" --restart always mysql:5.7
    复制
    3.2 ️ 编译
    make init
    make build
    复制
    3.3 启动/停止/检测

    启动

    make start

    停止

    make stop

    检测

    make check
    复制
  3. 快速验证
    开放端口
    IM 端口
    TCP 端口

说明

操作

TCP:10001

ws 协议,消息端口,用于客户端 SDK

端口放行

TCP:10002

api 端口,如用户、好友、群组、消息等接口

端口放行

TCP:10005

选择 MinIO 存储时需要(OpenIM 默认使用 MinIO 存储)

端口放行

Chat 端口
TCP 端口

说明

操作

TCP:10008

业务系统,如注册、登录等

端口放行

TCP:10009

管理后台,如统计、封号等

端口放行

PC Web 及管理后台前端资源端口
TCP 端口

说明

操作

TCP:11001

PC Web 前端资源

端口放行

TCP:11002

管理后台前端资源

端口放行

Grafana 端口
TCP 端口

说明

操作

TCP:13000

grafana端口

端口放行

三、验证
PC Web 验证
提示: 在浏览器中输入 http://ip:11001 来访问 PC Web。此 IP 应为服务端 OPENIM_IP,确保浏览器能访问。首次使用请通过手机号注册,验证码默认为 666666。
image.png

图:PC Web 接口示例

App 验证
扫描以下二维码或点击 这里 进行下载。

图:App 下载二维码

提示: 双击 OpenIM 后修改 IP 为服务端 OPENIM_IP 再重启 App。请确保开放相关端口,并在修改后重启 App。首次使用请先通过手机号注册,验证码默认为 666666。
image.png

图:服务器地址修改 - 步骤 1

image.png

图:服务器地址修改 - 步骤 2

管理后台验证
在浏览器中输入 http://ip:11002 来访问管理后台。此 IP 应为服务端 OPENIM_IP,确保您的浏览器能访问。默认账号和密码均为 chatAdmin。

image.png

图:管理后台界面

  1. 配置项修改
    5.1 ️ 共用配置项的修改
    配置项

需要修改的文件

操作

mongo/kafka/minio 相关

.env, openim-server/config/config.yaml

需重启组件和 IM

redis/zookeeper 相关

.env, openim-server/config/config.yaml, chat/config/config.yaml

需重启组件、IM 和 Chat

SECRET

openim-server/config/config.yaml, chat/config/config.yaml

需重启 IM 和 Chat

5.2 特殊配置项的修改
特殊配置项: API_OPENIM_PORT/MINIO_PORT/OPENIM_IP/GRAFANA_PORT

修改 .env 文件中的特殊配置项
在 openim-server/config/config.yaml 中按照规则修改配置
在 chat/config/config.yaml 中按照规则修改配置
重启 IM 和 Chat
5.3 ️ 其他配置项的修改
对于 .env、chat/config/config.yaml 和 openim-server/config/config.yaml 中的其他配置项,可以单独修改相应文件中的这些配置项。

5.4 端口的修改
特别注意,对于IM相关任何端口的修改,都需要同步修改 open-im-server/scripts/install/environment.sh 中的端口。

  1. 常见问题
    6.1 日志查看
    运行时日志:logs/OpenIM.log.all.
    启动日志:output/logs/openim
    .log
    6.2 启动顺序
    启动顺序如下:

IM 依赖的组件:mongo/redis/kafka/zookeeper/minio等
IM
Chat 依赖的组件:mysql
Chat
6.3 Docker 版本
新版 Docker 已经整合了 docker-compose.
老版本的 Docker 可能不支持 gateway 功能。建议升级到较新的版本,如 23.0.1。

  1. 关于OpenIM
    得益于广泛的开发者支持,OpenIM在开源即时通讯(IM)领域保持着领先地位,在Github上的星标数量已经超过12,000。在当前对数据和隐私安全日益重视的背景下,IM私有部署的需求不断增长,这与中国软件产业的快速发展趋势相契合。特别是在政府和企业领域,随着信息技术的飞速发展和创新产业的广泛应用,对IM解决方案的需求急剧上升。进一步来看,协同办公软件市场的持续扩张使得“安全可控”成为了一个关键属性。

仓库地址:https://github.com/openimsdk

image.png

目录
相关文章
|
9月前
|
测试技术 Go
客服系统程序入口文件解析-唯一客服系统源码开发
该代码为 Go 语言编写的客服系统命令行程序入口,结构清晰,使用 cmd 包启动业务逻辑,可能基于 cobra 框架实现,具备良好可扩展性与可维护性,适用于服务启动与管理。
308 69
|
8月前
|
数据安全/隐私保护 容器 Go
开源IM即时通讯系统调研
Lumen IM 是一款企业级开源即时通讯工具,前端采用 Vue3 + Naive UI,后端基于 Go 语言,使用 WebSocket 协议。支持 Docker + Nginx 快速部署,适合私有化环境。功能包括文本、图片、文件消息,内置笔记、群聊及消息历史记录。界面美观、功能完善,适用于企业沟通、团队协作及开发者学习。提供前后端源码,便于快速搭建 IM 系统。
开源IM即时通讯系统调研
|
移动开发 网络协议 小程序
基于开源IM即时通讯框架MobileIMSDK:RainbowChat-iOS端v10.0版已发布
RainbowChat是一套基于开源IM即时通讯聊天框架 MobileIMSDK 的产品级移动端IM系统。RainbowChat源于真实运营的产品,解决了大量的屏幕适配、细节优化、机器兼容问题。RainbowChat可能是市面上提供im即时通讯聊天源码的,唯一一款同时支持TCP、UDP两种通信协议的IM产品。与姊妹产品RainbowTalk和RainbowChat-Web 技术同源,历经考验。
623 0
基于开源IM即时通讯框架MobileIMSDK:RainbowChat-iOS端v10.0版已发布
|
8月前
|
移动开发 网络协议 小程序
鸿蒙NEXT即时通讯/IM系统RinbowTalk v2.4版发布,基于MobileIMSDK框架、ArkTS编写
RainbowTalk是一套基于开源即时通讯讯IM框架 MobileIMSDK 的产品级鸿蒙NEXT端IM系统。纯ArkTS编写、全新开发,没有套壳、也没走捷径,每一行代码都够“纯血”。与姊妹产品RainbowChat和RainbowChat-Web 技术同源,历经考验。
335 1
|
9月前
|
缓存 移动开发 网络协议
纯血鸿蒙NEXT即时通讯/IM系统:RinbowTalk正式发布,全源码、纯ArkTS编写
RainbowTalk是一套基于MobileIMSDK的产品级鸿蒙NEXT端IM系统,目前已正式发布。纯ArkTS、从零编写,无套壳、没走捷径,每一行代码都够“纯”(详见:《RainbowTalk详细介绍》)。 MobileIMSDK是一整套开源IM即时通讯框架,历经10年,超轻量级、高度提炼,一套API优雅支持 UDP 、TCP 、WebSocket 三种协议,支持 iOS、Android、H5、标准Java、小程序、Uniapp、鸿蒙NEXT,服务端基于Netty编写。
673 1
|
7月前
|
网络协议 NoSQL API
转转客服IM系统的WebSocket集群架构设计和部署方案
客服IM系统是转转自研的在线客服系统,是用户和转转客服沟通的重要工具,主要包括机器人客服、人工客服、会话分配、技能组管理等功能。在这套系统中,我们使用了很多开源框架和中间件,今天讲一下客服IM系统中WebSocket集群的的实践和应用。
578 141
|
9月前
|
前端开发 JavaScript Java
智能客服系统的技术栈解析-唯一客服系统技术架构优势
“唯一客服系统”采用 Vue.js 2.x + ElementUI 构建前端,实现响应式界面,支持多端适配;后端基于 Golang + Gin + GORM,具备高性能与高并发处理能力。系统支持私有化部署,提供灵活定制、AI 扩展能力,技术栈简洁易维护,兼顾开发者友好与企业级应用需求。
373 1
|
9月前
|
机器学习/深度学习 人工智能 自然语言处理
从0搭建AI智能客服教程(AI智能客服系统选型和实战指南)
针对智能客服技术与业务脱节的痛点,合力亿捷通过 NLP、知识图谱及人机协同策略,助企业实现首次解决率超 70%、人力成本降 43%、年省成本超千万。其方案提升制造业问题解决率 40%,投诉转接成功率达 99%,以分场景选型助力超万家企业平衡业务与成本,成行业首选。
|
9月前
|
人工智能 自然语言处理 语音技术
深度解析:AI语音客服系统如何重塑客户服务体验与主流解决方案探析
在数字化浪潮下,AI语音客服凭借高效、便捷、24小时在线的优势,成为企业提升服务效率、优化体验的重要工具。本文详解其核心技术、应用价值、选型要点及市场主流方案,如阿里云通义晓蜜、合力亿捷等,助力企业智能化升级。
597 1