mirror of
https://github.com/openimsdk/open-im-server.git
synced 2025-04-05 19:57:51 +08:00
179 lines
4.5 KiB
Markdown
179 lines
4.5 KiB
Markdown
# OpenIM Offline Deployment Design
|
||
|
||
## 1. Base Images
|
||
|
||
Below are the base images and their versions you'll need:
|
||
|
||
- [ ] bitnami/kafka:3.5.1
|
||
- [ ] redis:7.0.0
|
||
- [ ] mongo:6.0.2
|
||
- [ ] bitnami/zookeeper:3.8
|
||
- [ ] minio/minio:RELEASE.2024-01-11T07-46-16Z
|
||
|
||
> [!IMPORTANT]
|
||
> It is important to note that OpenIM removed mysql components from versions v3.5.0 (release-v3.5) and above, so mysql can be deployed without this requirement or above
|
||
|
||
**If you need to install more IM components or monitoring products:**
|
||
|
||
OpenIM:
|
||
|
||
> [!TIP]
|
||
> If you need to install more IM components or monitoring products [images.md](https://github.com/openimsdk/open-im-server/blob/main/docs/contrib/images.md)
|
||
|
||
- [ ] ghcr.io/openimsdk/openim-web:<version-name>
|
||
- [ ] ghcr.io/openimsdk/openim-admin:<version-name>
|
||
- [ ] ghcr.io/openimsdk/openim-chat:<version-name>
|
||
- [ ] ghcr.io/openimsdk/openim-server:<version-name>
|
||
|
||
|
||
Monitoring:
|
||
|
||
- [ ] prom/prometheus:v2.48.1
|
||
- [ ] prom/alertmanager:v0.23.0
|
||
- [ ] grafana/grafana:10.2.2
|
||
- [ ] bitnami/node-exporter:1.7.0
|
||
|
||
|
||
Use the following commands to pull these base images:
|
||
|
||
```bash
|
||
docker pull bitnami/kafka:3.5.1
|
||
docker pull redis:7.0.0
|
||
docker pull mongo:6.0.2
|
||
docker pull mariadb:10.6
|
||
docker pull bitnami/zookeeper:3.8
|
||
docker pull minio/minio:2024-01-11T07-46-16Z
|
||
```
|
||
|
||
If you need to install more IM components or monitoring products:
|
||
|
||
```bash
|
||
docker pull prom/prometheus:v2.48.1
|
||
docker pull prom/alertmanager:v0.23.0
|
||
docker pull grafana/grafana:10.2.2
|
||
docker pull bitnami/node-exporter:1.7.0
|
||
```
|
||
|
||
## 2. OpenIM Images
|
||
|
||
**For detailed understanding of version management and storage of OpenIM and Chat**: [version.md](https://github.com/openimsdk/open-im-server/blob/main/docs/contrib/version.md)
|
||
|
||
### OpenIM Image
|
||
|
||
- Get image version info: [images.md](https://github.com/openimsdk/open-im-server/blob/main/docs/contrib/images.md)
|
||
- Depending on the required version, execute the following command:
|
||
|
||
```bash
|
||
docker pull ghcr.io/openimsdk/openim-server:<version-name>
|
||
```
|
||
|
||
### Chat Image
|
||
|
||
- Execute the following command to pull the image:
|
||
|
||
```bash
|
||
docker pull ghcr.io/openimsdk/openim-chat:<version-name>
|
||
```
|
||
|
||
### Web Image
|
||
|
||
- Execute the following command to pull the image:
|
||
|
||
```bash
|
||
docker pull ghcr.io/openimsdk/openim-web:<version-name>
|
||
```
|
||
|
||
### Admin Image
|
||
|
||
- Execute the following command to pull the image:
|
||
|
||
```bash
|
||
docker pull ghcr.io/openimsdk/openim-admin:<version-name>
|
||
```
|
||
|
||
|
||
## 3. Image Storage Selection
|
||
|
||
**Repositories**:
|
||
|
||
- Alibaba Cloud: `registry.cn-hangzhou.aliyuncs.com/openimsdk/openim-server`
|
||
- Docker Hub: `openim/openim-server`
|
||
|
||
**Version Selection**:
|
||
|
||
- Stable: e.g. release-v3.2 (or 3.1, 3.3)
|
||
- Latest: latest
|
||
- Latest of main: main
|
||
|
||
## 4. Version Selection
|
||
|
||
You can select from the following versions:
|
||
|
||
- Stable: e.g. release-v3.2
|
||
- Latest: latest
|
||
- Latest from main branch: main
|
||
|
||
## 5. Offline Deployment Steps
|
||
|
||
1. **Pull images**: Execute the above `docker pull` commands to pull all required images locally.
|
||
2. **Save images**:
|
||
|
||
```bash
|
||
docker save -o <tar-file-name>.tar <image-name>
|
||
```
|
||
|
||
If you want to save all the images, use the following command:
|
||
|
||
```bash
|
||
docker save -o <tar-file-name>.tar $(docker images -q)
|
||
```
|
||
|
||
3. **Fetch code**: Clone the repository:
|
||
|
||
```bash
|
||
git clone https://github.com/openimsdk/openim-docker.git
|
||
```
|
||
|
||
Or download the code from [Releases](https://github.com/openimsdk/openim-docker/releases/).
|
||
|
||
> Because of the difference between win and linux newlines, please do not clone the repository with win and then synchronize scp to linux.
|
||
|
||
4. **Transfer files**: Use `scp` to transfer all images and code to the intranet server.
|
||
|
||
```bash
|
||
scp <tar-file-name>.tar user@remote-ip:/path/on/remote/server
|
||
```
|
||
|
||
Or choose other transfer methods such as a hard drive.
|
||
|
||
5. **Import images**: On the intranet server:
|
||
|
||
```bash
|
||
docker load -i <tar-file-name>.tar
|
||
```
|
||
|
||
Import directly with shortcut commands:
|
||
|
||
```bash
|
||
for i in `ls ./`;do docker load -i $i;done
|
||
```
|
||
|
||
6. **Deploy**: Navigate to the `openim-docker` repository directory and follow the [README guide](https://github.com/openimsdk/openim-docker) for deployment.
|
||
|
||
7. **Deploy using docker compose**:
|
||
|
||
```bash
|
||
export OPENIM_IP="your ip" # Set Ip
|
||
make init # Init config
|
||
docker compose up -d # Deployment
|
||
docker compose ps # Verify
|
||
```
|
||
|
||
> **Note**: If you're using a version of Docker prior to 20, make sure you've installed `docker-compose`.
|
||
|
||
## 6. Reference Links
|
||
|
||
- [openimsdk Issue #432](https://github.com/openimsdk/open-im-server/issues/432)
|
||
- [Notion Link](https://nsddd.notion.site/435ee747c0bc44048da9300a2d745ad3?pvs=25)
|
||
- [openimsdk Issue #474](https://github.com/openimsdk/open-im-server/issues/474)
|