mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 13:12:12 +08:00 
			
		
		
		
	* feat: replace mongo database openIM_v3 to openim_v3 * openim-building-an-efficient-version-control-and-testing-workflow * feat: complete openim source deployment rpc start timeout * feat: optimize config Signed-off-by: Xinwei Xiong (cubxxw) <3293172751nss@gmail.com> * feat: add scripts format * feat: use scripts format code * fix cos and minio etc to typecheck * feat: scripts make verify check ci * fix: make file verify spelling * fix: make file verify spelling * Concurrent Type Checking and Cross-Platform Development in Go * feat: add copyright make lint and format * feat: add config examples file Signed-off-by: Xinwei Xiong <3293172751@qq.com> * feat: add config examples file Signed-off-by: Xinwei Xiong <3293172751@qq.com> --------- Signed-off-by: Xinwei Xiong (cubxxw) <3293172751nss@gmail.com> Signed-off-by: Xinwei Xiong <3293172751@qq.com>
		
			
				
	
	
		
			176 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
			
		
		
	
	
			176 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| # OpenIM Application Containerization Deployment Guide
 | |
| 
 | |
| OpenIM supports a variety of cluster deployment methods, including but not limited to `helm`, `sealos`, `kustomize`
 | |
| 
 | |
| Various contributors, as well as previous official releases, have provided some referenceable solutions:
 | |
| 
 | |
