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

1. 环境及组件要求

环境要求

注意事项详细说明

操作系统Linux 系统

硬件资源至少 4G 可用内存

Golangv1.19 或更高

Dockerv24.0.5 或更高

Gitv2.17.1 或更高

存储组件要求

存储组件建议版本

MongoDBv6.0.2 或更高

Redisv7.0.0 或更高

Zookeeperv3.8

Kafkav3.5.1

MySQLv5.7 或更高

MinIO最新版本

2. 部署 OpenIM Server (IM)

2.1 设置 OPENIM_IP

# 如果服务器有外网IPexportOPENIM_IP="外网IP"# 如果仅提供内网服务exportOPENIM_IP="内网IP"

2.2 ️ 部署组件 (mongodb/redis/zookeeper/kafka/MinIO等)

git clone https://github.com/OpenIMSDK/open-im-server&&cdopen-im-server# 建议切换到release-v3.5及以后的release分支 make init&&docker compose up -d

2.3 ️ 编译

make build

2.4 启动/停止/检测

# 启动make start# 停止make stop# 检测make check

3. 部署 App Server (Chat)

3.1 ️ 部署组件(mysql)

# 返回上一级目录cd..# 克隆仓库 建议切换到release-v1.5及以后的release分支git clone https://github.com/OpenIMSDK/chat chat&&cdchat# 部署mysqldocker run -d --name mysql2 -p 13306:3306 -p 33306:33060 -v"$(pwd)/components/mysql/data:/var/lib/mysql"-v"/etc/localtime:/etc/localtime"-eMYSQL_ROOT_PASSWORD="openIM123"--restart always mysql:5.7

3.2 ️ 编译

make init

make build

3.3 启动/停止/检测

# 启动make start# 停止make stop# 检测make check

4. 快速验证

开放端口

IM 端口

TCP 端口说明操作

TCP:10001ws 协议,消息端口,用于客户端 SDK端口放行

TCP:10002api 端口,如用户、好友、群组、消息等接口端口放行

TCP:10005选择 MinIO 存储时需要(OpenIM 默认使用 MinIO 存储)端口放行

Chat 端口

TCP 端口说明操作

TCP:10008业务系统,如注册、登录等端口放行

TCP:10009管理后台,如统计、封号等端口放行

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

TCP 端口说明操作

TCP:11001PC Web 前端资源端口放行

TCP:11002管理后台前端资源端口放行

Grafana 端口

TCP 端口说明操作

TCP:13000grafana端口端口放行

三、验证

PC Web 验证

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

图:PC Web 接口示例

App 验证

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

图:App 下载二维码

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

 

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

 

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

 

管理后台验证

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

 

图:管理后台界面

5. 配置项修改

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

SECRETopenim-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 中的端口。

6. 常见问题

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。

7. 关于OpenIM

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

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

 

