稳扎稳打 部署丝滑 开源即时通讯(IM)项目OpenIM源码部署流程(linux windows mac)

news/2024/9/25 5:29:21/

背景
OpenIM包含多个关键组件,每个都是系统功能必不可少的一部分。具体来说,MongoDB 用于持久化存储;Redis 用作缓存;Kafka 用于消息队列;Zookeeper 用于服务发现;Minio 用于对象存储。这些组件的众多可能会增加部署的复杂性。此外,系统包含多个微服务模块,这要求有效管理进程的启动、停止和监控。为了简化这一过程,我们放弃了传统脚本,转而采用了 mage 这一跨平台方案,兼容所有主流平台和 CPU 架构。本文将详细介绍整个源码部署过程。

OpenIM整体架构
OpenIM主要分为OpenIM SDK和OpenIM Server两大核心部分。这两部分向开发者提供了全套工具和服务,使得即时通讯功能的集成变得简单便捷。功能涵盖了消息的发送与接收、用户管理、群组管理等关键方面。下面提供的OpenIM整体架构图清楚地展示了各组件在系统中的角色和位置,帮助开发者更好地理解和使用这一平台。

在这里插入图片描述

1环境要求
注意事项 详细说明
操作系统 全平台支持(Linux, Windows, Mac)
CPU 支持ARM和AMD架构
硬件资源 至少8GB可用内存
Golang v1.20 或更高
Docker 集成了Compose插件或者使用Docker-compose
Git v2.17.1 或更高

  1. 部署 OpenIM Server (IM)
    2.1 克隆仓库
    使用 main 分支或切换到 release-v3.7 及以后的发布分支:

git clone https://github.com/openimsdk/open-im-server && cd open-im-server
注意:

1.一般建议使用release分支,功能稳定;

2.如果是通过windows下载,再上传到linux,可能会有脚本权限或\r问题,建议 执行命令 find ./ -name “*.sh” | xargs chmod +x,以赋予脚本执行权限;

2.2 部署组件 (MongoDB/Redis/Zookeeper/Kafka/MinIO)
通过Docker Compose启动服务:

docker compose up -d
这一步主要是自动部署所依赖的组件,以及web/admin前端镜像,同时会把端口映射出来,以供openIM访问和外部使用,

如果要修改组件密码,则需要在此命令执行之前修改docker-compose.yml文件。

2.3 设置外网IP
修改配置文件,设置外部访问地址:

在 config/minio.yml 中修改 externalAddress 为 http://外网IP:port

这个是minio的访问地址,如不修改,则无法发送图片视频文件。

在 config/openim-api.yml 中将 grafanaURL: http://127.0.0.1:13000/ 修改为 http://外网IP:port

这个是grafana的访问地址,如不修改,则无法查看统计数据。

这里所谓的外网IP,仅表示用户能通过此IP访问,无所谓是否真正意义的外网IP

2.4 🛠️ 初始化
在第一次编译前执行初始化脚本:

Linux/Mac 平台:

bash bootstrap.sh
Windows 平台:

bootstrap.bat
这里主要是下载mage,前提是能本机访问github,同时已经安装了go

2.5 🛠️ 编译
适用于Linux/Windows/Mac平台:

mage
这里需要先下载依赖,所以第一次编译可能会比较慢,大概需要3-5分钟,建议设置go代理

在这里插入图片描述

2.6 🚀 启动/停止/检测
适用于Linux/Windows/Mac平台:

启动:

mage start

在这里插入图片描述

后台启动并收集日志:

nohup mage start >> _output/logs/openim.log 2>&1 &
停止:

mage stop

在这里插入图片描述

检测:

mage check

在这里插入图片描述

  1. 部署 App Server (Chat)
    3.1 clone仓库 使用main分支或切换到release-v1.7或以后的release分支
    git clone https://github.com/openimsdk/chat&& cd chat
    3.2 🛠️ 初始化
    第一次编译前,linux/mac平台下执行:

bash bootstrap.sh
windows执行

