mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 21:22:16 +08:00 
			
		
		
		
	build: implement services image build and CI release. (#2920)
* build: implement services image build. * remove unused tools * update test. * update images. * update dockerfile and go mod. * update go mod. * Add comments. * update go pkg. * update loadConfig and discovery logic in kubernetes. * update go pkg and discovery field. * update Load method args.
This commit is contained in:
		
							parent
							
								
									9cca969c63
								
							
						
					
					
						commit
						e16a140ad3
					
				
							
								
								
									
										91
									
								
								.github/workflows/build-and-release-services-images.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								.github/workflows/build-and-release-services-images.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @ -0,0 +1,91 @@ | ||||
| name: Build and release services Images | ||||
| 
 | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - release-* | ||||
|   release: | ||||
|     types: [published] | ||||
|   workflow_dispatch: | ||||
|     inputs: | ||||
|       tag: | ||||
|         description: "Tag version to be used for Docker image" | ||||
|         required: true | ||||
|         default: "v3.8.3" | ||||
| 
 | ||||
| jobs: | ||||
|   build-and-push: | ||||
|     runs-on: ubuntu-latest | ||||
| 
 | ||||
|     steps: | ||||
|       - name: Checkout repository | ||||
|         uses: actions/checkout@v3 | ||||
| 
 | ||||
|       - name: Set up Docker Buildx | ||||
|         uses: docker/setup-buildx-action@v2 | ||||
| 
 | ||||
|       - name: Log in to Docker Hub | ||||
|         uses: docker/login-action@v2 | ||||
|         with: | ||||
|           username: ${{ secrets.DOCKER_USERNAME }} | ||||
|           password: ${{ secrets.DOCKER_PASSWORD }} | ||||
| 
 | ||||
|       - name: Log in to GitHub Container Registry | ||||
|         uses: docker/login-action@v2 | ||||
|         with: | ||||
|           registry: ghcr.io | ||||
|           username: ${{ github.repository_owner }} | ||||
|           password: ${{ secrets.GITHUB_TOKEN }} | ||||
| 
 | ||||
|       - name: Log in to Aliyun Container Registry | ||||
|         uses: docker/login-action@v2 | ||||
|         with: | ||||
|           registry: registry.cn-hangzhou.aliyuncs.com | ||||
|           username: ${{ secrets.ALIREGISTRY_USERNAME }} | ||||
|           password: ${{ secrets.ALIREGISTRY_TOKEN }} | ||||
| 
 | ||||
|       - name: Extract metadata for Docker (tags, labels) | ||||
|         id: meta | ||||
|         uses: docker/metadata-action@v5 | ||||
|         with: | ||||
|           tags: | | ||||
|             type=ref,event=tag | ||||
|             type=schedule | ||||
|             type=ref,event=branch | ||||
|             type=semver,pattern={{version}} | ||||
|             type=semver,pattern=v{{version}} | ||||
|             # type=semver,pattern={{major}}.{{minor}} | ||||
|             type=semver,pattern=release-{{raw}} | ||||
|             type=sha | ||||
|             type=raw,value=${{ github.event.inputs.tag }} | ||||
| 
 | ||||
|       - name: Build and push Docker images | ||||
|         run: | | ||||
|           ROOT_DIR="build/images" | ||||
|           for dir in "$ROOT_DIR"/*/; do | ||||
|               # Find Dockerfile or *.dockerfile in a case-insensitive manner | ||||
|               dockerfile=$(find "$dir" -maxdepth 1 -type f \( -iname 'dockerfile' -o -iname '*.dockerfile' \) | head -n 1) | ||||
|                | ||||
|               if [ -n "$dockerfile" ] && [ -f "$dockerfile" ]; then | ||||
|                   IMAGE_NAME=$(basename "$dir") | ||||
|                   echo "Building Docker image for $IMAGE_NAME with tags:" | ||||
|                    | ||||
|                   # Initialize tag arguments | ||||
|                   tag_args=() | ||||
|    | ||||
|                   # Read each tag and append --tag arguments | ||||
|                   while IFS= read -r tag; do | ||||
|                       tag_args+=(--tag "${{ secrets.DOCKER_USERNAME }}/$IMAGE_NAME:$tag") | ||||
|                       tag_args+=(--tag "ghcr.io/${{ github.repository_owner }}/$IMAGE_NAME:$tag") | ||||
|                       tag_args+=(--tag "registry.cn-hangzhou.aliyuncs.com/openimsdk/$IMAGE_NAME:$tag") | ||||
|                   done <<< "${{ steps.meta.outputs.tags }}" | ||||
|    | ||||
|                   # Build and push the Docker image with all tags | ||||
|                   docker buildx build --platform linux/amd64,linux/arm64 \ | ||||
|                     --file "$dockerfile" \ | ||||
|                     "${tag_args[@]}" \ | ||||
|                     --push "$dir" | ||||
|               else | ||||
|                   echo "No valid Dockerfile found in $dir" | ||||
|               fi | ||||
|           done | ||||
| @ -43,7 +43,7 @@ COPY --from=builder $SERVER_DIR/start-config.yml $SERVER_DIR/ | ||||
| COPY --from=builder $SERVER_DIR/go.mod $SERVER_DIR/ | ||||
| COPY --from=builder $SERVER_DIR/go.sum $SERVER_DIR/ | ||||
| 
 | ||||
| RUN go get github.com/openimsdk/gomake@v0.0.14-alpha.5 | ||||
| RUN go get github.com/openimsdk/gomake@v0.0.15-alpha.1 | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ||||
|  | ||||
| @ -1,24 +1,24 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # # | ||||
| # # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # # you may not use this file except in compliance with the License. | ||||
| # # You may obtain a copy of the License at | ||||
| # # | ||||
| # #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # # | ||||
| # # Unless required by applicable law or agreed to in writing, software | ||||
| # # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # # See the License for the specific language governing permissions and | ||||
| # # limitations under the License. | ||||
| 
 | ||||
| FROM BASE_IMAGE | ||||
| # FROM BASE_IMAGE | ||||
| 
 | ||||
| WORKDIR ${SERVER_WORKDIR} | ||||
| # WORKDIR ${SERVER_WORKDIR} | ||||
| 
 | ||||
| # Set HTTP proxy | ||||
| ARG BINARY_NAME | ||||
| # # Set HTTP proxy | ||||
| # ARG BINARY_NAME | ||||
| 
 | ||||
| COPY BINARY_NAME ./bin/BINARY_NAME | ||||
| # COPY BINARY_NAME ./bin/BINARY_NAME | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/BINARY_NAME"] | ||||
| # ENTRYPOINT ["./bin/BINARY_NAME"] | ||||
| @ -1,44 +1,36 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # Use Go 1.22 Alpine as the base image for building the application | ||||
| FROM golang:1.22-alpine AS builder | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| # Set the working directory inside the container based on the environment variable | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| # Set the Go proxy to improve dependency resolution speed | ||||
| #ENV GOPROXY=https://goproxy.io,direct | ||||
| 
 | ||||
| # Copy all files from the current directory into the container | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make build BINS=openim-api | ||||
| RUN go mod tidy | ||||
| 
 | ||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-api /usr/bin/openim-api | ||||
| RUN go build -o _output/openim-api ./cmd/openim-api | ||||
| 
 | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| # Using Alpine Linux for the final image | ||||
| FROM alpine:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| # Install necessary packages, such as bash | ||||
| RUN apk add --no-cache bash | ||||
| 
 | ||||
| COPY --from=builder /usr/bin/openim-api ./bin/openim-api | ||||
| # Set the environment and work directory | ||||
| ENV SERVER_DIR=/openim-server | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/openim-api"] | ||||
| 
 | ||||
| # Copy the compiled binaries and mage from the builder image to the final image | ||||
| COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "_output/openim-api"] | ||||
|  | ||||
| @ -1,44 +0,0 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| 
 | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make build BINS=openim-cmdutils | ||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-cmdutils /usr/bin/openim-cmdutils | ||||
| 
 | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| COPY --from=builder /usr/bin/openim-cmdutils ./bin/openim-cmdutils | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/openim-cmdutils"] | ||||
| 
 | ||||
| CMD ["--help"] | ||||
| @ -1,44 +1,39 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # Use Go 1.22 Alpine as the base image for building the application | ||||
| FROM golang:1.22-alpine AS builder | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| # Set the working directory inside the container based on the environment variable | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| # Set the Go proxy to improve dependency resolution speed | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| #ENV GOPROXY=https://goproxy.io,direct | ||||
| 
 | ||||
| # Copy all files from the current directory into the container | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make build BINS=openim-crontask | ||||
| RUN go mod tidy | ||||
| 
 | ||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-crontask /usr/bin/openim-crontask | ||||
| 
 | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| RUN go build -o _output/openim-crontask ./cmd/openim-crontask | ||||
| 
 | ||||
| COPY --from=builder /usr/bin/openim-crontask ./bin/openim-crontask | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/openim-crontask"] | ||||
| # Using Alpine Linux for the final image | ||||
| FROM alpine:latest | ||||
| 
 | ||||
| # Install necessary packages, such as bash | ||||
| RUN apk add --no-cache bash | ||||
| 
 | ||||
| # Set the environment and work directory | ||||
| ENV SERVER_DIR=/openim-server | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| 
 | ||||
| # Copy the compiled binaries and mage from the builder image to the final image | ||||
| COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||
| # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "_output/openim-crontask"] | ||||
| @ -1,44 +1,39 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # Use Go 1.22 Alpine as the base image for building the application | ||||
| FROM golang:1.22-alpine AS builder | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| # Set the working directory inside the container based on the environment variable | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| # Set the Go proxy to improve dependency resolution speed | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| #ENV GOPROXY=https://goproxy.io,direct | ||||
| 
 | ||||
| # Copy all files from the current directory into the container | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make build BINS=openim-msggateway | ||||
| RUN go mod tidy | ||||
| 
 | ||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-msggateway /usr/bin/openim-msggateway | ||||
| 
 | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| RUN go build -o _output/openim-msggateway ./cmd/openim-msggateway | ||||
| 
 | ||||
| COPY --from=builder /usr/bin/openim-msggateway ./bin/openim-msggateway | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/openim-msggateway"] | ||||
| # Using Alpine Linux for the final image | ||||
| FROM alpine:latest | ||||
| 
 | ||||
| # Install necessary packages, such as bash | ||||
| RUN apk add --no-cache bash | ||||
| 
 | ||||
| # Set the environment and work directory | ||||
| ENV SERVER_DIR=/openim-server | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| 
 | ||||
| # Copy the compiled binaries and mage from the builder image to the final image | ||||
| COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||
| # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "_output/openim-msggateway"] | ||||
| @ -1,44 +1,39 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # Use Go 1.22 Alpine as the base image for building the application | ||||
| FROM golang:1.22-alpine AS builder | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| # Set the working directory inside the container based on the environment variable | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| # Set the Go proxy to improve dependency resolution speed | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| #ENV GOPROXY=https://goproxy.io,direct | ||||
| 
 | ||||
| # Copy all files from the current directory into the container | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make build BINS=openim-msgtransfer | ||||
| RUN go mod tidy | ||||
| 
 | ||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-msgtransfer /usr/bin/openim-msgtransfer | ||||
| 
 | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| RUN go build -o _output/openim-msgtransfer ./cmd/openim-msgtransfer | ||||
| 
 | ||||
| COPY --from=builder /usr/bin/openim-msgtransfer ./bin/openim-msgtransfer | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/openim-msgtransfer"] | ||||
| # Using Alpine Linux for the final image | ||||
| FROM alpine:latest | ||||
| 
 | ||||
| # Install necessary packages, such as bash | ||||
| RUN apk add --no-cache bash | ||||
| 
 | ||||
| # Set the environment and work directory | ||||
| ENV SERVER_DIR=/openim-server | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| 
 | ||||
| # Copy the compiled binaries and mage from the builder image to the final image | ||||
| COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||
| # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "_output/openim-msgtransfer"] | ||||
| @ -1,44 +1,39 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # Use Go 1.22 Alpine as the base image for building the application | ||||
| FROM golang:1.22-alpine AS builder | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| # Set the working directory inside the container based on the environment variable | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| # Set the Go proxy to improve dependency resolution speed | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| #ENV GOPROXY=https://goproxy.io,direct | ||||
| 
 | ||||
| # Copy all files from the current directory into the container | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make build BINS=openim-push | ||||
| RUN go mod tidy | ||||
| 
 | ||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-push /usr/bin/openim-push | ||||
| 
 | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| RUN go build -o _output/openim-push ./cmd/openim-push | ||||
| 
 | ||||
| COPY --from=builder /usr/bin/openim-push ./bin/openim-push | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/openim-push"] | ||||
| # Using Alpine Linux for the final image | ||||
| FROM alpine:latest | ||||
| 
 | ||||
| # Install necessary packages, such as bash | ||||
| RUN apk add --no-cache bash | ||||
| 
 | ||||
| # Set the environment and work directory | ||||
| ENV SERVER_DIR=/openim-server | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| 
 | ||||
| # Copy the compiled binaries and mage from the builder image to the final image | ||||
| COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||
| # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "_output/openim-push"] | ||||
| @ -1,44 +1,39 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # Use Go 1.22 Alpine as the base image for building the application | ||||
| FROM golang:1.22-alpine AS builder | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| # Set the working directory inside the container based on the environment variable | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| # Set the Go proxy to improve dependency resolution speed | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| #ENV GOPROXY=https://goproxy.io,direct | ||||
| 
 | ||||
| # Copy all files from the current directory into the container | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make build BINS=openim-rpc-auth | ||||
| RUN go mod tidy | ||||
| 
 | ||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-auth /usr/bin/openim-rpc-auth | ||||
| 
 | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| RUN go build -o _output/openim-rpc-auth ./cmd/openim-rpc/openim-rpc-auth | ||||
| 
 | ||||
| COPY --from=builder /usr/bin/openim-rpc-auth ./bin/openim-rpc-auth | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/openim-rpc-auth"] | ||||
| # Using Alpine Linux for the final image | ||||
| FROM alpine:latest | ||||
| 
 | ||||
| # Install necessary packages, such as bash | ||||
| RUN apk add --no-cache bash | ||||
| 
 | ||||
| # Set the environment and work directory | ||||
| ENV SERVER_DIR=/openim-server | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| 
 | ||||
| # Copy the compiled binaries and mage from the builder image to the final image | ||||
| COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||
| # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "_output/openim-rpc-auth"] | ||||
| @ -1,44 +1,39 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # Use Go 1.22 Alpine as the base image for building the application | ||||
| FROM golang:1.22-alpine AS builder | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| # Set the working directory inside the container based on the environment variable | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| # Set the Go proxy to improve dependency resolution speed | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| #ENV GOPROXY=https://goproxy.io,direct | ||||
| 
 | ||||
| # Copy all files from the current directory into the container | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make build BINS=openim-rpc-conversation | ||||
| RUN go mod tidy | ||||
| 
 | ||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-conversation /usr/bin/openim-rpc-conversation | ||||
| 
 | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| RUN go build -o _output/openim-rpc-conversation ./cmd/openim-rpc/openim-rpc-conversation | ||||
| 
 | ||||
| COPY --from=builder /usr/bin/openim-rpc-conversation ./bin/openim-rpc-conversation | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/openim-rpc-conversation"] | ||||
| # Using Alpine Linux for the final image | ||||
| FROM alpine:latest | ||||
| 
 | ||||
| # Install necessary packages, such as bash | ||||
| RUN apk add --no-cache bash | ||||
| 
 | ||||
| # Set the environment and work directory | ||||
| ENV SERVER_DIR=/openim-server | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| 
 | ||||
| # Copy the compiled binaries and mage from the builder image to the final image | ||||
| COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||
| # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "_output/openim-rpc-conversation"] | ||||
| @ -1,44 +1,39 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # Use Go 1.22 Alpine as the base image for building the application | ||||
| FROM golang:1.22-alpine AS builder | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| # Set the working directory inside the container based on the environment variable | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| # Set the Go proxy to improve dependency resolution speed | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| #ENV GOPROXY=https://goproxy.io,direct | ||||
| 
 | ||||
| # Copy all files from the current directory into the container | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make build BINS=openim-rpc-friend | ||||
| RUN go mod tidy | ||||
| 
 | ||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-friend /usr/bin/openim-rpc-friend | ||||
| 
 | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| RUN go build -o _output/openim-rpc-friend ./cmd/openim-rpc/openim-rpc-friend | ||||
| 
 | ||||
| COPY --from=builder /usr/bin/openim-rpc-friend ./bin/openim-rpc-friend | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/openim-rpc-friend"] | ||||
| # Using Alpine Linux for the final image | ||||
| FROM alpine:latest | ||||
| 
 | ||||
| # Install necessary packages, such as bash | ||||
| RUN apk add --no-cache bash | ||||
| 
 | ||||
| # Set the environment and work directory | ||||
| ENV SERVER_DIR=/openim-server | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| 
 | ||||
| # Copy the compiled binaries and mage from the builder image to the final image | ||||
| COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||
| # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "_output/openim-rpc-friend"] | ||||
| @ -1,44 +1,39 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # Use Go 1.22 Alpine as the base image for building the application | ||||
| FROM golang:1.22-alpine AS builder | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| # Set the working directory inside the container based on the environment variable | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| # Set the Go proxy to improve dependency resolution speed | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| #ENV GOPROXY=https://goproxy.io,direct | ||||
| 
 | ||||
| # Copy all files from the current directory into the container | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make build BINS=openim-rpc-group | ||||
| RUN go mod tidy | ||||
| 
 | ||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-group /usr/bin/openim-rpc-group | ||||
| 
 | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| RUN go build -o _output/openim-rpc-group ./cmd/openim-rpc/openim-rpc-group | ||||
| 
 | ||||
| COPY --from=builder /usr/bin/openim-rpc-group ./bin/openim-rpc-group | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/openim-rpc-group"] | ||||
| # Using Alpine Linux for the final image | ||||
| FROM alpine:latest | ||||
| 
 | ||||
| # Install necessary packages, such as bash | ||||
| RUN apk add --no-cache bash | ||||
| 
 | ||||
| # Set the environment and work directory | ||||
| ENV SERVER_DIR=/openim-server | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| 
 | ||||
| # Copy the compiled binaries and mage from the builder image to the final image | ||||
| COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||
| # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "_output/openim-rpc-group"] | ||||
| @ -1,44 +1,39 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # Use Go 1.22 Alpine as the base image for building the application | ||||
| FROM golang:1.22-alpine AS builder | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| # Set the working directory inside the container based on the environment variable | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| # Set the Go proxy to improve dependency resolution speed | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| #ENV GOPROXY=https://goproxy.io,direct | ||||
| 
 | ||||
| # Copy all files from the current directory into the container | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make build BINS=openim-rpc-msg | ||||
| RUN go mod tidy | ||||
| 
 | ||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-msg /usr/bin/openim-rpc-msg | ||||
| 
 | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| RUN go build -o _output/openim-rpc-msg ./cmd/openim-rpc/openim-rpc-msg | ||||
| 
 | ||||
| COPY --from=builder /usr/bin/openim-rpc-msg ./bin/openim-rpc-msg | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/openim-rpc-msg"] | ||||
| # Using Alpine Linux for the final image | ||||
| FROM alpine:latest | ||||
| 
 | ||||
| # Install necessary packages, such as bash | ||||
| RUN apk add --no-cache bash | ||||
| 
 | ||||
| # Set the environment and work directory | ||||
| ENV SERVER_DIR=/openim-server | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| 
 | ||||
| # Copy the compiled binaries and mage from the builder image to the final image | ||||
| COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||
| # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "_output/openim-rpc-msg"] | ||||
| @ -1,44 +1,39 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # Use Go 1.22 Alpine as the base image for building the application | ||||
| FROM golang:1.22-alpine AS builder | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| # Set the working directory inside the container based on the environment variable | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| # Set the Go proxy to improve dependency resolution speed | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| #ENV GOPROXY=https://goproxy.io,direct | ||||
| 
 | ||||
| # Copy all files from the current directory into the container | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make build BINS=openim-rpc-third | ||||
| RUN go mod tidy | ||||
| 
 | ||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-third /usr/bin/openim-rpc-third | ||||
| 
 | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| RUN go build -o _output/openim-rpc-third ./cmd/openim-rpc/openim-rpc-third | ||||
| 
 | ||||
| COPY --from=builder /usr/bin/openim-rpc-third ./bin/openim-rpc-third | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/openim-rpc-third"] | ||||
| # Using Alpine Linux for the final image | ||||
| FROM alpine:latest | ||||
| 
 | ||||
| # Install necessary packages, such as bash | ||||
| RUN apk add --no-cache bash | ||||
| 
 | ||||
| # Set the environment and work directory | ||||
| ENV SERVER_DIR=/openim-server | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| 
 | ||||
| # Copy the compiled binaries and mage from the builder image to the final image | ||||
| COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||
| # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "_output/openim-rpc-third"] | ||||
| @ -1,44 +1,37 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| # | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # Use Go 1.22 Alpine as the base image for building the application | ||||
| FROM golang:1.22-alpine AS builder | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| # Set the working directory inside the container based on the environment variable | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| # Set the Go proxy to improve dependency resolution speed | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| #ENV GOPROXY=https://goproxy.io,direct | ||||
| 
 | ||||
| # Copy all files from the current directory into the container | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make build BINS=openim-rpc-user | ||||
| RUN go mod tidy | ||||
| 
 | ||||
| RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-user /usr/bin/openim-rpc-user | ||||
| RUN go build -o _output/openim-rpc-user ./cmd/openim-rpc/openim-rpc-user | ||||
| 
 | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| # Using Alpine Linux for the final image | ||||
| FROM alpine:latest | ||||
| 
 | ||||
| COPY --from=builder /usr/bin/openim-rpc-user ./bin/openim-rpc-user | ||||
| # Install necessary packages, such as bash | ||||
| RUN apk add --no-cache bash | ||||
| 
 | ||||
| ENTRYPOINT ["./bin/openim-rpc-user"] | ||||
| # Set the environment and work directory | ||||
| ENV SERVER_DIR=/openim-server | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| 
 | ||||
| # Copy the compiled binaries and mage from the builder image to the final image | ||||
| COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||
| # COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "_output/openim-rpc-user"] | ||||
| @ -1,48 +1,108 @@ | ||||
| # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # # Copyright © 2023 OpenIM. All rights reserved. | ||||
| # # | ||||
| # # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # # you may not use this file except in compliance with the License. | ||||
| # # You may obtain a copy of the License at | ||||
| # # | ||||
| # #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # # | ||||
| # # Unless required by applicable law or agreed to in writing, software | ||||
| # # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # # See the License for the specific language governing permissions and | ||||
| # # limitations under the License. | ||||
| 
 | ||||
| # # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| 
 | ||||
| # # Set go mod installation source and proxy | ||||
| 
 | ||||
| # FROM golang:1.20 AS builder | ||||
| 
 | ||||
| #  | ||||
| # Licensed under the Apache License, Version 2.0 (the "License"); | ||||
| # you may not use this file except in compliance with the License. | ||||
| # You may obtain a copy of the License at | ||||
| 
 | ||||
| # WORKDIR /openim/openim-server | ||||
| 
 | ||||
| #  | ||||
| #     http://www.apache.org/licenses/LICENSE-2.0 | ||||
| # | ||||
| # Unless required by applicable law or agreed to in writing, software | ||||
| # distributed under the License is distributed on an "AS IS" BASIS, | ||||
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||||
| # See the License for the specific language governing permissions and | ||||
| # limitations under the License. | ||||
| # ENV GOPROXY=$GOPROXY | ||||
| 
 | ||||
| # OpenIM base image: https://github.com/openim-sigs/openim-base-image | ||||
| # COPY go.mod go.sum ./ | ||||
| # RUN go mod download | ||||
| 
 | ||||
| # Set go mod installation source and proxy | ||||
| # COPY . . | ||||
| 
 | ||||
| FROM golang:1.20 AS builder | ||||
| # RUN make clean | ||||
| # RUN make build BINS=component | ||||
| 
 | ||||
| ARG GO111MODULE=on | ||||
| # # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| # WORKDIR /openim/openim-server | ||||
| 
 | ||||
| ENV GO111MODULE=$GO111MODULE | ||||
| ENV GOPROXY=$GOPROXY | ||||
| # COPY --from=builder /openim/openim-server/_output/bin/tools /openim/openim-server/_output/bin/tools/ | ||||
| # COPY --from=builder /openim/openim-server/config /openim/openim-server/config | ||||
| 
 | ||||
| COPY go.mod go.sum ./ | ||||
| RUN go mod download | ||||
| # ENV OPENIM_SERVER_CONFIG_NAME=/openim/openim-server/config | ||||
| 
 | ||||
| # RUN mv ${OPENIM_SERVER_BINDIR}/platforms/$(get_os)/$(get_arch)/component /usr/bin/component | ||||
| 
 | ||||
| # ENTRYPOINT ["bash", "-c", "component -c $OPENIM_SERVER_CONFIG_NAME"] | ||||
| 
 | ||||
| 
 | ||||
| # Use Go 1.22 Alpine as the base image for building the application | ||||
| FROM golang:1.22-alpine AS builder | ||||
| # Define the base directory for the application as an environment variable | ||||
| ENV SERVER_DIR=/openim-server | ||||
| 
 | ||||
| # Set the working directory inside the container based on the environment variable | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| # Set the Go proxy to improve dependency resolution speed | ||||
| 
 | ||||
| #ENV GOPROXY=https://goproxy.io,direct | ||||
| 
 | ||||
| # Copy all files from the current directory into the container | ||||
| COPY . . | ||||
| 
 | ||||
| RUN make clean | ||||
| RUN make build BINS=component | ||||
| RUN go mod download | ||||
| 
 | ||||
| # FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| FROM ghcr.io/openim-sigs/openim-bash-image:latest | ||||
| # Install Mage to use for building the application | ||||
| RUN go install github.com/magefile/mage@v1.15.0 | ||||
| 
 | ||||
| WORKDIR /openim/openim-server | ||||
| # ENV BINS=openim-rpc-user | ||||
| 
 | ||||
| COPY --from=builder /openim/openim-server/_output/bin/tools /openim/openim-server/_output/bin/tools/ | ||||
| COPY --from=builder /openim/openim-server/config /openim/openim-server/config | ||||
| # Optionally build your application if needed | ||||
| # RUN mage build ${BINS} check-free-memory seq || true | ||||
| RUN mage build check-free-memory seq || true | ||||
| 
 | ||||
| ENV OPENIM_SERVER_CONFIG_NAME=/openim/openim-server/config | ||||
| # Using Alpine Linux with Go environment for the final image | ||||
| FROM golang:1.22-alpine | ||||
| 
 | ||||
| RUN mv ${OPENIM_SERVER_BINDIR}/platforms/$(get_os)/$(get_arch)/component /usr/bin/component | ||||
| # Install necessary packages, such as bash | ||||
| RUN apk add bash | ||||
| 
 | ||||
| ENTRYPOINT ["bash", "-c", "component -c $OPENIM_SERVER_CONFIG_NAME"] | ||||
| # Set the environment and work directory | ||||
| ENV SERVER_DIR=/openim-server | ||||
| WORKDIR $SERVER_DIR | ||||
| 
 | ||||
| 
 | ||||
| # Copy the compiled binaries and mage from the builder image to the final image | ||||
| COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output | ||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | ||||
| COPY --from=builder /go/bin/mage /usr/local/bin/mage | ||||
| COPY --from=builder $SERVER_DIR/magefile_windows.go $SERVER_DIR/ | ||||
| COPY --from=builder $SERVER_DIR/magefile_unix.go $SERVER_DIR/ | ||||
| COPY --from=builder $SERVER_DIR/magefile.go $SERVER_DIR/ | ||||
| # COPY --from=builder $SERVER_DIR/start-config.yml $SERVER_DIR/ | ||||
| COPY --from=builder $SERVER_DIR/go.mod $SERVER_DIR/ | ||||
| COPY --from=builder $SERVER_DIR/go.sum $SERVER_DIR/ | ||||
| 
 | ||||
| 
 | ||||
| RUN echo -e "serviceBinaries:\n  \n" \ | ||||
|     > $SERVER_DIR/start-config.yml && \ | ||||
|     echo -e "toolBinaries:\n  - check-free-memory\n  - seq\n" >> $SERVER_DIR/start-config.yml && \ | ||||
|     echo "maxFileDescriptors: 10000" >> $SERVER_DIR/start-config.yml | ||||
| 
 | ||||
| RUN go get github.com/openimsdk/gomake@v0.0.15-alpha.1 | ||||
| 
 | ||||
| # Set the command to run when the container starts | ||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ||||
|  | ||||
| @ -5,4 +5,16 @@ etcd: | ||||
|   username: '' | ||||
|   password: '' | ||||
| 
 | ||||
| kubernetes: | ||||
|   namespace: default | ||||
| 
 | ||||
| rpcService: | ||||
|   user: user-rpc-service | ||||
|   friend: friend-rpc-service | ||||
|   msg: msg-rpc-service | ||||
|   push: push-rpc-service | ||||
|   messageGateway: messageGateway-rpc-service | ||||
|   group: group-rpc-service | ||||
|   auth: auth-rpc-service | ||||
|   conversation: conversation-rpc-service | ||||
|   third: third-rpc-service | ||||
| @ -1,6 +1,12 @@ | ||||
| rpc: | ||||
|   # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP | ||||
|   registerIP: | ||||
|   # autoSetPorts indicates whether to automatically set the ports | ||||
|   # if you use in kubernetes, set it to false | ||||
|   autoSetPorts: true | ||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||
|   # It will only take effect when autoSetPorts is set to false. | ||||
|   ports: [ 10140, 10141, 10142, 10143, 10144, 10145, 10146, 10147, 10148, 10149, 10150, 10151, 10152, 10153, 10154, 10155 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|  | ||||
| @ -3,6 +3,13 @@ rpc: | ||||
|   registerIP: | ||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||
|   listenIP: 0.0.0.0 | ||||
|   # autoSetPorts indicates whether to automatically set the ports | ||||
|   # if you use in kubernetes, set it to false | ||||
|   autoSetPorts: true | ||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||
|   # It will only take effect when autoSetPorts is set to false. | ||||
|   ports: [ 10170, 10171, 10172, 10173, 10174, 10175, 10176, 10177, 10178, 10179, 10180, 10181, 10182, 10183, 10184, 10185 ] | ||||
| 
 | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|  | ||||
| @ -3,6 +3,12 @@ rpc: | ||||
|   registerIP:  | ||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||
|   listenIP: 0.0.0.0 | ||||
|   # autoSetPorts indicates whether to automatically set the ports | ||||
|   # if you use in kubernetes, set it to false | ||||
|   autoSetPorts: true | ||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||
|   # It will only take effect when autoSetPorts is set to false. | ||||
|   ports: [ 10200 ] | ||||
| 
 | ||||
| 
 | ||||
| prometheus: | ||||
|  | ||||
| @ -3,6 +3,12 @@ rpc: | ||||
|   registerIP:  | ||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||
|   listenIP: 0.0.0.0 | ||||
|   # autoSetPorts indicates whether to automatically set the ports | ||||
|   # if you use in kubernetes, set it to false | ||||
|   autoSetPorts: true | ||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||
|   # It will only take effect when autoSetPorts is set to false. | ||||
|   ports: [ 10220 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|  | ||||
| @ -3,6 +3,12 @@ rpc: | ||||
|   registerIP:  | ||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||
|   listenIP: 0.0.0.0 | ||||
|   # autoSetPorts indicates whether to automatically set the ports | ||||
|   # if you use in kubernetes, set it to false | ||||
|   autoSetPorts: true | ||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||
|   # It will only take effect when autoSetPorts is set to false. | ||||
|   ports: [ 10240 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|  | ||||
| @ -3,6 +3,12 @@ rpc: | ||||
|   registerIP: | ||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||
|   listenIP: 0.0.0.0 | ||||
|   # autoSetPorts indicates whether to automatically set the ports | ||||
|   # if you use in kubernetes, set it to false | ||||
|   autoSetPorts: true | ||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||
|   # It will only take effect when autoSetPorts is set to false. | ||||
|   ports: [ 10260 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|  | ||||
| @ -3,6 +3,12 @@ rpc: | ||||
|   registerIP:  | ||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||
|   listenIP: 0.0.0.0 | ||||
|   # autoSetPorts indicates whether to automatically set the ports | ||||
|   # if you use in kubernetes, set it to false | ||||
|   autoSetPorts: true | ||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||
|   # It will only take effect when autoSetPorts is set to false. | ||||
|   ports: [ 10280 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|  | ||||
| @ -3,6 +3,12 @@ rpc: | ||||
|   registerIP:  | ||||
|   # IP address that the RPC service listens on; setting to 0.0.0.0 listens on both internal and external IPs. If left blank, it automatically uses the internal network IP | ||||
|   listenIP: 0.0.0.0 | ||||
|   # autoSetPorts indicates whether to automatically set the ports | ||||
|   # if you use in kubernetes, set it to false | ||||
|   autoSetPorts: true | ||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||
|   # It will only take effect when autoSetPorts is set to false. | ||||
|   ports: [ 10300 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Enable or disable Prometheus monitoring | ||||
|  | ||||
| @ -3,6 +3,12 @@ rpc: | ||||
|   registerIP:  | ||||
|   # Listening IP; 0.0.0.0 means both internal and external IPs are listened to, if blank, the internal network IP is automatically obtained by default | ||||
|   listenIP: 0.0.0.0 | ||||
|   # autoSetPorts indicates whether to automatically set the ports | ||||
|   # if you use in kubernetes, set it to false | ||||
|   autoSetPorts: true | ||||
|   # List of ports that the RPC service listens on; configuring multiple ports will launch multiple instances. These must match the number of configured prometheus ports | ||||
|   # It will only take effect when autoSetPorts is set to false. | ||||
|   ports: [ 10320 ] | ||||
| 
 | ||||
| prometheus: | ||||
|   # Whether to enable prometheus | ||||
|  | ||||
							
								
								
									
										37
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										37
									
								
								go.mod
									
									
									
									
									
								
							| @ -14,8 +14,8 @@ require ( | ||||
| 	github.com/gorilla/websocket v1.5.1 | ||||
| 	github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 | ||||
| 	github.com/mitchellh/mapstructure v1.5.0 | ||||
| 	github.com/openimsdk/protocol v0.0.72-alpha.59 | ||||
| 	github.com/openimsdk/tools v0.0.50-alpha.38 | ||||
| 	github.com/openimsdk/protocol v0.0.72-alpha.61 | ||||
| 	github.com/openimsdk/tools v0.0.50-alpha.45 | ||||
| 	github.com/pkg/errors v0.9.1 // indirect | ||||
| 	github.com/prometheus/client_golang v1.18.0 | ||||
| 	github.com/stretchr/testify v1.9.0 | ||||
| @ -37,15 +37,17 @@ require ( | ||||
| 	github.com/hashicorp/golang-lru/v2 v2.0.7 | ||||
| 	github.com/kelindar/bitmap v1.5.2 | ||||
| 	github.com/likexian/gokit v0.25.13 | ||||
| 	github.com/openimsdk/gomake v0.0.14-alpha.5 | ||||
| 	github.com/openimsdk/gomake v0.0.15-alpha.1 | ||||
| 	github.com/redis/go-redis/v9 v9.4.0 | ||||
| 	github.com/robfig/cron/v3 v3.0.1 | ||||
| 	github.com/shirou/gopsutil v3.21.11+incompatible | ||||
| 	github.com/spf13/viper v1.18.2 | ||||
| 	github.com/stathat/consistent v1.0.0 | ||||
| 	go.uber.org/automaxprocs v1.5.3 | ||||
| 	golang.org/x/exp v0.0.0-20230905200255-921286631fa9 | ||||
| 	golang.org/x/sync v0.8.0 | ||||
| 	k8s.io/api v0.31.2 | ||||
| 	k8s.io/apimachinery v0.31.2 | ||||
| 	k8s.io/client-go v0.31.2 | ||||
| ) | ||||
| 
 | ||||
| require ( | ||||
| @ -90,19 +92,29 @@ require ( | ||||
| 	github.com/eapache/go-resiliency v1.6.0 // indirect | ||||
| 	github.com/eapache/go-xerial-snappy v0.0.0-20230731223053-c322873962e3 // indirect | ||||
| 	github.com/eapache/queue v1.1.0 // indirect | ||||
| 	github.com/elastic/go-sysinfo v1.0.2 // indirect | ||||
| 	github.com/elastic/go-windows v1.0.0 // indirect | ||||
| 	github.com/emicklei/go-restful/v3 v3.11.0 // indirect | ||||
| 	github.com/felixge/httpsnoop v1.0.4 // indirect | ||||
| 	github.com/fsnotify/fsnotify v1.7.0 // indirect | ||||
| 	github.com/fxamacker/cbor/v2 v2.7.0 // indirect | ||||
| 	github.com/gabriel-vasile/mimetype v1.4.3 // indirect | ||||
| 	github.com/gin-contrib/sse v0.1.0 // indirect | ||||
| 	github.com/go-logr/logr v1.4.2 // indirect | ||||
| 	github.com/go-logr/stdr v1.2.2 // indirect | ||||
| 	github.com/go-ole/go-ole v1.2.6 // indirect | ||||
| 	github.com/go-openapi/jsonpointer v0.19.6 // indirect | ||||
| 	github.com/go-openapi/jsonreference v0.20.2 // indirect | ||||
| 	github.com/go-openapi/swag v0.22.4 // indirect | ||||
| 	github.com/go-playground/universal-translator v0.18.1 // indirect | ||||
| 	github.com/go-zookeeper/zk v1.0.3 // indirect | ||||
| 	github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect | ||||
| 	github.com/golang/protobuf v1.5.4 // indirect | ||||
| 	github.com/golang/snappy v0.0.4 // indirect | ||||
| 	github.com/google/gnostic-models v0.6.8 // indirect | ||||
| 	github.com/google/go-cmp v0.6.0 // indirect | ||||
| 	github.com/google/go-querystring v1.1.0 // indirect | ||||
| 	github.com/google/gofuzz v1.2.0 // indirect | ||||
| 	github.com/google/s2a-go v0.1.7 // indirect | ||||
| 	github.com/googleapis/enterprise-certificate-proxy v0.3.2 // indirect | ||||
| 	github.com/googleapis/gax-go/v2 v2.12.3 // indirect | ||||
| @ -119,6 +131,8 @@ require ( | ||||
| 	github.com/jinzhu/copier v0.4.0 // indirect | ||||
| 	github.com/jinzhu/inflection v1.0.0 // indirect | ||||
| 	github.com/jinzhu/now v1.1.5 // indirect | ||||
| 	github.com/joeshaw/multierror v0.0.0-20140124173710-69b34d4ec901 // indirect | ||||
| 	github.com/josharian/intern v1.0.0 // indirect | ||||
| 	github.com/json-iterator/go v1.1.12 // indirect | ||||
| 	github.com/kelindar/simd v1.1.2 // indirect | ||||
| 	github.com/klauspost/compress v1.17.7 // indirect | ||||
| @ -128,6 +142,7 @@ require ( | ||||
| 	github.com/lithammer/shortuuid v3.0.0+incompatible // indirect | ||||
| 	github.com/magefile/mage v1.15.0 // indirect | ||||
| 	github.com/magiconair/properties v1.8.7 // indirect | ||||
| 	github.com/mailru/easyjson v0.7.7 // indirect | ||||
| 	github.com/mattn/go-colorable v0.1.13 // indirect | ||||
| 	github.com/matttproud/golang_protobuf_extensions/v2 v2.0.0 // indirect | ||||
| 	github.com/minio/md5-simd v1.1.2 // indirect | ||||
| @ -137,6 +152,7 @@ require ( | ||||
| 	github.com/modern-go/reflect2 v1.0.2 // indirect | ||||
| 	github.com/montanaflynn/stats v0.0.0-20171201202039-1bf9dbcd8cbe // indirect | ||||
| 	github.com/mozillazg/go-httpheader v0.4.0 // indirect | ||||
| 	github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect | ||||
| 	github.com/pelletier/go-toml/v2 v2.2.2 // indirect | ||||
| 	github.com/pierrec/lz4/v4 v4.1.21 // indirect | ||||
| 	github.com/pmezard/go-difflib v1.0.1-0.20181226105442-5d4384ee4fb2 // indirect | ||||
| @ -158,6 +174,7 @@ require ( | ||||
| 	github.com/tklauser/go-sysconf v0.3.13 // indirect | ||||
| 	github.com/tklauser/numcpus v0.7.0 // indirect | ||||
| 	github.com/twitchyliquid64/golang-asm v0.15.1 // indirect | ||||
| 	github.com/x448/float16 v0.8.4 // indirect | ||||
| 	github.com/xdg-go/pbkdf2 v1.0.0 // indirect | ||||
| 	github.com/xdg-go/scram v1.1.2 // indirect | ||||
| 	github.com/xdg-go/stringprep v1.0.4 // indirect | ||||
| @ -179,14 +196,24 @@ require ( | ||||
| 	golang.org/x/net v0.29.0 // indirect | ||||
| 	golang.org/x/oauth2 v0.23.0 // indirect | ||||
| 	golang.org/x/sys v0.25.0 // indirect | ||||
| 	golang.org/x/term v0.24.0 // indirect | ||||
| 	golang.org/x/text v0.18.0 // indirect | ||||
| 	golang.org/x/time v0.5.0 // indirect | ||||
| 	google.golang.org/appengine/v2 v2.0.2 // indirect | ||||
| 	google.golang.org/genproto v0.0.0-20240213162025-012b6fc9bca9 // indirect | ||||
| 	google.golang.org/genproto/googleapis/api v0.0.0-20240903143218-8af14fe29dc1 // indirect | ||||
| 	google.golang.org/genproto/googleapis/rpc v0.0.0-20240903143218-8af14fe29dc1 // indirect | ||||
| 	gopkg.in/inf.v0 v0.9.1 // indirect | ||||
| 	gopkg.in/yaml.v2 v2.4.0 // indirect | ||||
| 	gorm.io/gorm v1.25.8 // indirect | ||||
| 	stathat.com/c/consistent v1.0.0 // indirect | ||||
| 	howett.net/plist v0.0.0-20181124034731-591f970eefbb // indirect | ||||
| 	k8s.io/klog/v2 v2.130.1 // indirect | ||||
| 	k8s.io/kube-openapi v0.0.0-20240228011516-70dd3763d340 // indirect | ||||
| 	k8s.io/utils v0.0.0-20240711033017-18e509b52bc8 // indirect | ||||
| 	modernc.org/fileutil v1.0.0 // indirect | ||||
| 	sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd // indirect | ||||
| 	sigs.k8s.io/structured-merge-diff/v4 v4.4.1 // indirect | ||||
| 	sigs.k8s.io/yaml v1.4.0 // indirect | ||||
| ) | ||||
| 
 | ||||
| require ( | ||||
|  | ||||
							
								
								
									
										87
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										87
									
								
								go.sum
									
									
									
									
									
								
							| @ -103,6 +103,12 @@ github.com/eapache/go-xerial-snappy v0.0.0-20230731223053-c322873962e3 h1:Oy0F4A | ||||
| github.com/eapache/go-xerial-snappy v0.0.0-20230731223053-c322873962e3/go.mod h1:YvSRo5mw33fLEx1+DlK6L2VV43tJt5Eyel9n9XBcR+0= | ||||
| github.com/eapache/queue v1.1.0 h1:YOEu7KNc61ntiQlcEeUIoDTJ2o8mQznoNvUhiigpIqc= | ||||
| github.com/eapache/queue v1.1.0/go.mod h1:6eCeP0CKFpHLu8blIFXhExK/dRa7WDZfr6jVFPTqq+I= | ||||
| github.com/elastic/go-sysinfo v1.0.2 h1:Wq1bOgnSz7Obl7DbMjbn0tzx1bE5G8Cfy3MVFa6C1Cc= | ||||
| github.com/elastic/go-sysinfo v1.0.2/go.mod h1:O/D5m1VpYLwGjCYzEt63g3Z1uO3jXfwyzzjiW90t8cY= | ||||
| github.com/elastic/go-windows v1.0.0 h1:qLURgZFkkrYyTTkvYpsZIgf83AUsdIHfvlJaqaZ7aSY= | ||||
| github.com/elastic/go-windows v1.0.0/go.mod h1:TsU0Nrp7/y3+VwE82FoZF8gC/XFg/Elz6CcloAxnPgU= | ||||
| github.com/emicklei/go-restful/v3 v3.11.0 h1:rAQeMHw1c7zTmncogyy8VvRZwtkmkZ4FxERmMY4rD+g= | ||||
| github.com/emicklei/go-restful/v3 v3.11.0/go.mod h1:6n3XBCmQQb25CM2LCACGz8ukIrRry+4bhvbpWn3mrbc= | ||||
| github.com/envoyproxy/go-control-plane v0.9.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= | ||||
| github.com/envoyproxy/go-control-plane v0.9.1-0.20191026205805-5f8ba28d4473/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= | ||||
| github.com/envoyproxy/go-control-plane v0.9.4/go.mod h1:6rpuAdCZL397s3pYoYcLgu1mIlRU8Am5FuJP05cCM98= | ||||
| @ -117,6 +123,8 @@ github.com/frankban/quicktest v1.14.6 h1:7Xjx+VpznH+oBnejlPUj8oUpdxnVs4f8XU8WnHk | ||||
| github.com/frankban/quicktest v1.14.6/go.mod h1:4ptaffx2x8+WTWXmUCuVU6aPUX1/Mz7zb5vbUoiM6w0= | ||||
| github.com/fsnotify/fsnotify v1.7.0 h1:8JEhPFa5W2WU7YfeZzPNqzMP6Lwt7L2715Ggo0nosvA= | ||||
| github.com/fsnotify/fsnotify v1.7.0/go.mod h1:40Bi/Hjc2AVfZrqy+aj+yEI+/bRxZnMJyTJwOpGvigM= | ||||
| github.com/fxamacker/cbor/v2 v2.7.0 h1:iM5WgngdRBanHcxugY4JySA0nk1wZorNOpTgCMedv5E= | ||||
| github.com/fxamacker/cbor/v2 v2.7.0/go.mod h1:pxXPTn3joSm21Gbwsv0w9OSA2y1HFR9qXEeXQVeNoDQ= | ||||
| github.com/gabriel-vasile/mimetype v1.4.3 h1:in2uUcidCuFcDKtdcBxlR0rJ1+fsokWf+uqxgUFjbI0= | ||||
| github.com/gabriel-vasile/mimetype v1.4.3/go.mod h1:d8uq/6HKRL6CGdk+aubisF/M5GcPfT7nKyLpA0lbSSk= | ||||
| github.com/gin-contrib/gzip v1.0.1 h1:HQ8ENHODeLY7a4g1Au/46Z92bdGFl74OhxcZble9WJE= | ||||
| @ -132,6 +140,13 @@ github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag= | ||||
| github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE= | ||||
| github.com/go-ole/go-ole v1.2.6 h1:/Fpf6oFPoeFik9ty7siob0G6Ke8QvQEuVcuChpwXzpY= | ||||
| github.com/go-ole/go-ole v1.2.6/go.mod h1:pprOEPIfldk/42T2oK7lQ4v4JSDwmV0As9GaiUsvbm0= | ||||
| github.com/go-openapi/jsonpointer v0.19.6 h1:eCs3fxoIi3Wh6vtgmLTOjdhSpiqphQ+DaPn38N2ZdrE= | ||||
| github.com/go-openapi/jsonpointer v0.19.6/go.mod h1:osyAmYz/mB/C3I+WsTTSgw1ONzaLJoLCyoi6/zppojs= | ||||
| github.com/go-openapi/jsonreference v0.20.2 h1:3sVjiK66+uXK/6oQ8xgcRKcFgQ5KXa2KvnJRumpMGbE= | ||||
| github.com/go-openapi/jsonreference v0.20.2/go.mod h1:Bl1zwGIM8/wsvqjsOQLJ/SH+En5Ap4rVB5KVcIDZG2k= | ||||
| github.com/go-openapi/swag v0.22.3/go.mod h1:UzaqsxGiab7freDnrUUra0MwWfN/q7tE4j+VcZ0yl14= | ||||
| github.com/go-openapi/swag v0.22.4 h1:QLMzNJnMGPRNDCbySlcj1x01tzU8/9LTTL9hZZZogBU= | ||||
| github.com/go-openapi/swag v0.22.4/go.mod h1:UzaqsxGiab7freDnrUUra0MwWfN/q7tE4j+VcZ0yl14= | ||||
| github.com/go-playground/assert/v2 v2.0.1/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4= | ||||
| github.com/go-playground/assert/v2 v2.2.0 h1:JvknZsQTYeFEAhQwI4qEt9cyV5ONwRHC+lYKSsYSR8s= | ||||
| github.com/go-playground/assert/v2 v2.2.0/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4= | ||||
| @ -150,6 +165,8 @@ github.com/go-redis/redis v6.15.9+incompatible h1:K0pv1D7EQUjfyoMql+r/jZqCLizCGK | ||||
| github.com/go-redis/redis v6.15.9+incompatible/go.mod h1:NAIEuMOZ/fxfXJIrKDQDz8wamY7mA7PouImQ2Jvg6kA= | ||||
| github.com/go-redis/redismock/v9 v9.2.0 h1:ZrMYQeKPECZPjOj5u9eyOjg8Nnb0BS9lkVIZ6IpsKLw= | ||||
| github.com/go-redis/redismock/v9 v9.2.0/go.mod h1:18KHfGDK4Y6c2R0H38EUGWAdc7ZQS9gfYxc94k7rWT0= | ||||
| github.com/go-task/slim-sprig/v3 v3.0.0 h1:sUs3vkvUymDpBKi3qH1YSqBQk9+9D/8M2mN1vB6EwHI= | ||||
| github.com/go-task/slim-sprig/v3 v3.0.0/go.mod h1:W848ghGpv3Qj3dhTPRyJypKRiqCdHZiAzKg9hl15HA8= | ||||
| github.com/go-zookeeper/zk v1.0.3 h1:7M2kwOsc//9VeeFiPtf+uSJlVpU66x9Ba5+8XK7/TDg= | ||||
| github.com/go-zookeeper/zk v1.0.3/go.mod h1:nOB03cncLtlp4t+UAkGSV+9beXP/akpekBwL+UX1Qcw= | ||||
| github.com/goccy/go-json v0.10.2 h1:CrxCmQqYDkv1z7lO7Wbh2HN93uovUHgrECaO5ZrCXAU= | ||||
| @ -179,6 +196,8 @@ github.com/golang/protobuf v1.5.4 h1:i7eJL8qZTpSEXOPTxNKhASYpMn+8e5Q6AdndVa1dWek | ||||
| github.com/golang/protobuf v1.5.4/go.mod h1:lnTiLA8Wa4RWRcIUkrtSVa5nRhsEGBg48fD6rSs7xps= | ||||
| github.com/golang/snappy v0.0.4 h1:yAGX7huGHXlcLOEtBnF4w7FQwA26wojNCwOYAEhLjQM= | ||||
| github.com/golang/snappy v0.0.4/go.mod h1:/XxbfmMg8lxefKM7IXC3fBNl/7bRcc72aCRzEWrmP2Q= | ||||
| github.com/google/gnostic-models v0.6.8 h1:yo/ABAfM5IMRsS1VnXjTBvUb61tFIHozhlYvRgGre9I= | ||||
| github.com/google/gnostic-models v0.6.8/go.mod h1:5n7qKqH0f5wFt+aWF8CW6pZLLNOfYuF5OpfBSENuI8U= | ||||
| github.com/google/go-cmp v0.2.0/go.mod h1:oXzfMopK8JAjlY9xF4vHSVASa0yLyX7SntLO5aqRK0M= | ||||
| github.com/google/go-cmp v0.3.0/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU= | ||||
| github.com/google/go-cmp v0.3.1/go.mod h1:8QqcDgzrUqlUb/G2PQTWiueGozuR1884gddMywk6iLU= | ||||
| @ -186,14 +205,19 @@ github.com/google/go-cmp v0.4.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/ | ||||
| github.com/google/go-cmp v0.5.0/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/go-cmp v0.5.2/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/go-cmp v0.5.3/go.mod h1:v8dTdLbMG2kIc/vJvl+f65V22dbkXbowE6jgT/gNBxE= | ||||
| github.com/google/go-cmp v0.5.9/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= | ||||
| github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= | ||||
| github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= | ||||
| github.com/google/go-querystring v1.0.0/go.mod h1:odCYkC5MyYFN7vkCjXpyrEuKhc/BUO6wN/zVPAxq5ck= | ||||
| github.com/google/go-querystring v1.1.0 h1:AnCroh3fv4ZBgVIf1Iwtovgjaw/GiKJo8M8yD/fhyJ8= | ||||
| github.com/google/go-querystring v1.1.0/go.mod h1:Kcdr2DB4koayq7X8pmAG4sNG59So17icRSOU623lUBU= | ||||
| github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= | ||||
| github.com/google/gofuzz v1.2.0 h1:xRy4A+RhZaiKjJ1bPfwQ8sedCA+YS2YcCHW6ec7JMi0= | ||||
| github.com/google/gofuzz v1.2.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= | ||||
| github.com/google/martian/v3 v3.3.2 h1:IqNFLAmvJOgVlpdEBiQbDc2EwKW77amAycfTuWKdfvw= | ||||
| github.com/google/martian/v3 v3.3.2/go.mod h1:oBOf6HBosgwRXnUGWUB05QECsc6uvmMiJ3+6W4l/CUk= | ||||
| github.com/google/pprof v0.0.0-20240525223248-4bfdf5a9a2af h1:kmjWCqn2qkEml422C2Rrd27c3VGxi6a/6HNq8QmHRKM= | ||||
| github.com/google/pprof v0.0.0-20240525223248-4bfdf5a9a2af/go.mod h1:K1liHPHnj73Fdn/EKuT8nrFqBihUSKXoLYU0BuatOYo= | ||||
| github.com/google/s2a-go v0.1.7 h1:60BLSyTrOV4/haCDW4zb1guZItoSq8foHCXrAnjBo/o= | ||||
| github.com/google/s2a-go v0.1.7/go.mod h1:50CgR4k1jNlWBu4UfS4AcfhVe1r6pdZPygJ3R8F0Qdw= | ||||
| github.com/google/uuid v1.1.1/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= | ||||
| @ -244,6 +268,8 @@ github.com/jinzhu/now v1.1.5 h1:/o9tlHleP7gOFmsnYNz3RGnqzefHA47wQpKrrdTIwXQ= | ||||
| github.com/jinzhu/now v1.1.5/go.mod h1:d3SSVoowX0Lcu0IBviAWJpolVfI5UJVZZ7cO71lE/z8= | ||||
| github.com/jonboulle/clockwork v0.4.0 h1:p4Cf1aMWXnXAUh8lVfewRBx1zaTSYKrKMF2g3ST4RZ4= | ||||
| github.com/jonboulle/clockwork v0.4.0/go.mod h1:xgRqUGwRcjKCO1vbZUEtSLrqKoPSsUpK7fnezOII0kc= | ||||
| github.com/josharian/intern v1.0.0 h1:vlS4z54oSdjm0bgjRigI+G1HpF+tI+9rE5LLzOg8HmY= | ||||
| github.com/josharian/intern v1.0.0/go.mod h1:5DoeVV0s6jJacbCEi61lwdGj/aVlrQvzHFFd8Hwg//Y= | ||||
| github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM= | ||||
| github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= | ||||
| github.com/kelindar/bitmap v1.5.2 h1:XwX7CTvJtetQZ64zrOkApoZZHBJRkjE23NfqUALA/HE= | ||||
| @ -285,6 +311,8 @@ github.com/magefile/mage v1.15.0 h1:BvGheCMAsG3bWUDbZ8AyXXpCNwU9u5CB6sM+HNb9HYg= | ||||
| github.com/magefile/mage v1.15.0/go.mod h1:z5UZb/iS3GoOSn0JgWuiw7dxlurVYTu+/jHXqQg881A= | ||||
| github.com/magiconair/properties v1.8.7 h1:IeQXZAiQcpL9mgcAe1Nu6cX9LLw6ExEHKjN0VQdvPDY= | ||||
| github.com/magiconair/properties v1.8.7/go.mod h1:Dhd985XPs7jluiymwWYZ0G4Z61jb3vdS329zhj2hYo0= | ||||
| github.com/mailru/easyjson v0.7.7 h1:UGYAvKxe3sBsEDzO8ZeWOSlIQfWFlxbzLZe7hwFURr0= | ||||
| github.com/mailru/easyjson v0.7.7/go.mod h1:xzfreul335JAWq5oZzymOObrkdz5UnU4kGfJJLY9Nlc= | ||||
| github.com/mattn/go-colorable v0.1.13 h1:fFA4WZxdEF4tXPZVKMLwD8oUnCTTo08duU7wxecdEvA= | ||||
| github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg= | ||||
| github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= | ||||
| @ -311,18 +339,22 @@ github.com/montanaflynn/stats v0.0.0-20171201202039-1bf9dbcd8cbe/go.mod h1:wL8QJ | ||||
| github.com/mozillazg/go-httpheader v0.2.1/go.mod h1:jJ8xECTlalr6ValeXYdOF8fFUISeBAdw6E61aqQma60= | ||||
| github.com/mozillazg/go-httpheader v0.4.0 h1:aBn6aRXtFzyDLZ4VIRLsZbbJloagQfMnCiYgOq6hK4w= | ||||
| github.com/mozillazg/go-httpheader v0.4.0/go.mod h1:PuT8h0pw6efvp8ZeUec1Rs7dwjK08bt6gKSReGMqtdA= | ||||
| github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 h1:C3w9PqII01/Oq1c1nUAm88MOHcQC9l5mIlSMApZMrHA= | ||||
| github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ= | ||||
| github.com/nxadm/tail v1.4.8 h1:nPr65rt6Y5JFSKQO7qToXr7pePgD6Gwiw05lkbyAQTE= | ||||
| github.com/nxadm/tail v1.4.8/go.mod h1:+ncqLTQzXmGhMZNUePPaPqPvBxHAIsmXswZKocGu+AU= | ||||
| github.com/onsi/ginkgo v1.16.5 h1:8xi0RTUf59SOSfEtZMvwTvXYMzG4gV23XVHOZiXNtnE= | ||||
| github.com/onsi/ginkgo v1.16.5/go.mod h1:+E8gABHa3K6zRBolWtd+ROzc/U5bkGt0FwiG042wbpU= | ||||
| github.com/onsi/ginkgo/v2 v2.19.0 h1:9Cnnf7UHo57Hy3k6/m5k3dRfGTMXGvxhHFvkDTCTpvA= | ||||
| github.com/onsi/ginkgo/v2 v2.19.0/go.mod h1:rlwLi9PilAFJ8jCg9UE1QP6VBpd6/xj3SRC0d6TU0To= | ||||
| github.com/onsi/gomega v1.25.0 h1:Vw7br2PCDYijJHSfBOWhov+8cAnUf8MfMaIOV323l6Y= | ||||
| github.com/onsi/gomega v1.25.0/go.mod h1:r+zV744Re+DiYCIPRlYOTxn0YkOLcAnW8k1xXdMPGhM= | ||||
| github.com/openimsdk/gomake v0.0.14-alpha.5 h1:VY9c5x515lTfmdhhPjMvR3BBRrRquAUCFsz7t7vbv7Y= | ||||
| github.com/openimsdk/gomake v0.0.14-alpha.5/go.mod h1:PndCozNc2IsQIciyn9mvEblYWZwJmAI+06z94EY+csI= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.59 h1:+ycb2+68mLKPIo7VrxF0id/GXP6OqZ2/nBM1YZQr7qY= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.59/go.mod h1:Iet+piS/jaS+kWWyj6EEr36mk4ISzIRYjoMSVA4dq2M= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.38 h1:AU6/cvDfN4ciIOwAj8IWEwze3DeEp2cHYPgW3y0OlbU= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.38/go.mod h1:/Em/fQH46CuWf60+hcmvZyboGCQpSDEb2MdQ4nmQRAk= | ||||
| github.com/openimsdk/gomake v0.0.15-alpha.1 h1:a3U0gayzEJJucOoIOt9Jju+HQTG2BtKcuLG4AVjeVF4= | ||||
| github.com/openimsdk/gomake v0.0.15-alpha.1/go.mod h1:PndCozNc2IsQIciyn9mvEblYWZwJmAI+06z94EY+csI= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.61 h1:RuZR9/Sg3p6Bpb2CKPjPoA2AUmTvHITmhZ3PT/RbWMs= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.61/go.mod h1:Iet+piS/jaS+kWWyj6EEr36mk4ISzIRYjoMSVA4dq2M= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.45 h1:bu3HCkdzLNQAPUR1VhF40XA9OhaNGHGxZqcC4rIYJyY= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.45/go.mod h1:YOtTcSQ7Ik6NYkjXCTXZT3YDM7smGp9D2xvti3KvNoM= | ||||
| github.com/pelletier/go-toml/v2 v2.2.2 h1:aYUidT7k73Pcl9nb2gScu7NSrKCSHIDE89b3+6Wq+LM= | ||||
| github.com/pelletier/go-toml/v2 v2.2.2/go.mod h1:1t835xjRzz80PqgE6HHgN2JOsmgYu/h4qDAS4n929Rs= | ||||
| github.com/pierrec/lz4/v4 v4.1.21 h1:yOVMLb6qSIDP67pl/5F7RepeKYu/VmTyEXvuMI5d9mQ= | ||||
| @ -356,8 +388,8 @@ github.com/robfig/cron/v3 v3.0.1 h1:WdRxkvbJztn8LMz/QEvLN5sBU+xKpSqwwUO1Pjr4qDs= | ||||
| github.com/robfig/cron/v3 v3.0.1/go.mod h1:eQICP3HwyT7UooqI/z+Ov+PtYAWygg1TEWWzGIFLtro= | ||||
| github.com/rogpeppe/go-internal v1.6.1/go.mod h1:xXDCJY+GAPziupqXw64V24skbSoqbTEfhy4qGm1nDQc= | ||||
| github.com/rogpeppe/go-internal v1.8.0/go.mod h1:WmiCO8CzOY8rg0OYDC4/i/2WRWAB6poM+XZ2dLUbcbE= | ||||
| github.com/rogpeppe/go-internal v1.10.0 h1:TMyTOH3F/DB16zRVcYyreMH6GnZZrwQVAoYjRBZyWFQ= | ||||
| github.com/rogpeppe/go-internal v1.10.0/go.mod h1:UQnix2H7Ngw/k4C5ijL5+65zddjncjaFoBhdsK/akog= | ||||
| github.com/rogpeppe/go-internal v1.12.0 h1:exVL4IDcn6na9z1rAb56Vxr+CgyK3nn3O+epU5NdKM8= | ||||
| github.com/rogpeppe/go-internal v1.12.0/go.mod h1:E+RYuTGaKKdloAfM02xzb0FW3Paa99yedzYV+kq4uf4= | ||||
| github.com/rs/xid v1.5.0 h1:mKX4bl4iPYJtEIxp6CYiUuLQ/8DYMoz0PUdtGgMFRVc= | ||||
| github.com/rs/xid v1.5.0/go.mod h1:trrq9SKmegXys3aeAKXMUTdJsYXVwGY3RLcfgqegfbg= | ||||
| github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= | ||||
| @ -379,8 +411,6 @@ github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA= | ||||
| github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg= | ||||
| github.com/spf13/viper v1.18.2 h1:LUXCnvUvSM6FXAsj6nnfc8Q2tp1dIgUfY9Kc8GsSOiQ= | ||||
| github.com/spf13/viper v1.18.2/go.mod h1:EKmWIqdnk5lOcmR72yw6hS+8OPYcwD0jteitLMVB+yk= | ||||
| github.com/stathat/consistent v1.0.0 h1:ZFJ1QTRn8npNBKW065raSZ8xfOqhpb8vLOkfp4CcL/U= | ||||
| github.com/stathat/consistent v1.0.0/go.mod h1:uajTPbgSygZBJ+V+0mY7meZ8i0XAcZs7AQ6V121XSxw= | ||||
| github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= | ||||
| github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw= | ||||
| github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= | ||||
| @ -410,6 +440,8 @@ github.com/twitchyliquid64/golang-asm v0.15.1 h1:SU5vSMR7hnwNxj24w34ZyCi/FmDZTkS | ||||
| github.com/twitchyliquid64/golang-asm v0.15.1/go.mod h1:a1lVb/DtPvCB8fslRZhAngC2+aY1QWCk3Cedj/Gdt08= | ||||
| github.com/ugorji/go/codec v1.2.12 h1:9LC83zGrHhuUA9l16C9AHXAqEV/2wBQ4nkvumAE65EE= | ||||
| github.com/ugorji/go/codec v1.2.12/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg= | ||||
| github.com/x448/float16 v0.8.4 h1:qLwI1I70+NjRFUR3zs1JPUCgaCXSh3SW62uAKT1mSBM= | ||||
| github.com/x448/float16 v0.8.4/go.mod h1:14CWIYCyZA/cWjXOioeEpHeN/83MdbZDRQHoFcYsOfg= | ||||
| github.com/xdg-go/pbkdf2 v1.0.0 h1:Su7DPu48wXMwC3bs7MCNG+z4FhcyEuz5dlvchbq0B0c= | ||||
| github.com/xdg-go/pbkdf2 v1.0.0/go.mod h1:jrpuAogTd400dnrH08LKmI/xc1MbPOebTwRqcT5RDeI= | ||||
| github.com/xdg-go/scram v1.1.2 h1:FHX5I5B4i4hKRVRBCFRxq1iQRej7WO3hhBuJf+UUySY= | ||||
| @ -449,8 +481,8 @@ go.uber.org/atomic v1.9.0 h1:ECmE8Bn/WFTYwEW/bpKD3M8VtR/zQVbavAoalC1PYyE= | ||||
| go.uber.org/atomic v1.9.0/go.mod h1:fEN4uk6kAWBTFdckzkM89CLk9XfWZrxpCo0nPH17wJc= | ||||
| go.uber.org/automaxprocs v1.5.3 h1:kWazyxZUrS3Gs4qUpbwo5kEIMGe/DAvi5Z4tl2NW4j8= | ||||
| go.uber.org/automaxprocs v1.5.3/go.mod h1:eRbA25aqJrxAbsLO0xy5jVwPt7FQnRgjW+efnwa1WM0= | ||||
| go.uber.org/goleak v1.1.11 h1:wy28qYRKZgnJTxGxvye5/wgWr1EKjmUDGYox5mGlRlI= | ||||
| go.uber.org/goleak v1.1.11/go.mod h1:cwTWslyiVhfpKIDGSZEM2HlOvcqm+tG4zioyIeLoqMQ= | ||||
| go.uber.org/goleak v1.3.0 h1:2K3zAYmnTNqV73imy9J1T3WC+gmCePx2hEGkimedGto= | ||||
| go.uber.org/goleak v1.3.0/go.mod h1:CoHD4mav9JJNrW/WLlf7HGZPjdw8EucARQHekz1X6bE= | ||||
| go.uber.org/multierr v1.11.0 h1:blXXJkSxSSfBVBlC76pxqeO+LN3aDfLQo+309xJstO0= | ||||
| go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y= | ||||
| go.uber.org/zap v1.24.0 h1:FiJd5l1UOLj0wCgbSE0rwwXHzEdAZS6hiiSnxJN/D60= | ||||
| @ -527,6 +559,8 @@ golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9sn | ||||
| golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= | ||||
| golang.org/x/term v0.1.0/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= | ||||
| golang.org/x/term v0.5.0/go.mod h1:jMB1sMXY+tzblOD4FWmEbocvup2/aLOaQEp7JmGp78k= | ||||
| golang.org/x/term v0.24.0 h1:Mh5cbb+Zk2hqqXNO7S1iTjEphVL+jb8ZWaqh/g+JWkM= | ||||
| golang.org/x/term v0.24.0/go.mod h1:lOBK/LVxemqiMij05LGJ0tzNr8xlmwBRJ81PX6wVLH8= | ||||
| golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ= | ||||
| golang.org/x/text v0.3.2/go.mod h1:bEr9sfX3Q8Zfm5fL9x+3itogRgK3+ptLWKqgva+5dAk= | ||||
| golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= | ||||
| @ -548,6 +582,8 @@ golang.org/x/tools v0.0.0-20191119224855-298f0cb1881e/go.mod h1:b+2E5dAYhXwXZwtn | ||||
| golang.org/x/tools v0.0.0-20200619180055-7c47624df98f/go.mod h1:EkVYQZoAsY45+roYkvgYkIh4xh/qjgUK9TdY2XT94GE= | ||||
| golang.org/x/tools v0.0.0-20210106214847-113979e3529a/go.mod h1:emZCQorbCU4vsT4fOWvOPXz4eW1wZW4PmDk9uLelYpA= | ||||
| golang.org/x/tools v0.1.12/go.mod h1:hNGJHUnrk76NpqgfD5Aqm5Crs+Hm0VOH/i9J2+nxYbc= | ||||
| golang.org/x/tools v0.21.1-0.20240508182429-e35e4ccd0d2d h1:vU5i/LfpvrRCpgM/VPfJLg5KjxD3E+hfT1SH+d9zLwg= | ||||
| golang.org/x/tools v0.21.1-0.20240508182429-e35e4ccd0d2d/go.mod h1:aiJjzUbINMkxbQROHiO6hDPo2LHcIPhhQsa9DLh0yGk= | ||||
| golang.org/x/xerrors v0.0.0-20190717185122-a985d3407aa7/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| golang.org/x/xerrors v0.0.0-20191204190536-9bdfabe68543/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0= | ||||
| @ -592,11 +628,14 @@ gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8 | ||||
| gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk= | ||||
| gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c/go.mod h1:JHkPIbrfpd72SG/EVd6muEfDQjcINNoR0C8j2r3qZ4Q= | ||||
| gopkg.in/errgo.v2 v2.1.0/go.mod h1:hNsd1EY+bozCKY1Ytp96fpM3vjJbqLJn88ws8XvfDNI= | ||||
| gopkg.in/inf.v0 v0.9.1 h1:73M5CoZyi3ZLMOyDlQh031Cx6N9NDJ2Vvfl76EDAgDc= | ||||
| gopkg.in/inf.v0 v0.9.1/go.mod h1:cWUDdTG/fYaXco+Dcufb5Vnc6Gp2YChqWtbxRZE0mXw= | ||||
| gopkg.in/ini.v1 v1.67.0 h1:Dgnx+6+nfE+IfzjUEISNeydPJh9AXNNsWbGP9KzCsOA= | ||||
| gopkg.in/ini.v1 v1.67.0/go.mod h1:pNLf8WUiyNEtQjuu5G5vTm06TEv9tsIgeAvK8hOrP4k= | ||||
| gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7 h1:uRGJdciOHaEIrze2W8Q3AKkepLTh2hOroT7a+7czfdQ= | ||||
| gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw= | ||||
| gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= | ||||
| gopkg.in/yaml.v2 v2.2.8/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= | ||||
| gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY= | ||||
| gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ= | ||||
| gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= | ||||
| @ -607,7 +646,27 @@ gorm.io/gorm v1.25.8 h1:WAGEZ/aEcznN4D03laj8DKnehe1e9gYQAjW8xyPRdeo= | ||||
| gorm.io/gorm v1.25.8/go.mod h1:hbnx/Oo0ChWMn1BIhpy1oYozzpM15i4YPuHDmfYtwg8= | ||||
| honnef.co/go/tools v0.0.0-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= | ||||
| honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= | ||||
| howett.net/plist v0.0.0-20181124034731-591f970eefbb h1:jhnBjNi9UFpfpl8YZhA9CrOqpnJdvzuiHsl/dnxl11M= | ||||
| howett.net/plist v0.0.0-20181124034731-591f970eefbb/go.mod h1:vMygbs4qMhSZSc4lCUl2OEE+rDiIIJAIdR4m7MiMcm0= | ||||
| k8s.io/api v0.31.2 h1:3wLBbL5Uom/8Zy98GRPXpJ254nEFpl+hwndmk9RwmL0= | ||||
| k8s.io/api v0.31.2/go.mod h1:bWmGvrGPssSK1ljmLzd3pwCQ9MgoTsRCuK35u6SygUk= | ||||
| k8s.io/apimachinery v0.31.2 h1:i4vUt2hPK56W6mlT7Ry+AO8eEsyxMD1U44NR22CLTYw= | ||||
| k8s.io/apimachinery v0.31.2/go.mod h1:rsPdaZJfTfLsNJSQzNHQvYoTmxhoOEofxtOsF3rtsMo= | ||||
| k8s.io/client-go v0.31.2 h1:Y2F4dxU5d3AQj+ybwSMqQnpZH9F30//1ObxOKlTI9yc= | ||||
| k8s.io/client-go v0.31.2/go.mod h1:NPa74jSVR/+eez2dFsEIHNa+3o09vtNaWwWwb1qSxSs= | ||||
| k8s.io/klog/v2 v2.130.1 h1:n9Xl7H1Xvksem4KFG4PYbdQCQxqc/tTUyrgXaOhHSzk= | ||||
| k8s.io/klog/v2 v2.130.1/go.mod h1:3Jpz1GvMt720eyJH1ckRHK1EDfpxISzJ7I9OYgaDtPE= | ||||
| k8s.io/kube-openapi v0.0.0-20240228011516-70dd3763d340 h1:BZqlfIlq5YbRMFko6/PM7FjZpUb45WallggurYhKGag= | ||||
| k8s.io/kube-openapi v0.0.0-20240228011516-70dd3763d340/go.mod h1:yD4MZYeKMBwQKVht279WycxKyM84kkAx2DPrTXaeb98= | ||||
| k8s.io/utils v0.0.0-20240711033017-18e509b52bc8 h1:pUdcCO1Lk/tbT5ztQWOBi5HBgbBP1J8+AsQnQCKsi8A= | ||||
| k8s.io/utils v0.0.0-20240711033017-18e509b52bc8/go.mod h1:OLgZIPagt7ERELqWJFomSt595RzquPNLL48iOWgYOg0= | ||||
| modernc.org/fileutil v1.0.0 h1:Z1AFLZwl6BO8A5NldQg/xTSjGLetp+1Ubvl4alfGx8w= | ||||
| modernc.org/fileutil v1.0.0/go.mod h1:JHsWpkrk/CnVV1H/eGlFf85BEpfkrp56ro8nojIq9Q8= | ||||
| nullprogram.com/x/optparse v1.0.0/go.mod h1:KdyPE+Igbe0jQUrVfMqDMeJQIJZEuyV7pjYmp6pbG50= | ||||
| rsc.io/pdf v0.1.1/go.mod h1:n8OzWcQ6Sp37PL01nO98y4iUCRdTGarVfzxY20ICaU4= | ||||
| stathat.com/c/consistent v1.0.0 h1:ezyc51EGcRPJUxfHGSgJjWzJdj3NiMU9pNfLNGiXV0c= | ||||
| stathat.com/c/consistent v1.0.0/go.mod h1:QkzMWzcbB+yQBL2AttO6sgsQS/JSTapcDISJalmCDS0= | ||||
| sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd h1:EDPBXCAspyGV4jQlpZSudPeMmr1bNJefnuqLsRAsHZo= | ||||
| sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd/go.mod h1:B8JuhiUyNFVKdsE8h686QcCxMaH6HrOAZj4vswFpcB0= | ||||
| sigs.k8s.io/structured-merge-diff/v4 v4.4.1 h1:150L+0vs/8DA78h1u02ooW1/fFq/Lwr+sGiqlzvrtq4= | ||||
| sigs.k8s.io/structured-merge-diff/v4 v4.4.1/go.mod h1:N8hJocpFajUSSeSJ9bOZ77VzejKZaXsTtZo4/u7Io08= | ||||
| sigs.k8s.io/yaml v1.4.0 h1:Mk1wCc2gy/F0THH0TAp1QYyJNzRm2KCLy3o5ASXVI5E= | ||||
| sigs.k8s.io/yaml v1.4.0/go.mod h1:Ejl7/uTz7PSA4eKMyQCUTnhZYNmLIl+5c2lQPGR2BPY= | ||||
|  | ||||
| @ -17,9 +17,6 @@ package api | ||||
| import ( | ||||
| 	"context" | ||||
| 	"fmt" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	"github.com/openimsdk/tools/utils/network" | ||||
| 	"net" | ||||
| 	"net/http" | ||||
| 	"os" | ||||
| @ -28,6 +25,11 @@ import ( | ||||
| 	"syscall" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	"github.com/openimsdk/tools/utils/network" | ||||
| 	"github.com/openimsdk/tools/utils/runtimeenv" | ||||
| 
 | ||||
| 	kdisc "github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/prommetrics" | ||||
| 	"github.com/openimsdk/tools/discovery" | ||||
| @ -40,6 +42,8 @@ type Config struct { | ||||
| 	API       config.API | ||||
| 	Share     config.Share | ||||
| 	Discovery config.Discovery | ||||
| 
 | ||||
| 	RuntimeEnv string | ||||
| } | ||||
| 
 | ||||
| func Start(ctx context.Context, index int, config *Config) error { | ||||
| @ -48,10 +52,12 @@ func Start(ctx context.Context, index int, config *Config) error { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	config.RuntimeEnv = runtimeenv.PrintRuntimeEnvironment() | ||||
| 
 | ||||
| 	var client discovery.SvcDiscoveryRegistry | ||||
| 
 | ||||
| 	// Determine whether zk is passed according to whether it is a clustered deployment | ||||
| 	client, err = kdisc.NewDiscoveryRegister(&config.Discovery, &config.Share) | ||||
| 	client, err = kdisc.NewDiscoveryRegister(&config.Discovery, config.RuntimeEnv) | ||||
| 	if err != nil { | ||||
| 		return errs.WrapMsg(err, "failed to register discovery service") | ||||
| 	} | ||||
| @ -81,7 +87,7 @@ func Start(ctx context.Context, index int, config *Config) error { | ||||
| 	address := net.JoinHostPort(network.GetListenIP(config.API.Api.ListenIP), strconv.Itoa(apiPort)) | ||||
| 
 | ||||
| 	server := http.Server{Addr: address, Handler: router} | ||||
| 	log.CInfo(ctx, "API server is initializing", "address", address, "apiPort", apiPort, "prometheusPort", prometheusPort) | ||||
| 	log.CInfo(ctx, "API server is initializing", "runtimeEnv", config.RuntimeEnv, "address", address, "apiPort", apiPort, "prometheusPort", prometheusPort) | ||||
| 	go func() { | ||||
| 		err = server.ListenAndServe() | ||||
| 		if err != nil && err != http.ErrServerClosed { | ||||
|  | ||||
| @ -16,11 +16,13 @@ package msggateway | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpccache" | ||||
| 	"github.com/openimsdk/tools/db/redisutil" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	"time" | ||||
| 	"github.com/openimsdk/tools/utils/runtimeenv" | ||||
| 
 | ||||
| 	"github.com/openimsdk/tools/log" | ||||
| ) | ||||
| @ -31,11 +33,16 @@ type Config struct { | ||||
| 	RedisConfig    config.Redis | ||||
| 	WebhooksConfig config.Webhooks | ||||
| 	Discovery      config.Discovery | ||||
| 
 | ||||
| 	RuntimeEnv string | ||||
| } | ||||
| 
 | ||||
| // Start run ws server. | ||||
| func Start(ctx context.Context, index int, conf *Config) error { | ||||
| 	log.CInfo(ctx, "MSG-GATEWAY server is initializing", | ||||
| 	conf.RuntimeEnv = runtimeenv.PrintRuntimeEnvironment() | ||||
| 
 | ||||
| 	log.CInfo(ctx, "MSG-GATEWAY server is initializing", "runtimeEnv", conf.RuntimeEnv, "autoSetPorts", conf.MsgGateway.RPC.AutoSetPorts, | ||||
| 		"rpcPorts", conf.MsgGateway.RPC.Ports, | ||||
| 		"wsPort", conf.MsgGateway.LongConnSvr.Ports, "prometheusPorts", conf.MsgGateway.Prometheus.Ports) | ||||
| 	wsPort, err := datautil.GetElemByIndex(conf.MsgGateway.LongConnSvr.Ports, index) | ||||
| 	if err != nil { | ||||
|  | ||||
| @ -29,6 +29,7 @@ import ( | ||||
| 	"github.com/openimsdk/tools/db/mongoutil" | ||||
| 	"github.com/openimsdk/tools/db/redisutil" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	"github.com/openimsdk/tools/utils/runtimeenv" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| 	discRegister "github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister" | ||||
| @ -51,6 +52,8 @@ type MsgTransfer struct { | ||||
| 	historyMongoCH *OnlineHistoryMongoConsumerHandler | ||||
| 	ctx            context.Context | ||||
| 	cancel         context.CancelFunc | ||||
| 
 | ||||
| 	runTimeEnv string | ||||
| } | ||||
| 
 | ||||
| type Config struct { | ||||
| @ -64,7 +67,9 @@ type Config struct { | ||||
| } | ||||
| 
 | ||||
| func Start(ctx context.Context, index int, config *Config) error { | ||||
| 	log.CInfo(ctx, "MSG-TRANSFER server is initializing", "prometheusPorts", | ||||
| 	runTimeEnv := runtimeenv.PrintRuntimeEnvironment() | ||||
| 
 | ||||
| 	log.CInfo(ctx, "MSG-TRANSFER server is initializing", "runTimeEnv", runTimeEnv, "prometheusPorts", | ||||
| 		config.MsgTransfer.Prometheus.Ports, "index", index) | ||||
| 
 | ||||
| 	mgocli, err := mongoutil.NewMongoDB(ctx, config.MongodbConfig.Build()) | ||||
| @ -75,7 +80,7 @@ func Start(ctx context.Context, index int, config *Config) error { | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	client, err := discRegister.NewDiscoveryRegister(&config.Discovery, &config.Share) | ||||
| 	client, err := discRegister.NewDiscoveryRegister(&config.Discovery, runTimeEnv) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| @ -115,6 +120,7 @@ func Start(ctx context.Context, index int, config *Config) error { | ||||
| 	msgTransfer := &MsgTransfer{ | ||||
| 		historyCH:      historyCH, | ||||
| 		historyMongoCH: historyMongoCH, | ||||
| 		runTimeEnv:     runTimeEnv, | ||||
| 	} | ||||
| 	return msgTransfer.Start(index, config) | ||||
| } | ||||
|  | ||||
| @ -28,6 +28,7 @@ import ( | ||||
| 
 | ||||
| 	"github.com/openimsdk/tools/mcontext" | ||||
| 	"github.com/openimsdk/tools/mw" | ||||
| 	"github.com/openimsdk/tools/utils/runtimeenv" | ||||
| 	"google.golang.org/grpc" | ||||
| 	"google.golang.org/grpc/credentials/insecure" | ||||
| 
 | ||||
| @ -40,14 +41,18 @@ type CronTaskConfig struct { | ||||
| 	CronTask  config.CronTask | ||||
| 	Share     config.Share | ||||
| 	Discovery config.Discovery | ||||
| 
 | ||||
| 	runTimeEnv string | ||||
| } | ||||
| 
 | ||||
| func Start(ctx context.Context, config *CronTaskConfig) error { | ||||
| 	log.CInfo(ctx, "CRON-TASK server is initializing", "chatRecordsClearTime", config.CronTask.CronExecuteTime, "msgDestructTime", config.CronTask.RetainChatRecords) | ||||
| 	config.runTimeEnv = runtimeenv.PrintRuntimeEnvironment() | ||||
| 
 | ||||
| 	log.CInfo(ctx, "CRON-TASK server is initializing", "runTimeEnv", config.runTimeEnv, "chatRecordsClearTime", config.CronTask.CronExecuteTime, "msgDestructTime", config.CronTask.RetainChatRecords) | ||||
| 	if config.CronTask.RetainChatRecords < 1 { | ||||
| 		return errs.New("msg destruct time must be greater than 1").Wrap() | ||||
| 	} | ||||
| 	client, err := kdisc.NewDiscoveryRegister(&config.Discovery, &config.Share) | ||||
| 	client, err := kdisc.NewDiscoveryRegister(&config.Discovery, config.runTimeEnv) | ||||
| 	if err != nil { | ||||
| 		return errs.WrapMsg(err, "failed to register discovery service") | ||||
| 	} | ||||
|  | ||||
							
								
								
									
										13
									
								
								magefile.go
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								magefile.go
									
									
									
									
									
								
							| @ -4,14 +4,23 @@ | ||||
| package main | ||||
| 
 | ||||
| import ( | ||||
| 	"github.com/openimsdk/gomake/mageutil" | ||||
| 	"flag" | ||||
| 	"os" | ||||
| 
 | ||||
| 	"github.com/openimsdk/gomake/mageutil" | ||||
| ) | ||||
| 
 | ||||
| var Default = Build | ||||
| 
 | ||||
| func Build() { | ||||
| 	mageutil.Build() | ||||
| 	flag.Parse() | ||||
| 
 | ||||
| 	bin := flag.Args() | ||||
| 	if len(bin) != 0 { | ||||
| 		bin = bin[1:] | ||||
| 	} | ||||
| 
 | ||||
| 	mageutil.Build(bin) | ||||
| } | ||||
| 
 | ||||
| func Start() { | ||||
|  | ||||
| @ -16,12 +16,12 @@ package cmd | ||||
| 
 | ||||
| import ( | ||||
| 	"fmt" | ||||
| 	"path/filepath" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| 	"github.com/openimsdk/open-im-server/v3/version" | ||||
| 	"github.com/openimsdk/tools/errs" | ||||
| 	"github.com/openimsdk/tools/log" | ||||
| 	"github.com/openimsdk/tools/utils/runtimeenv" | ||||
| 	"github.com/spf13/cobra" | ||||
| ) | ||||
| 
 | ||||
| @ -105,18 +105,19 @@ func (r *RootCmd) initializeConfiguration(cmd *cobra.Command, opts *CmdOpts) err | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 
 | ||||
| 	runtimeEnv := runtimeenv.PrintRuntimeEnvironment() | ||||
| 
 | ||||
| 	// Load common configuration file | ||||
| 	//opts.configMap[ShareFileName] = StructEnvPrefix{EnvPrefix: shareEnvPrefix, ConfigStruct: &r.share} | ||||
| 	for configFileName, configStruct := range opts.configMap { | ||||
| 		err := config.LoadConfig(filepath.Join(configDirectory, configFileName), | ||||
| 			ConfigEnvPrefixMap[configFileName], configStruct) | ||||
| 		err := config.Load(configDirectory, configFileName, ConfigEnvPrefixMap[configFileName], runtimeEnv, configStruct) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
| 	// Load common log configuration file | ||||
| 	return config.LoadConfig(filepath.Join(configDirectory, LogConfigFileName), | ||||
| 		ConfigEnvPrefixMap[LogConfigFileName], &r.log) | ||||
| 	return config.Load(configDirectory, LogConfigFileName, ConfigEnvPrefixMap[LogConfigFileName], runtimeEnv, &r.log) | ||||
| } | ||||
| 
 | ||||
| func (r *RootCmd) applyOptions(opts ...func(*CmdOpts)) *CmdOpts { | ||||
|  | ||||
| @ -18,6 +18,8 @@ import ( | ||||
| 	"strings" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/openimsdk/tools/s3/aws" | ||||
| 
 | ||||
| 	"github.com/openimsdk/tools/db/mongoutil" | ||||
| 	"github.com/openimsdk/tools/db/redisutil" | ||||
| 	"github.com/openimsdk/tools/mq/kafka" | ||||
| @ -462,7 +464,12 @@ type ZooKeeper struct { | ||||
| type Discovery struct { | ||||
| 	Enable     string     `mapstructure:"enable"` | ||||
| 	Etcd       Etcd       `mapstructure:"etcd"` | ||||
| 	ZooKeeper ZooKeeper `mapstructure:"zooKeeper"` | ||||
| 	Kubernetes Kubernetes `mapstructure:"kubernetes"` | ||||
| 	RpcService RpcService `mapstructure:"rpcService"` | ||||
| } | ||||
| 
 | ||||
| type Kubernetes struct { | ||||
| 	Namespace string `mapstructure:"namespace"` | ||||
| } | ||||
| 
 | ||||
| type Etcd struct { | ||||
|  | ||||
| @ -16,6 +16,12 @@ package config | ||||
| 
 | ||||
| const ConfKey = "conf" | ||||
| 
 | ||||
| const ( | ||||
| 	MountConfigFilePath = "CONFIG_PATH" | ||||
| 	DeploymentType      = "DEPLOYMENT_TYPE" | ||||
| 	KUBERNETES          = "kubernetes" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
| 	// DefaultDirPerm is used for creating general directories, allowing the owner to read, write, and execute, | ||||
| 	// while the group and others can only read and execute. | ||||
|  | ||||
| @ -1,13 +1,29 @@ | ||||
| package config | ||||
| 
 | ||||
| import ( | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 	"strings" | ||||
| 
 | ||||
| 	"github.com/mitchellh/mapstructure" | ||||
| 	"github.com/openimsdk/tools/errs" | ||||
| 	"github.com/spf13/viper" | ||||
| 	"strings" | ||||
| ) | ||||
| 
 | ||||
| func LoadConfig(path string, envPrefix string, config any) error { | ||||
| func Load(configDirectory string, configFileName string, envPrefix string, runtimeEnv string, config any) error { | ||||
| 	if runtimeEnv == KUBERNETES { | ||||
| 		mountPath := os.Getenv(MountConfigFilePath) | ||||
| 		if mountPath == "" { | ||||
| 			return errs.ErrArgs.WrapMsg(MountConfigFilePath + " env is empty") | ||||
| 		} | ||||
| 
 | ||||
| 		return loadConfig(filepath.Join(mountPath, configFileName), envPrefix, config) | ||||
| 	} | ||||
| 
 | ||||
| 	return loadConfig(filepath.Join(configDirectory, configFileName), envPrefix, config) | ||||
| } | ||||
| 
 | ||||
| func loadConfig(path string, envPrefix string, config any) error { | ||||
| 	v := viper.New() | ||||
| 	v.SetConfigFile(path) | ||||
| 	v.SetEnvPrefix(envPrefix) | ||||
|  | ||||
| @ -1,27 +1,51 @@ | ||||
| package config | ||||
| 
 | ||||
| import ( | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| 	"os" | ||||
| 	"testing" | ||||
| 
 | ||||
| 	"github.com/stretchr/testify/assert" | ||||
| ) | ||||
| 
 | ||||
| func TestLoadLogConfig(t *testing.T) { | ||||
| 	var log Log | ||||
| 	err := LoadConfig("../../../config/log.yml", "IMENV_LOG", &log) | ||||
| 	os.Setenv("IMENV_LOG_REMAINLOGLEVEL", "5") | ||||
| 	err := Load("../../../config/", "log.yml", "IMENV_LOG", "source", &log) | ||||
| 	assert.Nil(t, err) | ||||
| 	assert.Equal(t, "../../../../logs/", log.StorageLocation) | ||||
| 	t.Log(log.RemainLogLevel) | ||||
| 	// assert.Equal(t, "../../../../logs/", log.StorageLocation) | ||||
| } | ||||
| 
 | ||||
| func TestLoadMongoConfig(t *testing.T) { | ||||
| 	var mongo Mongo | ||||
| 	// os.Setenv("DEPLOYMENT_TYPE", "kubernetes") | ||||
| 	os.Setenv("IMENV_MONGODB_PASSWORD", "openIM1231231") | ||||
| 	// os.Setenv("IMENV_MONGODB_URI", "openIM123") | ||||
| 	// os.Setenv("IMENV_MONGODB_USERNAME", "openIM123") | ||||
| 	err := Load("../../../config/", "mongodb.yml", "IMENV_MONGODB", "source", &mongo) | ||||
| 	// err := LoadConfig("../../../config/mongodb.yml", "IMENV_MONGODB", &mongo) | ||||
| 
 | ||||
| 	assert.Nil(t, err) | ||||
| 	t.Log(mongo.Password) | ||||
| 	// assert.Equal(t, "openIM123", mongo.Password) | ||||
| 	t.Log(os.Getenv("IMENV_MONGODB_PASSWORD")) | ||||
| 	t.Log(mongo) | ||||
| 	// //export IMENV_OPENIM_RPC_USER_RPC_LISTENIP="0.0.0.0" | ||||
| 	// assert.Equal(t, "0.0.0.0", user.RPC.ListenIP) | ||||
| 	// //export IMENV_OPENIM_RPC_USER_RPC_PORTS="10110,10111,10112" | ||||
| 	// assert.Equal(t, []int{10110, 10111, 10112}, user.RPC.Ports) | ||||
| } | ||||
| 
 | ||||
| func TestLoadMinioConfig(t *testing.T) { | ||||
| 	var storageConfig Minio | ||||
| 	err := LoadConfig("../../../config/minio.yml", "IMENV_MINIO", &storageConfig) | ||||
| 	err := Load("../../../config/minio.yml", "IMENV_MINIO", "", "source", &storageConfig) | ||||
| 	assert.Nil(t, err) | ||||
| 	assert.Equal(t, "openim", storageConfig.Bucket) | ||||
| } | ||||
| 
 | ||||
| func TestLoadWebhooksConfig(t *testing.T) { | ||||
| 	var webhooks Webhooks | ||||
| 	err := LoadConfig("../../../config/webhooks.yml", "IMENV_WEBHOOKS", &webhooks) | ||||
| 	err := Load("../../../config/webhooks.yml", "IMENV_WEBHOOKS", "", "source", &webhooks) | ||||
| 	assert.Nil(t, err) | ||||
| 	assert.Equal(t, 5, webhooks.BeforeAddBlack.Timeout) | ||||
| 
 | ||||
| @ -29,7 +53,7 @@ func TestLoadWebhooksConfig(t *testing.T) { | ||||
| 
 | ||||
| func TestLoadOpenIMRpcUserConfig(t *testing.T) { | ||||
| 	var user User | ||||
| 	err := LoadConfig("../../../config/openim-rpc-user.yml", "IMENV_OPENIM_RPC_USER", &user) | ||||
| 	err := Load("../../../config/openim-rpc-user.yml", "IMENV_OPENIM_RPC_USER", "", "source", &user) | ||||
| 	assert.Nil(t, err) | ||||
| 	//export IMENV_OPENIM_RPC_USER_RPC_LISTENIP="0.0.0.0" | ||||
| 	assert.Equal(t, "0.0.0.0", user.RPC.ListenIP) | ||||
| @ -39,14 +63,14 @@ func TestLoadOpenIMRpcUserConfig(t *testing.T) { | ||||
| 
 | ||||
| func TestLoadNotificationConfig(t *testing.T) { | ||||
| 	var noti Notification | ||||
| 	err := LoadConfig("../../../config/notification.yml", "IMENV_NOTIFICATION", ¬i) | ||||
| 	err := Load("../../../config/notification.yml", "IMENV_NOTIFICATION", "", "source", ¬i) | ||||
| 	assert.Nil(t, err) | ||||
| 	assert.Equal(t, "Your friend's profile has been changed", noti.FriendRemarkSet.OfflinePush.Title) | ||||
| } | ||||
| 
 | ||||
| func TestLoadOpenIMThirdConfig(t *testing.T) { | ||||
| 	var third Third | ||||
| 	err := LoadConfig("../../../config/openim-rpc-third.yml", "IMENV_OPENIM_RPC_THIRD", &third) | ||||
| 	err := Load("../../../config/openim-rpc-third.yml", "IMENV_OPENIM_RPC_THIRD", "", "source", &third) | ||||
| 	assert.Nil(t, err) | ||||
| 	assert.Equal(t, "enabled", third.Object.Enable) | ||||
| 	assert.Equal(t, "https://oss-cn-chengdu.aliyuncs.com", third.Object.Oss.Endpoint) | ||||
|  | ||||
| @ -15,29 +15,27 @@ | ||||
| package discoveryregister | ||||
| 
 | ||||
| import ( | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister/kubernetes" | ||||
| 	"github.com/openimsdk/tools/discovery" | ||||
| 
 | ||||
| 	"github.com/openimsdk/tools/discovery/kubernetes" | ||||
| 
 | ||||
| 	"github.com/openimsdk/tools/discovery/etcd" | ||||
| 	"github.com/openimsdk/tools/discovery/zookeeper" | ||||
| 	"github.com/openimsdk/tools/errs" | ||||
| 	"time" | ||||
| ) | ||||
| 
 | ||||
| // NewDiscoveryRegister creates a new service discovery and registry client based on the provided environment type. | ||||
| func NewDiscoveryRegister(discovery *config.Discovery, share *config.Share) (discovery.SvcDiscoveryRegistry, error) { | ||||
| func NewDiscoveryRegister(discovery *config.Discovery, runtimeEnv string) (discovery.SvcDiscoveryRegistry, error) { | ||||
| 	if runtimeEnv == "kubernetes" { | ||||
| 		discovery.Enable = "kubernetes" | ||||
| 	} | ||||
| 
 | ||||
| 	switch discovery.Enable { | ||||
| 	case "zookeeper": | ||||
| 		return zookeeper.NewZkClient( | ||||
| 			discovery.ZooKeeper.Address, | ||||
| 			discovery.ZooKeeper.Schema, | ||||
| 			zookeeper.WithFreq(time.Hour), | ||||
| 			zookeeper.WithUserNameAndPassword(discovery.ZooKeeper.Username, discovery.ZooKeeper.Password), | ||||
| 			zookeeper.WithRoundRobin(), | ||||
| 			zookeeper.WithTimeout(10), | ||||
| 		) | ||||
| 	case "k8s": | ||||
| 		return kubernetes.NewK8sDiscoveryRegister(share.RpcRegisterName.MessageGateway) | ||||
| 	case "kubernetes": | ||||
| 		return kubernetes.NewKubernetesConnManager(discovery.Kubernetes.Namespace) | ||||
| 	case "etcd": | ||||
| 		return etcd.NewSvcDiscoveryRegistry( | ||||
| 			discovery.Etcd.RootDirectory, | ||||
|  | ||||
| @ -16,184 +16,281 @@ package kubernetes | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 	"errors" | ||||
| 	"fmt" | ||||
| 	"os" | ||||
| 	"strconv" | ||||
| 	"strings" | ||||
| 	"sync" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/openimsdk/tools/discovery" | ||||
| 	"github.com/openimsdk/tools/log" | ||||
| 	"github.com/stathat/consistent" | ||||
| 	"google.golang.org/grpc" | ||||
| 	"google.golang.org/grpc/credentials/insecure" | ||||
| 	v1 "k8s.io/api/core/v1" | ||||
| 	metav1 "k8s.io/apimachinery/pkg/apis/meta/v1" | ||||
| 	"k8s.io/client-go/informers" | ||||
| 	"k8s.io/client-go/kubernetes" | ||||
| 	"k8s.io/client-go/rest" | ||||
| 	"k8s.io/client-go/tools/cache" | ||||
| ) | ||||
| 
 | ||||
| // K8sDR represents the Kubernetes service discovery and registration client. | ||||
| type K8sDR struct { | ||||
| 	options               []grpc.DialOption | ||||
| 	rpcRegisterAddr       string | ||||
| 	gatewayHostConsistent *consistent.Consistent | ||||
| 	gatewayName           string | ||||
| type KubernetesConnManager struct { | ||||
| 	clientset   *kubernetes.Clientset | ||||
| 	namespace   string | ||||
| 	dialOptions []grpc.DialOption | ||||
| 
 | ||||
| 	selfTarget string | ||||
| 
 | ||||
| 	mu      sync.RWMutex | ||||
| 	connMap map[string][]*grpc.ClientConn | ||||
| } | ||||
| 
 | ||||
| func NewK8sDiscoveryRegister(gatewayName string) (discovery.SvcDiscoveryRegistry, error) { | ||||
| 	gatewayConsistent := consistent.New() | ||||
| 	gatewayHosts := getMsgGatewayHost(context.Background(), gatewayName) | ||||
| 	for _, v := range gatewayHosts { | ||||
| 		gatewayConsistent.Add(v) | ||||
| 	} | ||||
| 	return &K8sDR{gatewayHostConsistent: gatewayConsistent}, nil | ||||
| } | ||||
| 
 | ||||
| func (cli *K8sDR) Register(serviceName, host string, port int, opts ...grpc.DialOption) error { | ||||
| 	if serviceName != cli.gatewayName { | ||||
| 		cli.rpcRegisterAddr = serviceName | ||||
| 	} else { | ||||
| 		cli.rpcRegisterAddr = getSelfHost(context.Background(), cli.gatewayName) | ||||
| 	} | ||||
| 
 | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func (cli *K8sDR) UnRegister() error { | ||||
| 
 | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func (cli *K8sDR) CreateRpcRootNodes(serviceNames []string) error { | ||||
| 
 | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func (cli *K8sDR) RegisterConf2Registry(key string, conf []byte) error { | ||||
| 
 | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func (cli *K8sDR) GetConfFromRegistry(key string) ([]byte, error) { | ||||
| 
 | ||||
| 	return nil, nil | ||||
| } | ||||
| 
 | ||||
| func (cli *K8sDR) GetUserIdHashGatewayHost(ctx context.Context, userId string) (string, error) { | ||||
| 	host, err := cli.gatewayHostConsistent.Get(userId) | ||||
| // NewKubernetesConnManager creates a new connection manager that uses Kubernetes services for service discovery. | ||||
| func NewKubernetesConnManager(namespace string, options ...grpc.DialOption) (*KubernetesConnManager, error) { | ||||
| 	config, err := rest.InClusterConfig() | ||||
| 	if err != nil { | ||||
| 		log.ZError(ctx, "GetUserIdHashGatewayHost error", err) | ||||
| 		return nil, fmt.Errorf("failed to create in-cluster config: %v", err) | ||||
| 	} | ||||
| 	return host, err | ||||
| 
 | ||||
| 	clientset, err := kubernetes.NewForConfig(config) | ||||
| 	if err != nil { | ||||
| 		return nil, fmt.Errorf("failed to create clientset: %v", err) | ||||
| 	} | ||||
| 
 | ||||
| 	k := &KubernetesConnManager{ | ||||
| 		clientset:   clientset, | ||||
| 		namespace:   namespace, | ||||
| 		dialOptions: options, | ||||
| 		connMap:     make(map[string][]*grpc.ClientConn), | ||||
| 	} | ||||
| 
 | ||||
| 	go k.watchEndpoints() | ||||
| 
 | ||||
| 	return k, nil | ||||
| } | ||||
| 
 | ||||
| func getSelfHost(ctx context.Context, gatewayName string) string { | ||||
| 	port := 88 | ||||
| 	instance := "openimserver" | ||||
| 	selfPodName := os.Getenv("MY_POD_NAME") | ||||
| 	ns := os.Getenv("MY_POD_NAMESPACE") | ||||
| 	statefuleIndex := 0 | ||||
| 	gatewayEnds := strings.Split(gatewayName, ":") | ||||
| 	if len(gatewayEnds) != 2 { | ||||
| 		log.ZError(ctx, "msggateway RpcRegisterName is error:config.RpcRegisterName.OpenImMessageGatewayName", errors.New("config error")) | ||||
| 	} else { | ||||
| 		port, _ = strconv.Atoi(gatewayEnds[1]) | ||||
| func (k *KubernetesConnManager) initializeConns(serviceName string) error { | ||||
| 	port, err := k.getServicePort(serviceName) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	podInfo := strings.Split(selfPodName, "-") | ||||
| 	instance = podInfo[0] | ||||
| 	count := len(podInfo) | ||||
| 	statefuleIndex, _ = strconv.Atoi(podInfo[count-1]) | ||||
| 	host := fmt.Sprintf("%s-openim-msggateway-%d.%s-openim-msggateway-headless.%s.svc.cluster.local:%d", instance, statefuleIndex, instance, ns, port) | ||||
| 	return host | ||||
| 
 | ||||
| 	endpoints, err := k.clientset.CoreV1().Endpoints(k.namespace).Get(context.Background(), serviceName, metav1.GetOptions{}) | ||||
| 	if err != nil { | ||||
| 		return fmt.Errorf("failed to get endpoints for service %s: %v", serviceName, err) | ||||
| 	} | ||||
| 
 | ||||
| 	var conns []*grpc.ClientConn | ||||
| 	for _, subset := range endpoints.Subsets { | ||||
| 		for _, address := range subset.Addresses { | ||||
| 			target := fmt.Sprintf("%s:%d", address.IP, port) | ||||
| 			conn, err := grpc.Dial(target, grpc.WithTransportCredentials(insecure.NewCredentials())) | ||||
| 			if err != nil { | ||||
| 				return fmt.Errorf("failed to dial endpoint %s: %v", target, err) | ||||
| 			} | ||||
| 			conns = append(conns, conn) | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	k.mu.Lock() | ||||
| 	defer k.mu.Unlock() | ||||
| 	k.connMap[serviceName] = conns | ||||
| 
 | ||||
| 	// go k.watchEndpoints(serviceName) | ||||
| 
 | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| // like openimserver-openim-msggateway-0.openimserver-openim-msggateway-headless.openim-lin.svc.cluster.local:88. | ||||
| // Replica set in kubernetes environment | ||||
| func getMsgGatewayHost(ctx context.Context, gatewayName string) []string { | ||||
| 	port := 88 | ||||
| 	instance := "openimserver" | ||||
| 	selfPodName := os.Getenv("MY_POD_NAME") | ||||
| 	replicas := os.Getenv("MY_MSGGATEWAY_REPLICACOUNT") | ||||
| 	ns := os.Getenv("MY_POD_NAMESPACE") | ||||
| 	gatewayEnds := strings.Split(gatewayName, ":") | ||||
| 	if len(gatewayEnds) != 2 { | ||||
| 		log.ZError(ctx, "msggateway RpcRegisterName is error:config.RpcRegisterName.OpenImMessageGatewayName", errors.New("config error")) | ||||
| 	} else { | ||||
| 		port, _ = strconv.Atoi(gatewayEnds[1]) | ||||
| // GetConns returns gRPC client connections for a given Kubernetes service name. | ||||
| func (k *KubernetesConnManager) GetConns(ctx context.Context, serviceName string, opts ...grpc.DialOption) ([]*grpc.ClientConn, error) { | ||||
| 	k.mu.RLock() | ||||
| 	conns, exists := k.connMap[serviceName] | ||||
| 	defer k.mu.RUnlock() | ||||
| 
 | ||||
| 	if exists { | ||||
| 		return conns, nil | ||||
| 	} | ||||
| 	nReplicas, _ := strconv.Atoi(replicas) | ||||
| 	podInfo := strings.Split(selfPodName, "-") | ||||
| 	instance = podInfo[0] | ||||
| 	var ret []string | ||||
| 	for i := 0; i < nReplicas; i++ { | ||||
| 		host := fmt.Sprintf("%s-openim-msggateway-%d.%s-openim-msggateway-headless.%s.svc.cluster.local:%d", instance, i, instance, ns, port) | ||||
| 		ret = append(ret, host) | ||||
| 
 | ||||
| 	k.mu.Lock() | ||||
| 	defer k.mu.Unlock() | ||||
| 
 | ||||
| 	// Check if another goroutine has already initialized the connections when we released the read lock | ||||
| 	conns, exists = k.connMap[serviceName] | ||||
| 	if exists { | ||||
| 		return conns, nil | ||||
| 	} | ||||
| 	log.ZDebug(ctx, "getMsgGatewayHost", "instance", instance, "selfPodName", selfPodName, "replicas", replicas, "ns", ns, "ret", ret) | ||||
| 	return ret | ||||
| 
 | ||||
| 	if err := k.initializeConns(serviceName); err != nil { | ||||
| 		return nil, fmt.Errorf("failed to initialize connections for service %s: %v", serviceName, err) | ||||
| 	} | ||||
| 
 | ||||
| 	return k.connMap[serviceName], nil | ||||
| } | ||||
| 
 | ||||
| // GetConns returns the gRPC client connections to the specified service. | ||||
| func (cli *K8sDR) GetConns(ctx context.Context, serviceName string, opts ...grpc.DialOption) ([]*grpc.ClientConn, error) { | ||||
| 
 | ||||
| 	// This conditional checks if the serviceName is not the OpenImMessageGatewayName. | ||||
| 	// It seems to handle a special case for the OpenImMessageGateway. | ||||
| 	if serviceName != cli.gatewayName { | ||||
| 		// DialContext creates a client connection to the given target (serviceName) using the specified context. | ||||
| 		// 'cli.options' are likely default or common options for all connections in this struct. | ||||
| 		// 'opts...' allows for additional gRPC dial options to be passed and used. | ||||
| 		conn, err := grpc.DialContext(ctx, serviceName, append(cli.options, opts...)...) | ||||
| 
 | ||||
| 		// The function returns a slice of client connections with the new connection, or an error if occurred. | ||||
| 		return []*grpc.ClientConn{conn}, err | ||||
| 	} else { | ||||
| 		// This block is executed if the serviceName is OpenImMessageGatewayName. | ||||
| 		// 'ret' will accumulate the connections to return. | ||||
| 		var ret []*grpc.ClientConn | ||||
| 
 | ||||
| 		// getMsgGatewayHost presumably retrieves hosts for the message gateway service. | ||||
| 		// The context is passed, likely for cancellation and timeout control. | ||||
| 		gatewayHosts := getMsgGatewayHost(ctx, cli.gatewayName) | ||||
| 
 | ||||
| 		// Iterating over the retrieved gateway hosts. | ||||
| 		for _, host := range gatewayHosts { | ||||
| 			// Establishes a connection to each host. | ||||
| 			// Again, appending cli.options with any additional opts provided. | ||||
| 			conn, err := grpc.DialContext(ctx, host, append(cli.options, opts...)...) | ||||
| 
 | ||||
| 			// If there's an error while dialing any host, the function returns immediately with the error. | ||||
| // GetConn returns a single gRPC client connection for a given Kubernetes service name. | ||||
| func (k *KubernetesConnManager) GetConn(ctx context.Context, serviceName string, opts ...grpc.DialOption) (*grpc.ClientConn, error) { | ||||
| 	port, err := k.getServicePort(serviceName) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 			} else { | ||||
| 				// If the connection is successful, it is added to the 'ret' slice. | ||||
| 				ret = append(ret, conn) | ||||
| 			} | ||||
| 		} | ||||
| 		// After all hosts are processed, the slice of connections is returned. | ||||
| 		return ret, nil | ||||
| 	} | ||||
| 
 | ||||
| 	fmt.Println("SVC port:", port) | ||||
| 
 | ||||
| 	target := fmt.Sprintf("%s.%s.svc.cluster.local:%d", serviceName, k.namespace, port) | ||||
| 
 | ||||
| 	fmt.Println("SVC target:", target) | ||||
| 
 | ||||
| 	return grpc.DialContext( | ||||
| 		ctx, | ||||
| 		target, | ||||
| 		append([]grpc.DialOption{grpc.WithTransportCredentials(insecure.NewCredentials())}, k.dialOptions...)..., | ||||
| 	) | ||||
| } | ||||
| 
 | ||||
| func (cli *K8sDR) GetConn(ctx context.Context, serviceName string, opts ...grpc.DialOption) (*grpc.ClientConn, error) { | ||||
| 
 | ||||
| 	return grpc.DialContext(ctx, serviceName, append(cli.options, opts...)...) | ||||
| // GetSelfConnTarget returns the connection target for the current service. | ||||
| func (k *KubernetesConnManager) GetSelfConnTarget() string { | ||||
| 	return k.selfTarget | ||||
| } | ||||
| 
 | ||||
| func (cli *K8sDR) GetSelfConnTarget() string { | ||||
| 
 | ||||
| 	return cli.rpcRegisterAddr | ||||
| // AddOption appends gRPC dial options to the existing options. | ||||
| func (k *KubernetesConnManager) AddOption(opts ...grpc.DialOption) { | ||||
| 	k.mu.Lock() | ||||
| 	defer k.mu.Unlock() | ||||
| 	k.dialOptions = append(k.dialOptions, opts...) | ||||
| } | ||||
| 
 | ||||
| func (cli *K8sDR) AddOption(opts ...grpc.DialOption) { | ||||
| 	cli.options = append(cli.options, opts...) | ||||
| } | ||||
| 
 | ||||
| func (cli *K8sDR) CloseConn(conn *grpc.ClientConn) { | ||||
| // CloseConn closes a given gRPC client connection. | ||||
| func (k *KubernetesConnManager) CloseConn(conn *grpc.ClientConn) { | ||||
| 	conn.Close() | ||||
| } | ||||
| 
 | ||||
| // do not use this method for call rpc. | ||||
| func (cli *K8sDR) GetClientLocalConns() map[string][]*grpc.ClientConn { | ||||
| 	log.ZError(context.Background(), "should not call this function!", nil) | ||||
| // Close closes all gRPC connections managed by KubernetesConnManager. | ||||
| func (k *KubernetesConnManager) Close() { | ||||
| 	k.mu.Lock() | ||||
| 	defer k.mu.Unlock() | ||||
| 	for _, conns := range k.connMap { | ||||
| 		for _, conn := range conns { | ||||
| 			_ = conn.Close() | ||||
| 		} | ||||
| 	} | ||||
| 	k.connMap = make(map[string][]*grpc.ClientConn) | ||||
| } | ||||
| 
 | ||||
| func (k *KubernetesConnManager) Register(serviceName, host string, port int, opts ...grpc.DialOption) error { | ||||
| 	return nil | ||||
| } | ||||
| func (k *KubernetesConnManager) UnRegister() error { | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func (cli *K8sDR) Close() { | ||||
| 
 | ||||
| func (k *KubernetesConnManager) GetUserIdHashGatewayHost(ctx context.Context, userId string) (string, error) { | ||||
| 	return "", nil | ||||
| } | ||||
| 
 | ||||
| func (k *KubernetesConnManager) getServicePort(serviceName string) (int32, error) { | ||||
| 	svc, err := k.clientset.CoreV1().Services(k.namespace).Get(context.Background(), serviceName, metav1.GetOptions{}) | ||||
| 	if err != nil { | ||||
| 		fmt.Print("namespace:", k.namespace) | ||||
| 		return 0, fmt.Errorf("failed to get service %s: %v", serviceName, err) | ||||
| 	} | ||||
| 
 | ||||
| 	if len(svc.Spec.Ports) == 0 { | ||||
| 		return 0, fmt.Errorf("service %s has no ports defined", serviceName) | ||||
| 	} | ||||
| 
 | ||||
| 	return svc.Spec.Ports[0].Port, nil | ||||
| } | ||||
| 
 | ||||
| // watchEndpoints listens for changes in Pod resources. | ||||
| func (k *KubernetesConnManager) watchEndpoints() { | ||||
| 	informerFactory := informers.NewSharedInformerFactory(k.clientset, time.Minute*10) | ||||
| 	informer := informerFactory.Core().V1().Pods().Informer() | ||||
| 
 | ||||
| 	// Watch for Pod changes (add, update, delete) | ||||
| 	informer.AddEventHandler(cache.ResourceEventHandlerFuncs{ | ||||
| 		AddFunc: func(obj interface{}) { | ||||
| 			k.handleEndpointChange(obj) | ||||
| 		}, | ||||
| 		UpdateFunc: func(oldObj, newObj interface{}) { | ||||
| 			k.handleEndpointChange(newObj) | ||||
| 		}, | ||||
| 		DeleteFunc: func(obj interface{}) { | ||||
| 			k.handleEndpointChange(obj) | ||||
| 		}, | ||||
| 	}) | ||||
| 
 | ||||
| 	informerFactory.Start(context.Background().Done()) | ||||
| 	<-context.Background().Done() // Block forever | ||||
| } | ||||
| 
 | ||||
| func (k *KubernetesConnManager) handleEndpointChange(obj interface{}) { | ||||
| 	endpoint, ok := obj.(*v1.Endpoints) | ||||
| 	if !ok { | ||||
| 		return | ||||
| 	} | ||||
| 	serviceName := endpoint.Name | ||||
| 	if err := k.initializeConns(serviceName); err != nil { | ||||
| 		fmt.Printf("Error initializing connections for %s: %v\n", serviceName, err) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // ================= | ||||
| 
 | ||||
| // initEndpoints initializes connections by fetching all available endpoints in the specified namespace. | ||||
| 
 | ||||
| // func (k *KubernetesConnManager) initEndpoints() error { | ||||
| // 	k.mu.Lock() | ||||
| // 	defer k.mu.Unlock() | ||||
| 
 | ||||
| // 	pods, err := k.clientset.CoreV1().Pods(k.namespace).List(context.TODO(), metav1.ListOptions{}) | ||||
| // 	if err != nil { | ||||
| // 		return fmt.Errorf("failed to list pods: %v", err) | ||||
| // 	} | ||||
| 
 | ||||
| // 	for _, pod := range pods.Items { | ||||
| // 		if pod.Status.Phase == v1.PodRunning { | ||||
| // 			target := fmt.Sprintf("%s:%d", address.IP, port) | ||||
| // 			conn, err := grpc.Dial(target, grpc.WithTransportCredentials(insecure.NewCredentials())) | ||||
| // 			conn, err := k.createGRPCConnection(pod) | ||||
| // 			if err != nil { | ||||
| // 				return fmt.Errorf("failed to create GRPC connection for pod %s: %v", pod.Name, err) | ||||
| // 			} | ||||
| // 			k.connMap[pod.Name] = append(k.connMap[pod.Name], conn) | ||||
| // 		} | ||||
| // 	} | ||||
| 
 | ||||
| // 	return nil | ||||
| // } | ||||
| 
 | ||||
| // ----- | ||||
| 
 | ||||
| // func (k *KubernetesConnManager) watchEndpoints1(serviceName string) { | ||||
| // 	// watch for changes to the service's endpoints | ||||
| // 	informerFactory := informers.NewSharedInformerFactory(k.clientset, time.Minute) | ||||
| // 	endpointsInformer := informerFactory.Core().V1().Endpoints().Informer() | ||||
| 
 | ||||
| // 	endpointsInformer.AddEventHandler(cache.ResourceEventHandlerFuncs{ | ||||
| // 		AddFunc: func(obj interface{}) { | ||||
| // 			eps := obj.(*v1.Endpoints) | ||||
| // 			if eps.Name == serviceName { | ||||
| // 				k.initializeConns(serviceName) | ||||
| // 			} | ||||
| // 		}, | ||||
| // 		UpdateFunc: func(oldObj, newObj interface{}) { | ||||
| // 			eps := newObj.(*v1.Endpoints) | ||||
| // 			if eps.Name == serviceName { | ||||
| // 				k.initializeConns(serviceName) | ||||
| // 			} | ||||
| // 		}, | ||||
| // 		DeleteFunc: func(obj interface{}) { | ||||
| // 			eps := obj.(*v1.Endpoints) | ||||
| // 			if eps.Name == serviceName { | ||||
| // 				k.mu.Lock() | ||||
| // 				defer k.mu.Unlock() | ||||
| // 				for _, conn := range k.connMap[serviceName] { | ||||
| // 					_ = conn.Close() | ||||
| // 				} | ||||
| // 				delete(k.connMap, serviceName) | ||||
| // 			} | ||||
| // 		}, | ||||
| // 	}) | ||||
| 
 | ||||
| // 	informerFactory.Start(wait.NeverStop) | ||||
| // 	informerFactory.WaitForCacheSync(wait.NeverStop) | ||||
| // } | ||||
|  | ||||
| @ -17,9 +17,6 @@ package startrpc | ||||
| import ( | ||||
| 	"context" | ||||
| 	"fmt" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	"google.golang.org/grpc/status" | ||||
| 	"net" | ||||
| 	"net/http" | ||||
| 	"os" | ||||
| @ -27,7 +24,13 @@ import ( | ||||
| 	"syscall" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/internal/tools/addr" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	"github.com/openimsdk/tools/utils/runtimeenv" | ||||
| 	"google.golang.org/grpc/status" | ||||
| 
 | ||||
| 	"strconv" | ||||
| 
 | ||||
| 	kdisc "github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/prommetrics" | ||||
| 	"github.com/openimsdk/tools/discovery" | ||||
| @ -37,14 +40,65 @@ import ( | ||||
| 	"github.com/openimsdk/tools/utils/network" | ||||
| 	"google.golang.org/grpc" | ||||
| 	"google.golang.org/grpc/credentials/insecure" | ||||
| 	"strconv" | ||||
| ) | ||||
| 
 | ||||
| // Start rpc server. | ||||
| func Start[T any](ctx context.Context, discovery *config.Discovery, prometheusConfig *config.Prometheus, listenIP string, | ||||
| 	index int, rpcRegisterName string, share *config.Share, config T, rpcFn func(ctx context.Context, | ||||
| func Start[T any](ctx context.Context, discovery *config.Discovery, prometheusConfig *config.Prometheus, listenIP, | ||||
| 	registerIP string, autoSetPorts bool, rpcPorts []int, index int, rpcRegisterName string, share *config.Share, config T, rpcFn func(ctx context.Context, | ||||
| 	config T, client discovery.SvcDiscoveryRegistry, server *grpc.Server) error, options ...grpc.ServerOption) error { | ||||
| 
 | ||||
| 	var ( | ||||
| 		rpcTcpAddr string | ||||
| 		netDone    = make(chan struct{}, 2) | ||||
| 		netErr     error | ||||
| 	) | ||||
| 
 | ||||
| 	runTimeEnv := runtimeenv.PrintRuntimeEnvironment() | ||||
| 
 | ||||
| 	if !autoSetPorts { | ||||
| 		rpcPort, err := datautil.GetElemByIndex(rpcPorts, index) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		rpcTcpAddr = net.JoinHostPort(network.GetListenIP(listenIP), strconv.Itoa(rpcPort)) | ||||
| 	} else { | ||||
| 		rpcTcpAddr = net.JoinHostPort(network.GetListenIP(listenIP), "0") | ||||
| 	} | ||||
| 
 | ||||
| 	// var reg *prometheus.Registry | ||||
| 	// var metric *grpcprometheus.ServerMetrics | ||||
| 	if prometheusConfig.Enable { | ||||
| 		// cusMetrics := prommetrics.GetGrpcCusMetrics(rpcRegisterName, share) | ||||
| 		// reg, metric, _ = prommetrics.NewGrpcPromObj(cusMetrics) | ||||
| 		// options = append(options, mw.GrpcServer(), grpc.StreamInterceptor(metric.StreamServerInterceptor()), | ||||
| 		//	grpc.UnaryInterceptor(metric.UnaryServerInterceptor())) | ||||
| 		options = append( | ||||
| 			options, mw.GrpcServer(), | ||||
| 			prommetricsUnaryInterceptor(rpcRegisterName), | ||||
| 			prommetricsStreamInterceptor(rpcRegisterName), | ||||
| 		) | ||||
| 		prometheusPort, err := datautil.GetElemByIndex(prometheusConfig.Ports, index) | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 		cs := prommetrics.GetGrpcCusMetrics(rpcRegisterName, discovery) | ||||
| 		go func() { | ||||
| 			if err := prommetrics.RpcInit(cs, prometheusPort); err != nil && !errors.Is(err, http.ErrServerClosed) { | ||||
| 				netErr = errs.WrapMsg(err, fmt.Sprintf("rpc %s prometheus start err: %d", rpcRegisterName, prometheusPort)) | ||||
| 				netDone <- struct{}{} | ||||
| 			} | ||||
| 			// metric.InitializeMetrics(srv) | ||||
| 			// Create a HTTP server for prometheus. | ||||
| 			// httpServer = &http.Server{Handler: promhttp.HandlerFor(reg, promhttp.HandlerOpts{}), Addr: fmt.Sprintf("0.0.0.0:%d", prometheusPort)} | ||||
| 			// if err := httpServer.ListenAndServe(); err != nil && err != http.ErrServerClosed { | ||||
| 			//	netErr = errs.WrapMsg(err, "prometheus start err", httpServer.Addr) | ||||
| 			//	netDone <- struct{}{} | ||||
| 			// } | ||||
| 		}() | ||||
| 	} else { | ||||
| 		options = append(options, mw.GrpcServer()) | ||||
| 	} | ||||
| 
 | ||||
| 	rpcTcpAddr := net.JoinHostPort(network.GetListenIP(listenIP), "0") | ||||
| 	listener, err := net.Listen( | ||||
| 		"tcp", | ||||
| @ -58,11 +112,11 @@ func Start[T any](ctx context.Context, discovery *config.Discovery, prometheusCo | ||||
| 	host, _ := addr.Extract(h) | ||||
| 	port, _ := strconv.Atoi(portStr) | ||||
| 
 | ||||
| 	log.CInfo(ctx, "RPC server is initializing", "rpcRegisterName", rpcRegisterName, "rpcPort", portStr, | ||||
| 	log.CInfo(ctx, "RPC server is initializing", "runTimeEnv", runTimeEnv, "rpcRegisterName", rpcRegisterName, "rpcPort", portStr, | ||||
| 		"prometheusPorts", prometheusConfig.Ports) | ||||
| 
 | ||||
| 	defer listener.Close() | ||||
| 	client, err := kdisc.NewDiscoveryRegister(discovery, share) | ||||
| 	client, err := kdisc.NewDiscoveryRegister(discovery, runTimeEnv) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
|  | ||||
| @ -33,6 +33,7 @@ import ( | ||||
| 	"github.com/openimsdk/tools/mq/kafka" | ||||
| 	"github.com/openimsdk/tools/s3/minio" | ||||
| 	"github.com/openimsdk/tools/system/program" | ||||
| 	"github.com/openimsdk/tools/utils/runtimeenv" | ||||
| ) | ||||
| 
 | ||||
| const maxRetry = 180 | ||||
| @ -78,35 +79,37 @@ func initConfig(configDir string) (*config.Mongo, *config.Redis, *config.Kafka, | ||||
| 		discovery   = &config.Discovery{} | ||||
| 		thirdConfig = &config.Third{} | ||||
| 	) | ||||
| 	err := config.LoadConfig(filepath.Join(configDir, cmd.MongodbConfigFileName), cmd.ConfigEnvPrefixMap[cmd.MongodbConfigFileName], mongoConfig) | ||||
| 	runtimeEnv := runtimeenv.PrintRuntimeEnvironment() | ||||
| 
 | ||||
| 	err := config.Load(configDir, cmd.MongodbConfigFileName, cmd.ConfigEnvPrefixMap[cmd.MongodbConfigFileName], runtimeEnv, mongoConfig) | ||||
| 	if err != nil { | ||||
| 		return nil, nil, nil, nil, nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	err = config.LoadConfig(filepath.Join(configDir, cmd.RedisConfigFileName), cmd.ConfigEnvPrefixMap[cmd.RedisConfigFileName], redisConfig) | ||||
| 	err = config.Load(configDir, cmd.RedisConfigFileName, cmd.ConfigEnvPrefixMap[cmd.RedisConfigFileName], runtimeEnv, redisConfig) | ||||
| 	if err != nil { | ||||
| 		return nil, nil, nil, nil, nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	err = config.LoadConfig(filepath.Join(configDir, cmd.KafkaConfigFileName), cmd.ConfigEnvPrefixMap[cmd.KafkaConfigFileName], kafkaConfig) | ||||
| 	err = config.Load(configDir, cmd.KafkaConfigFileName, cmd.ConfigEnvPrefixMap[cmd.KafkaConfigFileName], runtimeEnv, kafkaConfig) | ||||
| 	if err != nil { | ||||
| 		return nil, nil, nil, nil, nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	err = config.LoadConfig(filepath.Join(configDir, cmd.OpenIMRPCThirdCfgFileName), cmd.ConfigEnvPrefixMap[cmd.OpenIMRPCThirdCfgFileName], thirdConfig) | ||||
| 	err = config.Load(configDir, cmd.OpenIMRPCThirdCfgFileName, cmd.ConfigEnvPrefixMap[cmd.OpenIMRPCThirdCfgFileName], runtimeEnv, thirdConfig) | ||||
| 	if err != nil { | ||||
| 		return nil, nil, nil, nil, nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	if thirdConfig.Object.Enable == "minio" { | ||||
| 		err = config.LoadConfig(filepath.Join(configDir, cmd.MinioConfigFileName), cmd.ConfigEnvPrefixMap[cmd.MinioConfigFileName], minioConfig) | ||||
| 		err = config.Load(configDir, cmd.MinioConfigFileName, cmd.ConfigEnvPrefixMap[cmd.MinioConfigFileName], runtimeEnv, minioConfig) | ||||
| 		if err != nil { | ||||
| 			return nil, nil, nil, nil, nil, err | ||||
| 		} | ||||
| 	} else { | ||||
| 		minioConfig = nil | ||||
| 	} | ||||
| 	err = config.LoadConfig(filepath.Join(configDir, cmd.DiscoveryConfigFilename), cmd.ConfigEnvPrefixMap[cmd.DiscoveryConfigFilename], discovery) | ||||
| 	err = config.Load(configDir, cmd.DiscoveryConfigFilename, cmd.ConfigEnvPrefixMap[cmd.DiscoveryConfigFilename], runtimeEnv, discovery) | ||||
| 	if err != nil { | ||||
| 		return nil, nil, nil, nil, nil, err | ||||
| 	} | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user