| + [k8s-jenkins Repository](https://github.com/OpenIMSDK/k8s-jenkins)
 | |
| + [open-im-server-k8s-deploy Repository](https://github.com/openimsdk/open-im-server-k8s-deploy)
 | |
| + [openim-charts Repository](https://github.com/OpenIMSDK/openim-charts)
 | |
| + [deploy-openim Repository](https://github.com/showurl/deploy-openim)
 | |
| 
 | |
| ### Dependency Check
 | |
| 
 | |
| ```bash
 | |
| Kubernetes: >= 1.16.0-0
 | |
| Helm: >= 3.0
 | |
| ```
 | |
| 
 | |
| ### Minimum Configuration
 | |
| 
 | |
| The recommended minimum configuration for a production environment is as follows:
 | |
| 
 | |
| ```yaml
 | |
| CPU: 4
 | |
| Memory: 8G
 | |
| Disk: 100G
 | |
| ```
 | |
| 
 | |
| ## Configuration File Generation
 | |
| 
 | |
| We have automated all the files, making the generation of configuration files optional for OpenIM. However, if you desire custom configurations, you can follow the steps below:
 | |
| 
 | |
| ```bash
 | |
| $ make init
 | |
| # Alternatively, use script:
 | |
| # ./scripts/init-config.sh
 | |
| ```
 | |
| 
 | |
| At this point, configuration files will be generated under `deployments/openim/config`, which you can modify as per your requirements.
 | |
| 
 | |
| ## Cluster Setup
 | |
| 
 | |
| If you already have a `kubernetes` cluster, or if you wish to build a `kubernetes` cluster from scratch, you can skip this step.
 | |
| 
 | |
| For a quick start, I used [sealos](https://github.com/labring/sealos) to rapidly set up the cluster, with sealos also being a wrapper for kubeadm at its core:
 | |
| 
 | |
| ```bash
 | |
| $ SEALOS_VERSION=`curl -s https://api.github.com/repos/labring/sealos/releases/latest | grep -oE '"tag_name": "[^"]+"' | head -n1 | cut -d'"' -f4` && \
 | |
|   curl -sfL https://raw.githubusercontent.com/labring/sealos/${SEALOS_VERSION}/scripts/install.sh |
 | |
|   sh -s ${SEALOS_VERSION} labring/sealos
 | |
| ```
 | |
| 
 | |
| **Supported Versions:**
 | |
| 
 | |
| + docker: `labring/kubernetes-docker`:(v1.24.0~v1.27.0)
 | |
| + containerd: `labring/kubernetes`:(v1.24.0~v1.27.0)
 | |
| 
 | |
| #### Cluster Installation:
 | |
| 
 | |
| Cluster details are as follows:
 | |
| 
 | |
| | Hostname | IP Address | System Info                                                  |
 | |
| | -------- | ---------- | ------------------------------------------------------------ |
 | |
| | master01 | 10.0.0.9   | `Linux VM-0-9-ubuntu 5.15.0-76-generic #83-Ubuntu SMP Thu Jun 15 19:16:32 UTC 2023 x86_64 x86_64 x86_64 GNU/Linux` |
 | |
| | node01   | 10.0.0.4   | Similar to master01                                          |
 | |
| | node02   | 10.0.0.10  | Similar to master01                                          |
 | |
| 
 | |
| ```bash
 | |
| $ export CLUSTER_USERNAME=ubuntu
 | |
| $ export CLUSTER_PASSWORD=123456
 | |
| $ sudo sealos run labring/kubernetes:v1.25.0 labring/helm:v3.8.2 labring/calico:v3.24.1 \
 | |
|     --masters 10.0.0.9 \
 | |
|     --nodes 10.0.0.4,10.0.0.10 \
 | |
|     -u "$CLUSTER_USERNAME" \
 | |
|     -p "$CLUSTER_PASSWORD"
 | |
| ```
 | |
| 
 | |
| > **Node** Uninstallation method: using `kubeadm` for uninstallation does not remove `etcd` and `cni` related configurations. Manual clearance or using `sealos` for uninstallation is needed.
 | |
| >
 | |
| > ```bash
 | |
| > $ sealos reset
 | |
| > ```
 | |
| 
 | |
| If you are local, you can also use Kind and Minikube to test, for example, using Kind:
 | |
| 
 | |
| ```bash
 | |
| $ GO111MODULE="on" go get sigs.k8s.io/kind@v0.11.1
 | |
| $ kind create cluster
 | |
| ```
 | |
| 
 | |
| ### Installing helm
 | |
| 
 | |
| Helm simplifies the deployment and management of Kubernetes applications to a large extent by offering version control and release management through packaging.
 | |
| 
 | |
| **Using Script:**
 | |
| 
 | |
| ```bash
 | |
| $ curl https://raw.githubusercontent.com/helm/helm/main/scripts/get-helm-3 | bash
 | |
| ```
 | |
| 
 | |
| **Adding Repository:**
 | |
| 
 | |
| ```bash
 | |
| $ helm repo add brigade https://openimsdk.github.io/openim-charts
 | |
| ```
 | |
| 
 | |
| ### OpenIM Image Strategy
 | |
| 
 | |
| Automated offerings include aliyun, ghcr, docker hub: [Image Documentation](https://github.com/openimsdk/open-im-server/blob/main/docs/contrib/images.md)
 | |
| 
 | |
| **Local Test Build Method:**
 | |
| 
 | |
| ```bash
 | |
| $ make image
 | |
| ```
 | |
| 
 | |
| > This command assists in quickly building the required images locally. For a detailed build strategy, refer to the [Build Documentation](https://github.com/openimsdk/open-im-server/blob/main/build/README.md).
 | |
| 
 | |
| ## Installation
 | |
| 
 | |
| Explore our Helm-Charts repository and read through: [Helm-Charts Repository](https://github.com/openimsdk/helm-charts)
 | |
| 
 | |
| 
 | |
| Using the helm charts repository, you can ignore the following configuration, but if you want to just use the server and scale on top of it, you can go ahead:
 | |
| 
 | |
| **Use the Helm template to generate the deployment yaml file: `openim-charts.yaml`**
 | |
| 
 | |
| **Gen Image:**
 | |
| 
 | |
| ```bash
 | |
| ../scripts/genconfig.sh ../scripts/install/environment.sh ./templates/helm-image.yaml > ./charts/generated-configs/helm-image.yaml
 | |
| ```
 | |
| 
 | |
| **Gen Charts:**
 | |
| 
 | |
| ```bash
 | |
| for chart in ./charts/*/; do
 | |
|     if [[ "$chart" == *"generated-configs"* || "$chart" == *"helmfile.yaml"* ]]; then
 | |
|         continue
 | |
|     fi
 | |
| 
 | |
|     if [ -f "${chart}values.yaml" ]; then
 | |
|         helm template "$chart" -f "./charts/generated-configs/helm-image.yaml" -f "./charts/generated-configs/config.yaml" -f "./charts/generated-configs/notification.yaml" >> openim-charts.yaml
 | |
|     else
 | |
|         helm template "$chart" >> openim-charts.yaml
 | |
|     fi
 | |
| done
 | |
| ```
 | |
| 
 | |
| **Use Helmfile:**
 | |
| 
 | |
| ```bash
 | |
| GO111MODULE=on go get github.com/roboll/helmfile@latest
 | |
| ```
 | |
| 
 | |
| ```bash
 | |
| export MONGO_ADDRESS=im-mongo
 | |
| export MONGO_PORT=27017
 | |
| export REDIS_ADDRESS=im-redis-master
 | |
| export REDIS_PORT=6379
 | |
| export KAFKA_ADDRESS=im-kafka
 | |
| export KAFKA_PORT=9092
 | |
| export OBJECT_APIURL="https://openim.server.com/api"
 | |
| export MINIO_ENDPOINT="http://im-minio:9000"
 | |
| export MINIO_SIGN_ENDPOINT="https://openim.server.com/im-minio-api"
 | |
| 
 | |
| mkdir ./charts/generated-configs
 | |
| ../scripts/genconfig.sh ../scripts/install/environment.sh ./templates/config.yaml > ./charts/generated-configs/config.yaml
 | |
| cp ../config/notification.yaml ./charts/generated-configs/notification.yaml
 | |
| ../scripts/genconfig.sh ../scripts/install/environment.sh ./templates/helm-image.yaml > ./charts/generated-configs/helm-image.yaml
 | |
| ```
 | |
| 
 | |
| ```bash
 | |
| helmfile apply
 | |
| ```
 |