bootstrap.bat
3.3 🛠️ 编译(linux/windows/mac平台均可用)
mage
3.4 🚀 启动/停止/检测(linux/windows/mac平台均可用)

启动

mage start

后台启动 收集日志

nohup mage start >> _output/logs/chat.log 2>&1 &

停止

mage stop

检测

mage check
关于我们
得益于广泛的开发者支持,OpenIM在开源即时通讯(IM)领域保持领先地位,目前在GitHub上的星标已超过13k。在政府和企业领域,随着信息技术的快速发展和创新产业的广泛应用,对IM的需求正急速增长。此外,随着协同办公软件市场的持续扩展,“安全可控”已成为最关键的要求之一。

在后AIGC时代,IM作为人机交互的首要接口,其价值势必会越来越大。我们期待OpenIM在后AIGC时代能发挥更大的作用,使每一个应用都能集成OpenIM,提升整体效率和安全性。

github: https://github.com/openimsdk

developer: https://docs.openim.io/zh-Hans/

在这里插入图片描述


http://www.ppmy.cn/news/1445392.html

相关文章

ABP项目中关于Swagger显示的一些相关问题

abp默认配置如下。 public override void ConfigureServices(ServiceConfigurationContext context) {var services context.Services;services.AddAbpSwaggerGen(options >{options.SwaggerDoc("v1", new OpenApiInfo { Title "Test API", Version …

JavaScript 中的 this 到底指向谁? 今天彻底把它征服!!!

概述 我们知道,JS 中的 this 指向问题,一直是一个经久不衰的重点和考点。那么它到底难不难呢?怎么说呢?它也难也不难,你要是不把它理清楚,随意变化一下就能把你绊倒;但是你要是把他理清楚了以后…

社区新零售:重构邻里生活圈,赋能美好未来

新时代的邻里脉动 在城市的肌理中,社区作为生活的基本单元,正经历一场由新零售引领的深刻变革。社区新零售,以其独特的商业模式、创新的技术手段和以人为本的服务理念,重新定义了社区商业的边界,重构了邻里生活的形态…

vue+elementplus(五)

一级分类-整体认识和路由配置 点击上方导航栏实现跳转 router->index.js {path:category/:id,component:Category}, 来到LayoutHeader.vue 找到跳转代码 发现自己没加首页 正好一起改了 动态路由&#xff0c;跳转到分类页面下的商品数据id为路由名字 <RouterLink :…

k8s 日常维护命令简介

基础信息 1、查看客户端和服务器版本 如果 kubectl 客户端版本低于 k8s 服务端版本太多&#xff0c;使用 kubectl 管理 k8s 时可能会出现未知异常。如果升级了 k8s 版本记得也要更新下使用的 kubectl 版本。 [roothaiouc ~]# kubectl version -ojson | jq -r {client:.clien…

js逆向验证码篇之某程(滑动拼图验证码)

提示!本文章仅供学习交流,严禁用于任何商业和非法用途,未经许可禁止转载,禁止任何修改后二次传播,擅自使用本文讲解的技术而导致的任何意外,作者均不负责,如有侵权,可联系本文作者删除! 前言:一开始想的是带大家直接抠混淆后的代码,但是后来想想先解混淆,然后带大家…

数之寻软件怎么样?

数之寻软件是一款功能强大的数据恢复和备份软件&#xff0c;以下是对其特点和功能的详细评价&#xff1a; 一、数据恢复方面&#xff1a; 高效的数据恢复能力&#xff1a;数之寻软件采用了先进的算法和数据恢复技术&#xff0c;能够快速有效地恢复丢失或损坏的数据。无论是文…

wow-slist文件说明

wow-slist文件说明 项目地址&#xff1a;https://gitee.com/wow-iot/wow-iot7本文件的的功能主要用于链表相关操作&#xff0c;主要涉及创建、销毁、插入、查找、移除、替换、获取、清空、遍历&#xff1b; 创建与销毁: Slist_T* wow_slist_create(void) {Slist_T *slist C…