# 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 )