🛠 开源即时通讯(IM)项目OpenIM源码部署指南的更多相关文章

  1. 一款Java开源的Springboot即时通讯 IM,附源码

    # 开篇 电商平台最不能缺的就是即时通讯,例如通知类下发,客服聊天等.今天,就来给大家分享一个开源的即时通讯系统.如对文章不感兴趣可直接跳至文章末尾,有获取源码链接的方法. 但文章内容是需要你简单的过 ...

  2. 即时通信系统中实现全局系统通知,并与Web后台集成【附C#开源即时通讯系统(支持广域网)——QQ高仿版IM最新源码】

    像QQ这样的即时通信软件,时不时就会从桌面的右下角弹出一个小窗口,或是显示一个广告.或是一个新闻.或是一个公告等.在这里,我们将其统称为“全局系统通知”.很多使用C#开源即时通讯系统——GGTalk的 ...

  3. GGTalk——C#开源即时通讯系统源码介绍系列(一)

    坦白讲,我们公司其实没啥技术实力,之所以还能不断接到各种项目,全凭我们老板神通广大!要知道他每次的饭局上可都是些什么人物! 但是项目接下一大把,就凭咱哥儿几个的水平,想要独立自主.保质保量保期地一个个 ...

  4. 开源项目Telegram源码 Telegram for Android Source

    背景介绍 Telegram 是一款跨平台的即时通信软件,它的客户端是自由及开放源代码软件.用户可以相互交换加密与自毁消息,发送照片.影片等所有类型文件.官方提供手机版.桌面版和网页版等多种平台客户端. ...

  5. 【原】Android热更新开源项目Tinker源码解析系列之三:so热更新

    本系列将从以下三个方面对Tinker进行源码解析: Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Android热更新开源项目Tinker源码解析系列之二:资源文件热更新 A ...

  6. 【原】Android热更新开源项目Tinker源码解析系列之一:Dex热更新

    [原]Android热更新开源项目Tinker源码解析系列之一:Dex热更新 Tinker是微信的第一个开源项目,主要用于安卓应用bug的热修复和功能的迭代. Tinker github地址:http ...

  7. 【原】Android热更新开源项目Tinker源码解析系列之二:资源文件热更新

    上一篇文章介绍了Dex文件的热更新流程,本文将会分析Tinker中对资源文件的热更新流程. 同Dex,资源文件的热更新同样包括三个部分:资源补丁生成,资源补丁合成及资源补丁加载. 本系列将从以下三个方 ...

  8. Oschat IM 开源即时通讯项目介绍 - FengJ的个人页面 - 开源中国社区

    Oschat IM 开源即时通讯项目介绍 - FengJ的个人页面 - 开源中国社区 Oschat IM 开源即时通讯项目介绍    255人收藏此文章, 我要收藏 发表于5天前(2013-08-28 ...

  9. Python优秀开源项目Rich源码解析

    这篇文章对优秀的开源项目Rich的源码进行解析,OMG,盘他.为什么建议阅读源码,有两个原因,第一,单纯学语言很难在实践中灵活应用,通过阅读源码可以看到每个知识点的运用场景,印象会更深,以后写代码的时 ...

  10. 急急如律令!火速搭建一个C#即时通信系统!(附源码分享——高度可移植!)

    (2016年3月更:由于后来了解到GGTalk开源即时通讯系统,因此直接采用了该资源用于项目开发,在此对作者表示由衷的感谢!) —————————————————————————————————— 人 ...

随机推荐

  1. 基于C++11特性的线程池

    写在前面:本文学习自基于C++11实现线程池,代码部分均属于该博主,自己只是想记录以下自己的认知,并以这种方式加深一下自己对于多线程的理解 1 前置知识 RAII管理机制 简单来说RAII机制是一种对 ...

  2. 让 ChatGPT 如虎添翼 2.0

    月初写了4个工具,让 ChatGPT 如虎添翼!,时隔二十多天,我又发现了基于ChatGPT的应用,只推最好用的,强烈建议大家都感受一下. 极简搭建 ChatGPT 演示网页 项目地址:https:/ ...

  3. 【django-vue】celery延迟任务、定时任务 django中使用celery 秒杀功能 双写一致性 首页轮播图定时更新 课程前端页面

    目录 上节回顾 字符编码 django-redis 今日内容 1 celery 执行异步任务,延迟任务,定时任务 延时任务 定时任务 2 django中使用celery 2.1 秒杀功能 2.1.1 ...

  4. 透析阿里云视频云「低代码音视频工厂」之能量引擎——vPaaS 视频原生应用开发平台

    为满足企业用户极速搭建高品质专属音视频业务的需求,阿里云视频云的"低代码音视频工厂"应运而生,但极速而高品质的平台搭建诉求,需要用全新的开发方式才能真正实现,而全新的开发方式背后蕴 ...

  5. 获取标准报表CJI3的ALV数据

    1.CJI3 运行标准程序CJI3,获取对象和业务货币值,在其他程序中展示 2.代码展示 CJI3对应程序名rkpep003,最终展示的ALV结构可以再程序中找到. 因为本实例只获取其中两个字段的值, ...

  6. Blazor实现菜单动画

    想到动画,你可能会去安装Blazor的动画组件BlazorAnimate,然后使用它.本人初学,暂时我也不知道原理,先不用组件,自己实现吧.虽然项目中我用了AntDesignBlazor,但是我忘了使 ...

  7. JS 实现 HashMap

    HashMap代码(这种实现方式是错误的,错误原因:代码中_map._length变量是HashMap的所有实例共用的): /** * HashMap * 2021年09月09日 */ (functi ...

  8. Codeforces Round #619 (Div. 2) A-D

    比赛链接:Here 1301A. Three Strings 题意: 给三个相同长的字符串 \(a,b,c\)​ ,对于每个位置 \(i\)​ ,你必须做一次操作:交换 \(a_i\)​ 和 \(c_ ...

  9. vivo智能活动中台-悟空系统建设之路

    作者:来自 vivo 互联网悟空系统研发团队 本文根据冯伟.姜野老师在"2023 vivo开发者大会"现场演讲内容整理而成.[vivo互联网技术]公众号回复[2023 VDC]获取 ...

  10. 一文读懂 Serverless 的起源、发展和落地实践

    讲师 | 洛浩(阿里云云原生高级架构师) ​ Serverless 的发展轨迹 **2012 年,Serverless 这个单词第一次出现,由 Iron 公司提出,字面意思就是不需要服务器.但是真正被 ...