mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 21:22:16 +08:00 
			
		
		
		
	Merge branch 'main' of github.com:openimsdk/open-im-server into build/k8s
This commit is contained in:
		
						commit
						1c5cba64bd
					
				
							
								
								
									
										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 | ||||||
| @ -1,8 +1,6 @@ | |||||||
| # Use Go 1.22 Alpine as the base image for building the application | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| FROM golang:1.22-alpine AS builder | FROM golang:1.22-alpine AS builder | ||||||
| 
 | 
 | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| # Define the base directory for the application as an environment variable | # Define the base directory for the application as an environment variable | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| @ -10,27 +8,20 @@ ENV SERVER_DIR=/openim-server | |||||||
| WORKDIR $SERVER_DIR | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set the Go proxy to improve dependency resolution speed | # Set the Go proxy to improve dependency resolution speed | ||||||
| ENV GO111MODULE=$GO111MODULE | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| ENV GOPROXY=https://goproxy.io,direct |  | ||||||
| 
 | 
 | ||||||
| # Copy all files from the current directory into the container | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN go mod download | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| # Install Mage to use for building the application | RUN go build -o _output/openim-api ./cmd/openim-api | ||||||
| RUN go install github.com/magefile/mage@v1.15.0 |  | ||||||
| 
 | 
 | ||||||
| ENV BINS=openim-api | # Using Alpine Linux for the final image | ||||||
| 
 | FROM alpine:latest | ||||||
| # Optionally build your application if needed |  | ||||||
| RUN mage build ${BINS} check-free-memory seq || true |  | ||||||
| 
 |  | ||||||
| # Using Alpine Linux with Go environment for the final image |  | ||||||
| FROM golang:1.22-alpine |  | ||||||
| 
 | 
 | ||||||
| # Install necessary packages, such as bash | # Install necessary packages, such as bash | ||||||
| RUN apk add bash | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| # Set the environment and work directory | # Set the environment and work directory | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| @ -40,21 +31,6 @@ WORKDIR $SERVER_DIR | |||||||
| # Copy the compiled binaries and mage from the builder image to the final image | # 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/_output $SERVER_DIR/_output | ||||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | 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  openim-api: 1 \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 | # Set the command to run when the container starts | ||||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ENTRYPOINT ["sh", "-c", "_output/openim-api"] | ||||||
|  | |||||||
| @ -1,8 +1,5 @@ | |||||||
| # Use Go 1.22 Alpine as the base image for building the application | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| FROM golang:1.22-alpine AS builder | FROM golang:1.22-alpine AS builder | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| # Define the base directory for the application as an environment variable | # Define the base directory for the application as an environment variable | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| @ -10,27 +7,24 @@ ENV SERVER_DIR=/openim-server | |||||||
| WORKDIR $SERVER_DIR | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set the Go proxy to improve dependency resolution speed | # Set the Go proxy to improve dependency resolution speed | ||||||
| ENV GO111MODULE=$GO111MODULE | 
 | ||||||
| ENV GOPROXY=https://goproxy.io,direct | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 | 
 | ||||||
| # Copy all files from the current directory into the container | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN go mod download | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| # Install Mage to use for building the application |  | ||||||
| RUN go install github.com/magefile/mage@v1.15.0 |  | ||||||
| 
 | 
 | ||||||
| ENV BINS=openim-crontask |  | ||||||
| 
 | 
 | ||||||
| # Optionally build your application if needed | RUN go build -o _output/openim-crontask ./cmd/openim-crontask | ||||||
| RUN mage build ${BINS} check-free-memory seq || true |  | ||||||
| 
 | 
 | ||||||
| # Using Alpine Linux with Go environment for the final image | 
 | ||||||
| FROM golang:1.22-alpine | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
| 
 | 
 | ||||||
| # Install necessary packages, such as bash | # Install necessary packages, such as bash | ||||||
| RUN apk add bash | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| # Set the environment and work directory | # Set the environment and work directory | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| @ -39,22 +33,7 @@ WORKDIR $SERVER_DIR | |||||||
| 
 | 
 | ||||||
| # Copy the compiled binaries and mage from the builder image to the final image | # 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/_output $SERVER_DIR/_output | ||||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | # 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  openim-crontask: 1 \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 | # Set the command to run when the container starts | ||||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ENTRYPOINT ["sh", "-c", "_output/openim-crontask"] | ||||||
|  | |||||||
| @ -1,8 +1,5 @@ | |||||||
| # Use Go 1.22 Alpine as the base image for building the application | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| FROM golang:1.22-alpine AS builder | FROM golang:1.22-alpine AS builder | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| # Define the base directory for the application as an environment variable | # Define the base directory for the application as an environment variable | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| @ -10,27 +7,24 @@ ENV SERVER_DIR=/openim-server | |||||||
| WORKDIR $SERVER_DIR | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set the Go proxy to improve dependency resolution speed | # Set the Go proxy to improve dependency resolution speed | ||||||
| ENV GO111MODULE=$GO111MODULE | 
 | ||||||
| ENV GOPROXY=https://goproxy.io,direct | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 | 
 | ||||||
| # Copy all files from the current directory into the container | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN go mod download | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| # Install Mage to use for building the application |  | ||||||
| RUN go install github.com/magefile/mage@v1.15.0 |  | ||||||
| 
 | 
 | ||||||
| ENV BINS=openim-msggateway |  | ||||||
| 
 | 
 | ||||||
| # Optionally build your application if needed | RUN go build -o _output/openim-msggateway ./cmd/openim-msggateway | ||||||
| RUN mage build ${BINS} check-free-memory seq || true |  | ||||||
| 
 | 
 | ||||||
| # Using Alpine Linux with Go environment for the final image | 
 | ||||||
| FROM golang:1.22-alpine | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
| 
 | 
 | ||||||
| # Install necessary packages, such as bash | # Install necessary packages, such as bash | ||||||
| RUN apk add bash | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| # Set the environment and work directory | # Set the environment and work directory | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| @ -39,22 +33,7 @@ WORKDIR $SERVER_DIR | |||||||
| 
 | 
 | ||||||
| # Copy the compiled binaries and mage from the builder image to the final image | # 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/_output $SERVER_DIR/_output | ||||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | # 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  openim-msggateway: 1 \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 | # Set the command to run when the container starts | ||||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ENTRYPOINT ["sh", "-c", "_output/openim-msggateway"] | ||||||
|  | |||||||
| @ -1,8 +1,5 @@ | |||||||
| # Use Go 1.22 Alpine as the base image for building the application | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| FROM golang:1.22-alpine AS builder | FROM golang:1.22-alpine AS builder | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| # Define the base directory for the application as an environment variable | # Define the base directory for the application as an environment variable | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| @ -10,27 +7,24 @@ ENV SERVER_DIR=/openim-server | |||||||
| WORKDIR $SERVER_DIR | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set the Go proxy to improve dependency resolution speed | # Set the Go proxy to improve dependency resolution speed | ||||||
| ENV GO111MODULE=$GO111MODULE | 
 | ||||||
| ENV GOPROXY=https://goproxy.io,direct | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 | 
 | ||||||
| # Copy all files from the current directory into the container | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN go mod download | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| # Install Mage to use for building the application |  | ||||||
| RUN go install github.com/magefile/mage@v1.15.0 |  | ||||||
| 
 | 
 | ||||||
| ENV BINS=openim-msgtransfer |  | ||||||
| 
 | 
 | ||||||
| # Optionally build your application if needed | RUN go build -o _output/openim-msgtransfer ./cmd/openim-msgtransfer | ||||||
| RUN mage build ${BINS} check-free-memory seq || true |  | ||||||
| 
 | 
 | ||||||
| # Using Alpine Linux with Go environment for the final image | 
 | ||||||
| FROM golang:1.22-alpine | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
| 
 | 
 | ||||||
| # Install necessary packages, such as bash | # Install necessary packages, such as bash | ||||||
| RUN apk add bash | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| # Set the environment and work directory | # Set the environment and work directory | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| @ -39,22 +33,7 @@ WORKDIR $SERVER_DIR | |||||||
| 
 | 
 | ||||||
| # Copy the compiled binaries and mage from the builder image to the final image | # 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/_output $SERVER_DIR/_output | ||||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | # 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  openim-msgtransfer: 1 \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 | # Set the command to run when the container starts | ||||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ENTRYPOINT ["sh", "-c", "_output/openim-msgtransfer"] | ||||||
|  | |||||||
| @ -1,8 +1,5 @@ | |||||||
| # Use Go 1.22 Alpine as the base image for building the application | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| FROM golang:1.22-alpine AS builder | FROM golang:1.22-alpine AS builder | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| # Define the base directory for the application as an environment variable | # Define the base directory for the application as an environment variable | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| @ -10,27 +7,24 @@ ENV SERVER_DIR=/openim-server | |||||||
| WORKDIR $SERVER_DIR | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set the Go proxy to improve dependency resolution speed | # Set the Go proxy to improve dependency resolution speed | ||||||
| ENV GO111MODULE=$GO111MODULE | 
 | ||||||
| ENV GOPROXY=https://goproxy.io,direct | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 | 
 | ||||||
| # Copy all files from the current directory into the container | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN go mod download | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| # Install Mage to use for building the application |  | ||||||
| RUN go install github.com/magefile/mage@v1.15.0 |  | ||||||
| 
 | 
 | ||||||
| ENV BINS=openim-push |  | ||||||
| 
 | 
 | ||||||
| # Optionally build your application if needed | RUN go build -o _output/openim-push ./cmd/openim-push | ||||||
| RUN mage build ${BINS} check-free-memory seq || true |  | ||||||
| 
 | 
 | ||||||
| # Using Alpine Linux with Go environment for the final image | 
 | ||||||
| FROM golang:1.22-alpine | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
| 
 | 
 | ||||||
| # Install necessary packages, such as bash | # Install necessary packages, such as bash | ||||||
| RUN apk add bash | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| # Set the environment and work directory | # Set the environment and work directory | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| @ -39,22 +33,7 @@ WORKDIR $SERVER_DIR | |||||||
| 
 | 
 | ||||||
| # Copy the compiled binaries and mage from the builder image to the final image | # 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/_output $SERVER_DIR/_output | ||||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | # 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  openim-push: 1 \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 | # Set the command to run when the container starts | ||||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ENTRYPOINT ["sh", "-c", "_output/openim-push"] | ||||||
|  | |||||||
| @ -1,8 +1,5 @@ | |||||||
| # Use Go 1.22 Alpine as the base image for building the application | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| FROM golang:1.22-alpine AS builder | FROM golang:1.22-alpine AS builder | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| # Define the base directory for the application as an environment variable | # Define the base directory for the application as an environment variable | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| @ -10,27 +7,24 @@ ENV SERVER_DIR=/openim-server | |||||||
| WORKDIR $SERVER_DIR | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set the Go proxy to improve dependency resolution speed | # Set the Go proxy to improve dependency resolution speed | ||||||
| ENV GO111MODULE=$GO111MODULE | 
 | ||||||
| ENV GOPROXY=https://goproxy.io,direct | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 | 
 | ||||||
| # Copy all files from the current directory into the container | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN go mod download | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| # Install Mage to use for building the application |  | ||||||
| RUN go install github.com/magefile/mage@v1.15.0 |  | ||||||
| 
 | 
 | ||||||
| ENV BINS=openim-rpc-auth |  | ||||||
| 
 | 
 | ||||||
| # Optionally build your application if needed | RUN go build -o _output/openim-rpc-auth ./cmd/openim-rpc/openim-rpc-auth | ||||||
| RUN mage build ${BINS} check-free-memory seq || true |  | ||||||
| 
 | 
 | ||||||
| # Using Alpine Linux with Go environment for the final image | 
 | ||||||
| FROM golang:1.22-alpine | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
| 
 | 
 | ||||||
| # Install necessary packages, such as bash | # Install necessary packages, such as bash | ||||||
| RUN apk add bash | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| # Set the environment and work directory | # Set the environment and work directory | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| @ -39,22 +33,7 @@ WORKDIR $SERVER_DIR | |||||||
| 
 | 
 | ||||||
| # Copy the compiled binaries and mage from the builder image to the final image | # 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/_output $SERVER_DIR/_output | ||||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | # 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  openim-rpc-auth: 1 \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 | # Set the command to run when the container starts | ||||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-auth"] | ||||||
|  | |||||||
| @ -1,8 +1,5 @@ | |||||||
| # Use Go 1.22 Alpine as the base image for building the application | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| FROM golang:1.22-alpine AS builder | FROM golang:1.22-alpine AS builder | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| # Define the base directory for the application as an environment variable | # Define the base directory for the application as an environment variable | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| @ -10,27 +7,24 @@ ENV SERVER_DIR=/openim-server | |||||||
| WORKDIR $SERVER_DIR | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set the Go proxy to improve dependency resolution speed | # Set the Go proxy to improve dependency resolution speed | ||||||
| ENV GO111MODULE=$GO111MODULE | 
 | ||||||
| ENV GOPROXY=https://goproxy.io,direct | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 | 
 | ||||||
| # Copy all files from the current directory into the container | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN go mod download | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| # Install Mage to use for building the application |  | ||||||
| RUN go install github.com/magefile/mage@v1.15.0 |  | ||||||
| 
 | 
 | ||||||
| ENV BINS=openim-rpc-conversation |  | ||||||
| 
 | 
 | ||||||
| # Optionally build your application if needed | RUN go build -o _output/openim-rpc-conversation ./cmd/openim-rpc/openim-rpc-conversation | ||||||
| RUN mage build ${BINS} check-free-memory seq || true |  | ||||||
| 
 | 
 | ||||||
| # Using Alpine Linux with Go environment for the final image | 
 | ||||||
| FROM golang:1.22-alpine | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
| 
 | 
 | ||||||
| # Install necessary packages, such as bash | # Install necessary packages, such as bash | ||||||
| RUN apk add bash | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| # Set the environment and work directory | # Set the environment and work directory | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| @ -39,22 +33,7 @@ WORKDIR $SERVER_DIR | |||||||
| 
 | 
 | ||||||
| # Copy the compiled binaries and mage from the builder image to the final image | # 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/_output $SERVER_DIR/_output | ||||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | # 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  openim-rpc-conversation: 1 \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 | # Set the command to run when the container starts | ||||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-conversation"] | ||||||
|  | |||||||
| @ -1,8 +1,5 @@ | |||||||
| # Use Go 1.22 Alpine as the base image for building the application | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| FROM golang:1.22-alpine AS builder | FROM golang:1.22-alpine AS builder | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| # Define the base directory for the application as an environment variable | # Define the base directory for the application as an environment variable | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| @ -10,27 +7,24 @@ ENV SERVER_DIR=/openim-server | |||||||
| WORKDIR $SERVER_DIR | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set the Go proxy to improve dependency resolution speed | # Set the Go proxy to improve dependency resolution speed | ||||||
| ENV GO111MODULE=$GO111MODULE | 
 | ||||||
| ENV GOPROXY=https://goproxy.io,direct | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 | 
 | ||||||
| # Copy all files from the current directory into the container | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN go mod download | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| # Install Mage to use for building the application |  | ||||||
| RUN go install github.com/magefile/mage@v1.15.0 |  | ||||||
| 
 | 
 | ||||||
| ENV BINS=openim-rpc-friend |  | ||||||
| 
 | 
 | ||||||
| # Optionally build your application if needed | RUN go build -o _output/openim-rpc-friend ./cmd/openim-rpc/openim-rpc-friend | ||||||
| RUN mage build ${BINS} check-free-memory seq || true |  | ||||||
| 
 | 
 | ||||||
| # Using Alpine Linux with Go environment for the final image | 
 | ||||||
| FROM golang:1.22-alpine | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
| 
 | 
 | ||||||
| # Install necessary packages, such as bash | # Install necessary packages, such as bash | ||||||
| RUN apk add bash | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| # Set the environment and work directory | # Set the environment and work directory | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| @ -39,22 +33,7 @@ WORKDIR $SERVER_DIR | |||||||
| 
 | 
 | ||||||
| # Copy the compiled binaries and mage from the builder image to the final image | # 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/_output $SERVER_DIR/_output | ||||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | # 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  openim-rpc-friend: 1 \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 | # Set the command to run when the container starts | ||||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-friend"] | ||||||
|  | |||||||
| @ -1,8 +1,5 @@ | |||||||
| # Use Go 1.22 Alpine as the base image for building the application | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| FROM golang:1.22-alpine AS builder | FROM golang:1.22-alpine AS builder | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| # Define the base directory for the application as an environment variable | # Define the base directory for the application as an environment variable | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| @ -10,27 +7,24 @@ ENV SERVER_DIR=/openim-server | |||||||
| WORKDIR $SERVER_DIR | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set the Go proxy to improve dependency resolution speed | # Set the Go proxy to improve dependency resolution speed | ||||||
| ENV GO111MODULE=$GO111MODULE | 
 | ||||||
| ENV GOPROXY=https://goproxy.io,direct | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 | 
 | ||||||
| # Copy all files from the current directory into the container | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN go mod download | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| # Install Mage to use for building the application |  | ||||||
| RUN go install github.com/magefile/mage@v1.15.0 |  | ||||||
| 
 | 
 | ||||||
| ENV BINS=openim-rpc-group |  | ||||||
| 
 | 
 | ||||||
| # Optionally build your application if needed | RUN go build -o _output/openim-rpc-group ./cmd/openim-rpc/openim-rpc-group | ||||||
| RUN mage build ${BINS} check-free-memory seq || true |  | ||||||
| 
 | 
 | ||||||
| # Using Alpine Linux with Go environment for the final image | 
 | ||||||
| FROM golang:1.22-alpine | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
| 
 | 
 | ||||||
| # Install necessary packages, such as bash | # Install necessary packages, such as bash | ||||||
| RUN apk add bash | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| # Set the environment and work directory | # Set the environment and work directory | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| @ -39,22 +33,7 @@ WORKDIR $SERVER_DIR | |||||||
| 
 | 
 | ||||||
| # Copy the compiled binaries and mage from the builder image to the final image | # 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/_output $SERVER_DIR/_output | ||||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | # 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  openim-rpc-group: 1 \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 | # Set the command to run when the container starts | ||||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-group"] | ||||||
|  | |||||||
| @ -1,8 +1,5 @@ | |||||||
| # Use Go 1.22 Alpine as the base image for building the application | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| FROM golang:1.22-alpine AS builder | FROM golang:1.22-alpine AS builder | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| # Define the base directory for the application as an environment variable | # Define the base directory for the application as an environment variable | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| @ -10,27 +7,24 @@ ENV SERVER_DIR=/openim-server | |||||||
| WORKDIR $SERVER_DIR | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set the Go proxy to improve dependency resolution speed | # Set the Go proxy to improve dependency resolution speed | ||||||
| ENV GO111MODULE=$GO111MODULE | 
 | ||||||
| ENV GOPROXY=https://goproxy.io,direct | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 | 
 | ||||||
| # Copy all files from the current directory into the container | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN go mod download | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| # Install Mage to use for building the application |  | ||||||
| RUN go install github.com/magefile/mage@v1.15.0 |  | ||||||
| 
 | 
 | ||||||
| ENV BINS=openim-rpc-msg |  | ||||||
| 
 | 
 | ||||||
| # Optionally build your application if needed | RUN go build -o _output/openim-rpc-msg ./cmd/openim-rpc/openim-rpc-msg | ||||||
| RUN mage build ${BINS} check-free-memory seq || true |  | ||||||
| 
 | 
 | ||||||
| # Using Alpine Linux with Go environment for the final image | 
 | ||||||
| FROM golang:1.22-alpine | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
| 
 | 
 | ||||||
| # Install necessary packages, such as bash | # Install necessary packages, such as bash | ||||||
| RUN apk add bash | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| # Set the environment and work directory | # Set the environment and work directory | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| @ -39,22 +33,7 @@ WORKDIR $SERVER_DIR | |||||||
| 
 | 
 | ||||||
| # Copy the compiled binaries and mage from the builder image to the final image | # 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/_output $SERVER_DIR/_output | ||||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | # 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  openim-rpc-msg: 1 \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 | # Set the command to run when the container starts | ||||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-msg"] | ||||||
|  | |||||||
| @ -1,8 +1,5 @@ | |||||||
| # Use Go 1.22 Alpine as the base image for building the application | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| FROM golang:1.22-alpine AS builder | FROM golang:1.22-alpine AS builder | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| # Define the base directory for the application as an environment variable | # Define the base directory for the application as an environment variable | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| @ -10,27 +7,24 @@ ENV SERVER_DIR=/openim-server | |||||||
| WORKDIR $SERVER_DIR | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set the Go proxy to improve dependency resolution speed | # Set the Go proxy to improve dependency resolution speed | ||||||
| ENV GO111MODULE=$GO111MODULE | 
 | ||||||
| ENV GOPROXY=https://goproxy.io,direct | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 | 
 | ||||||
| # Copy all files from the current directory into the container | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN go mod download | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| # Install Mage to use for building the application |  | ||||||
| RUN go install github.com/magefile/mage@v1.15.0 |  | ||||||
| 
 | 
 | ||||||
| ENV BINS=openim-rpc-third |  | ||||||
| 
 | 
 | ||||||
| # Optionally build your application if needed | RUN go build -o _output/openim-rpc-third ./cmd/openim-rpc/openim-rpc-third | ||||||
| RUN mage build ${BINS} check-free-memory seq || true |  | ||||||
| 
 | 
 | ||||||
| # Using Alpine Linux with Go environment for the final image | 
 | ||||||
| FROM golang:1.22-alpine | # Using Alpine Linux for the final image | ||||||
|  | FROM alpine:latest | ||||||
| 
 | 
 | ||||||
| # Install necessary packages, such as bash | # Install necessary packages, such as bash | ||||||
| RUN apk add bash | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| # Set the environment and work directory | # Set the environment and work directory | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| @ -39,22 +33,7 @@ WORKDIR $SERVER_DIR | |||||||
| 
 | 
 | ||||||
| # Copy the compiled binaries and mage from the builder image to the final image | # 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/_output $SERVER_DIR/_output | ||||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | # 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  openim-rpc-third: 1 \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 | # Set the command to run when the container starts | ||||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-third"] | ||||||
|  | |||||||
| @ -1,8 +1,5 @@ | |||||||
| # Use Go 1.22 Alpine as the base image for building the application | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| FROM golang:1.22-alpine AS builder | FROM golang:1.22-alpine AS builder | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| # Define the base directory for the application as an environment variable | # Define the base directory for the application as an environment variable | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| @ -10,27 +7,22 @@ ENV SERVER_DIR=/openim-server | |||||||
| WORKDIR $SERVER_DIR | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set the Go proxy to improve dependency resolution speed | # Set the Go proxy to improve dependency resolution speed | ||||||
| ENV GO111MODULE=$GO111MODULE | 
 | ||||||
| ENV GOPROXY=https://goproxy.io,direct | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 | 
 | ||||||
| # Copy all files from the current directory into the container | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
| 
 | 
 | ||||||
| RUN go mod download | RUN go mod tidy | ||||||
| 
 | 
 | ||||||
| # Install Mage to use for building the application | RUN go build -o _output/openim-rpc-user ./cmd/openim-rpc/openim-rpc-user | ||||||
| RUN go install github.com/magefile/mage@v1.15.0 |  | ||||||
| 
 | 
 | ||||||
| ENV BINS=openim-rpc-user |  | ||||||
| 
 | 
 | ||||||
| # Optionally build your application if needed | # Using Alpine Linux for the final image | ||||||
| RUN mage build ${BINS} check-free-memory seq || true | FROM alpine:latest | ||||||
| 
 |  | ||||||
| # Using Alpine Linux with Go environment for the final image |  | ||||||
| FROM golang:1.22-alpine |  | ||||||
| 
 | 
 | ||||||
| # Install necessary packages, such as bash | # Install necessary packages, such as bash | ||||||
| RUN apk add bash | RUN apk add --no-cache bash | ||||||
| 
 | 
 | ||||||
| # Set the environment and work directory | # Set the environment and work directory | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| @ -39,22 +31,7 @@ WORKDIR $SERVER_DIR | |||||||
| 
 | 
 | ||||||
| # Copy the compiled binaries and mage from the builder image to the final image | # 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/_output $SERVER_DIR/_output | ||||||
| COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config | # 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  openim-rpc-user: 1 \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 | # Set the command to run when the container starts | ||||||
| ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"] | ENTRYPOINT ["sh", "-c", "_output/openim-rpc-user"] | ||||||
|  | |||||||
| @ -18,11 +18,11 @@ | |||||||
| 
 | 
 | ||||||
| # FROM golang:1.20 AS builder | # FROM golang:1.20 AS builder | ||||||
| 
 | 
 | ||||||
| # ARG GO111MODULE=on | #  | ||||||
| 
 | 
 | ||||||
| # WORKDIR /openim/openim-server | # WORKDIR /openim/openim-server | ||||||
| 
 | 
 | ||||||
| # ENV GO111MODULE=$GO111MODULE | #  | ||||||
| # ENV GOPROXY=$GOPROXY | # ENV GOPROXY=$GOPROXY | ||||||
| 
 | 
 | ||||||
| # COPY go.mod go.sum ./ | # COPY go.mod go.sum ./ | ||||||
| @ -50,9 +50,6 @@ | |||||||
| 
 | 
 | ||||||
| # Use Go 1.22 Alpine as the base image for building the application | # Use Go 1.22 Alpine as the base image for building the application | ||||||
| FROM golang:1.22-alpine AS builder | FROM golang:1.22-alpine AS builder | ||||||
| 
 |  | ||||||
| ARG GO111MODULE=on |  | ||||||
| 
 |  | ||||||
| # Define the base directory for the application as an environment variable | # Define the base directory for the application as an environment variable | ||||||
| ENV SERVER_DIR=/openim-server | ENV SERVER_DIR=/openim-server | ||||||
| 
 | 
 | ||||||
| @ -60,8 +57,8 @@ ENV SERVER_DIR=/openim-server | |||||||
| WORKDIR $SERVER_DIR | WORKDIR $SERVER_DIR | ||||||
| 
 | 
 | ||||||
| # Set the Go proxy to improve dependency resolution speed | # Set the Go proxy to improve dependency resolution speed | ||||||
| ENV GO111MODULE=$GO111MODULE | 
 | ||||||
| ENV GOPROXY=https://goproxy.io,direct | #ENV GOPROXY=https://goproxy.io,direct | ||||||
| 
 | 
 | ||||||
| # Copy all files from the current directory into the container | # Copy all files from the current directory into the container | ||||||
| COPY . . | COPY . . | ||||||
|  | |||||||
| @ -5,4 +5,16 @@ etcd: | |||||||
|   username: '' |   username: '' | ||||||
|   password: '' |   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,7 +1,11 @@ | |||||||
| rpc: | rpc: | ||||||
|   # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP |   # The IP address where this RPC service registers itself; if left blank, it defaults to the internal network IP | ||||||
|   registerIP: |   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 |   # 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 ] |   ports: [ 10140, 10141, 10142, 10143, 10144, 10145, 10146, 10147, 10148, 10149, 10150, 10151, 10152, 10153, 10154, 10155 ] | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|  | |||||||
| @ -3,9 +3,14 @@ rpc: | |||||||
|   registerIP: |   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 |   # 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 |   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 |   # 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 ] |   ports: [ 10170, 10171, 10172, 10173, 10174, 10175, 10176, 10177, 10178, 10179, 10180, 10181, 10182, 10183, 10184, 10185 ] | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| prometheus: | prometheus: | ||||||
|   # Enable or disable Prometheus monitoring |   # Enable or disable Prometheus monitoring | ||||||
|   enable: true |   enable: true | ||||||
|  | |||||||
| @ -3,9 +3,14 @@ rpc: | |||||||
|   registerIP:  |   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 |   # 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 |   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 |   # 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 ] |   ports: [ 10200 ] | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| prometheus: | prometheus: | ||||||
|   # Enable or disable Prometheus monitoring |   # Enable or disable Prometheus monitoring | ||||||
|   enable: true |   enable: true | ||||||
|  | |||||||
| @ -3,7 +3,11 @@ rpc: | |||||||
|   registerIP:  |   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 |   # 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 |   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 |   # 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 ] |   ports: [ 10220 ] | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|  | |||||||
| @ -3,7 +3,11 @@ rpc: | |||||||
|   registerIP:  |   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 |   # 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 |   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 |   # 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 ] |   ports: [ 10240 ] | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|  | |||||||
| @ -3,7 +3,11 @@ rpc: | |||||||
|   registerIP: |   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 |   # 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 |   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 |   # 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 ] |   ports: [ 10260 ] | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|  | |||||||
| @ -3,7 +3,11 @@ rpc: | |||||||
|   registerIP:  |   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 |   # 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 |   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 |   # 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 ] |   ports: [ 10280 ] | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|  | |||||||
| @ -3,7 +3,11 @@ rpc: | |||||||
|   registerIP:  |   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 |   # 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 |   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 |   # 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 ] |   ports: [ 10300 ] | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
| @ -31,10 +35,17 @@ object: | |||||||
|     sessionToken:  |     sessionToken:  | ||||||
|     publicRead: false |     publicRead: false | ||||||
|   kodo: |   kodo: | ||||||
|     endpoint: http://s3.cn-south-1.qiniucs.com |     endpoint: https://s3.cn-south-1.qiniucs.com | ||||||
|     bucket: kodo-bucket-test |     bucket: testdemo12313 | ||||||
|     bucketURL: http://kodo-bucket-test-oetobfb.qiniudns.com |     bucketURL: http://so2at6d05.hn-bkt.clouddn.com | ||||||
|     accessKeyID: |     accessKeyID: | ||||||
|     accessKeySecret: |     accessKeySecret: | ||||||
|     sessionToken:  |     sessionToken:  | ||||||
|     publicRead: false |     publicRead: false | ||||||
|  |   aws: | ||||||
|  |     region: ap-southeast-2 | ||||||
|  |     bucket: testdemo832234 | ||||||
|  |     accessKeyID: | ||||||
|  |     secretAccessKey: | ||||||
|  |     sessionToken: | ||||||
|  |     publicRead: false | ||||||
| @ -3,7 +3,11 @@ rpc: | |||||||
|   registerIP:  |   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 |   # 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 |   listenIP: 0.0.0.0 | ||||||
|   # Listening ports; if multiple are configured, multiple instances will be launched, and must be consistent with the number of prometheus.ports |   # 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 ] |   ports: [ 10320 ] | ||||||
| 
 | 
 | ||||||
| prometheus: | prometheus: | ||||||
|  | |||||||
							
								
								
									
										25
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										25
									
								
								go.mod
									
									
									
									
									
								
							| @ -14,8 +14,8 @@ require ( | |||||||
| 	github.com/gorilla/websocket v1.5.1 | 	github.com/gorilla/websocket v1.5.1 | ||||||
| 	github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 | 	github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 | ||||||
| 	github.com/mitchellh/mapstructure v1.5.0 | 	github.com/mitchellh/mapstructure v1.5.0 | ||||||
| 	github.com/openimsdk/protocol v0.0.72-alpha.59 | 	github.com/openimsdk/protocol v0.0.72-alpha.61 | ||||||
| 	github.com/openimsdk/tools v0.0.50-alpha.38 | 	github.com/openimsdk/tools v0.0.50-alpha.45 | ||||||
| 	github.com/pkg/errors v0.9.1 // indirect | 	github.com/pkg/errors v0.9.1 // indirect | ||||||
| 	github.com/prometheus/client_golang v1.18.0 | 	github.com/prometheus/client_golang v1.18.0 | ||||||
| 	github.com/stretchr/testify v1.9.0 | 	github.com/stretchr/testify v1.9.0 | ||||||
| @ -42,10 +42,12 @@ require ( | |||||||
| 	github.com/robfig/cron/v3 v3.0.1 | 	github.com/robfig/cron/v3 v3.0.1 | ||||||
| 	github.com/shirou/gopsutil v3.21.11+incompatible | 	github.com/shirou/gopsutil v3.21.11+incompatible | ||||||
| 	github.com/spf13/viper v1.18.2 | 	github.com/spf13/viper v1.18.2 | ||||||
| 	github.com/stathat/consistent v1.0.0 |  | ||||||
| 	go.uber.org/automaxprocs v1.5.3 | 	go.uber.org/automaxprocs v1.5.3 | ||||||
| 	golang.org/x/exp v0.0.0-20230905200255-921286631fa9 | 	golang.org/x/exp v0.0.0-20230905200255-921286631fa9 | ||||||
| 	golang.org/x/sync v0.8.0 | 	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 ( | require ( | ||||||
| @ -55,9 +57,11 @@ require ( | |||||||
| 	cloud.google.com/go/iam v1.1.7 // indirect | 	cloud.google.com/go/iam v1.1.7 // indirect | ||||||
| 	cloud.google.com/go/longrunning v0.5.5 // indirect | 	cloud.google.com/go/longrunning v0.5.5 // indirect | ||||||
| 	cloud.google.com/go/storage v1.40.0 // indirect | 	cloud.google.com/go/storage v1.40.0 // indirect | ||||||
|  | 	github.com/BurntSushi/toml v1.3.2 // indirect | ||||||
| 	github.com/MicahParks/keyfunc v1.9.0 // indirect | 	github.com/MicahParks/keyfunc v1.9.0 // indirect | ||||||
|  | 	github.com/alex-ant/gomath v0.0.0-20160516115720-89013a210a82 // indirect | ||||||
| 	github.com/aliyun/aliyun-oss-go-sdk v3.0.2+incompatible // indirect | 	github.com/aliyun/aliyun-oss-go-sdk v3.0.2+incompatible // indirect | ||||||
| 	github.com/aws/aws-sdk-go-v2 v1.32.5 // indirect | 	github.com/aws/aws-sdk-go-v2 v1.32.6 // indirect | ||||||
| 	github.com/aws/aws-sdk-go-v2/aws/protocol/eventstream v1.5.1 // indirect | 	github.com/aws/aws-sdk-go-v2/aws/protocol/eventstream v1.5.1 // indirect | ||||||
| 	github.com/aws/aws-sdk-go-v2/config v1.28.5 // indirect | 	github.com/aws/aws-sdk-go-v2/config v1.28.5 // indirect | ||||||
| 	github.com/aws/aws-sdk-go-v2/credentials v1.17.46 // indirect | 	github.com/aws/aws-sdk-go-v2/credentials v1.17.46 // indirect | ||||||
| @ -90,11 +94,14 @@ require ( | |||||||
| 	github.com/eapache/go-resiliency v1.6.0 // indirect | 	github.com/eapache/go-resiliency v1.6.0 // indirect | ||||||
| 	github.com/eapache/go-xerial-snappy v0.0.0-20230731223053-c322873962e3 // indirect | 	github.com/eapache/go-xerial-snappy v0.0.0-20230731223053-c322873962e3 // indirect | ||||||
| 	github.com/eapache/queue v1.1.0 // 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/emicklei/go-restful/v3 v3.11.0 // indirect | ||||||
| 	github.com/felixge/httpsnoop v1.0.4 // indirect | 	github.com/felixge/httpsnoop v1.0.4 // indirect | ||||||
| 	github.com/fsnotify/fsnotify v1.7.0 // indirect | 	github.com/fsnotify/fsnotify v1.7.0 // indirect | ||||||
| 	github.com/fxamacker/cbor/v2 v2.7.0 // indirect | 	github.com/fxamacker/cbor/v2 v2.7.0 // indirect | ||||||
| 	github.com/gabriel-vasile/mimetype v1.4.3 // indirect | 	github.com/gabriel-vasile/mimetype v1.4.3 // indirect | ||||||
|  | 	github.com/gammazero/toposort v0.1.1 // indirect | ||||||
| 	github.com/gin-contrib/sse v0.1.0 // indirect | 	github.com/gin-contrib/sse v0.1.0 // indirect | ||||||
| 	github.com/go-logr/logr v1.4.2 // indirect | 	github.com/go-logr/logr v1.4.2 // indirect | ||||||
| 	github.com/go-logr/stdr v1.2.2 // indirect | 	github.com/go-logr/stdr v1.2.2 // indirect | ||||||
| @ -104,6 +111,7 @@ require ( | |||||||
| 	github.com/go-openapi/swag v0.22.4 // indirect | 	github.com/go-openapi/swag v0.22.4 // indirect | ||||||
| 	github.com/go-playground/universal-translator v0.18.1 // indirect | 	github.com/go-playground/universal-translator v0.18.1 // indirect | ||||||
| 	github.com/go-zookeeper/zk v1.0.3 // indirect | 	github.com/go-zookeeper/zk v1.0.3 // indirect | ||||||
|  | 	github.com/gofrs/flock v0.8.1 // indirect | ||||||
| 	github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect | 	github.com/golang/groupcache v0.0.0-20210331224755-41bb18bfe9da // indirect | ||||||
| 	github.com/golang/protobuf v1.5.4 // indirect | 	github.com/golang/protobuf v1.5.4 // indirect | ||||||
| 	github.com/golang/snappy v0.0.4 // indirect | 	github.com/golang/snappy v0.0.4 // indirect | ||||||
| @ -127,6 +135,7 @@ require ( | |||||||
| 	github.com/jinzhu/copier v0.4.0 // indirect | 	github.com/jinzhu/copier v0.4.0 // indirect | ||||||
| 	github.com/jinzhu/inflection v1.0.0 // indirect | 	github.com/jinzhu/inflection v1.0.0 // indirect | ||||||
| 	github.com/jinzhu/now v1.1.5 // 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/josharian/intern v1.0.0 // indirect | ||||||
| 	github.com/json-iterator/go v1.1.12 // indirect | 	github.com/json-iterator/go v1.1.12 // indirect | ||||||
| 	github.com/kelindar/simd v1.1.2 // indirect | 	github.com/kelindar/simd v1.1.2 // indirect | ||||||
| @ -154,7 +163,7 @@ require ( | |||||||
| 	github.com/prometheus/client_model v0.5.0 // indirect | 	github.com/prometheus/client_model v0.5.0 // indirect | ||||||
| 	github.com/prometheus/common v0.45.0 // indirect | 	github.com/prometheus/common v0.45.0 // indirect | ||||||
| 	github.com/prometheus/procfs v0.12.0 // indirect | 	github.com/prometheus/procfs v0.12.0 // indirect | ||||||
| 	github.com/qiniu/go-sdk/v7 v7.18.2 // indirect | 	github.com/qiniu/go-sdk/v7 v7.25.0 // indirect | ||||||
| 	github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 // indirect | 	github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 // indirect | ||||||
| 	github.com/rs/xid v1.5.0 // indirect | 	github.com/rs/xid v1.5.0 // indirect | ||||||
| 	github.com/sagikazarmark/locafero v0.4.0 // indirect | 	github.com/sagikazarmark/locafero v0.4.0 // indirect | ||||||
| @ -201,16 +210,14 @@ require ( | |||||||
| 	gopkg.in/inf.v0 v0.9.1 // indirect | 	gopkg.in/inf.v0 v0.9.1 // indirect | ||||||
| 	gopkg.in/yaml.v2 v2.4.0 // indirect | 	gopkg.in/yaml.v2 v2.4.0 // indirect | ||||||
| 	gorm.io/gorm v1.25.8 // indirect | 	gorm.io/gorm v1.25.8 // indirect | ||||||
| 	k8s.io/api v0.31.2 // indirect | 	howett.net/plist v0.0.0-20181124034731-591f970eefbb // indirect | ||||||
| 	k8s.io/apimachinery v0.31.2 // indirect |  | ||||||
| 	k8s.io/client-go v0.31.2 // indirect |  | ||||||
| 	k8s.io/klog/v2 v2.130.1 // indirect | 	k8s.io/klog/v2 v2.130.1 // indirect | ||||||
| 	k8s.io/kube-openapi v0.0.0-20240228011516-70dd3763d340 // indirect | 	k8s.io/kube-openapi v0.0.0-20240228011516-70dd3763d340 // indirect | ||||||
| 	k8s.io/utils v0.0.0-20240711033017-18e509b52bc8 // 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/json v0.0.0-20221116044647-bc3834ca7abd // indirect | ||||||
| 	sigs.k8s.io/structured-merge-diff/v4 v4.4.1 // indirect | 	sigs.k8s.io/structured-merge-diff/v4 v4.4.1 // indirect | ||||||
| 	sigs.k8s.io/yaml v1.4.0 // indirect | 	sigs.k8s.io/yaml v1.4.0 // indirect | ||||||
| 	stathat.com/c/consistent v1.0.0 // indirect |  | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| require ( | require ( | ||||||
|  | |||||||
							
								
								
									
										58
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										58
									
								
								go.sum
									
									
									
									
									
								
							| @ -14,15 +14,19 @@ cloud.google.com/go/storage v1.40.0/go.mod h1:Rrj7/hKlG87BLqDJYtwR0fbPld8uJPbQ2u | |||||||
| firebase.google.com/go/v4 v4.14.1 h1:4qiUETaFRWoFGE1XP5VbcEdtPX93Qs+8B/7KvP2825g= | firebase.google.com/go/v4 v4.14.1 h1:4qiUETaFRWoFGE1XP5VbcEdtPX93Qs+8B/7KvP2825g= | ||||||
| firebase.google.com/go/v4 v4.14.1/go.mod h1:fgk2XshgNDEKaioKco+AouiegSI9oTWVqRaBdTTGBoM= | firebase.google.com/go/v4 v4.14.1/go.mod h1:fgk2XshgNDEKaioKco+AouiegSI9oTWVqRaBdTTGBoM= | ||||||
| github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= | github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= | ||||||
|  | github.com/BurntSushi/toml v1.3.2 h1:o7IhLm0Msx3BaB+n3Ag7L8EVlByGnpq14C4YWiu/gL8= | ||||||
|  | github.com/BurntSushi/toml v1.3.2/go.mod h1:CxXYINrC8qIiEnFrOxCa7Jy5BFHlXnUU2pbicEuybxQ= | ||||||
| github.com/IBM/sarama v1.43.0 h1:YFFDn8mMI2QL0wOrG0J2sFoVIAFl7hS9JQi2YZsXtJc= | github.com/IBM/sarama v1.43.0 h1:YFFDn8mMI2QL0wOrG0J2sFoVIAFl7hS9JQi2YZsXtJc= | ||||||
| github.com/IBM/sarama v1.43.0/go.mod h1:zlE6HEbC/SMQ9mhEYaF7nNLYOUyrs0obySKCckWP9BM= | github.com/IBM/sarama v1.43.0/go.mod h1:zlE6HEbC/SMQ9mhEYaF7nNLYOUyrs0obySKCckWP9BM= | ||||||
| github.com/MicahParks/keyfunc v1.9.0 h1:lhKd5xrFHLNOWrDc4Tyb/Q1AJ4LCzQ48GVJyVIID3+o= | github.com/MicahParks/keyfunc v1.9.0 h1:lhKd5xrFHLNOWrDc4Tyb/Q1AJ4LCzQ48GVJyVIID3+o= | ||||||
| github.com/MicahParks/keyfunc v1.9.0/go.mod h1:IdnCilugA0O/99dW+/MkvlyrsX8+L8+x95xuVNtM5jw= | github.com/MicahParks/keyfunc v1.9.0/go.mod h1:IdnCilugA0O/99dW+/MkvlyrsX8+L8+x95xuVNtM5jw= | ||||||
| github.com/QcloudApi/qcloud_sign_golang v0.0.0-20141224014652-e4130a326409/go.mod h1:1pk82RBxDY/JZnPQrtqHlUFfCctgdorsd9M06fMynOM= | github.com/QcloudApi/qcloud_sign_golang v0.0.0-20141224014652-e4130a326409/go.mod h1:1pk82RBxDY/JZnPQrtqHlUFfCctgdorsd9M06fMynOM= | ||||||
|  | github.com/alex-ant/gomath v0.0.0-20160516115720-89013a210a82 h1:7dONQ3WNZ1zy960TmkxJPuwoolZwL7xKtpcM04MBnt4= | ||||||
|  | github.com/alex-ant/gomath v0.0.0-20160516115720-89013a210a82/go.mod h1:nLnM0KdK1CmygvjpDUO6m1TjSsiQtL61juhNsvV/JVI= | ||||||
| github.com/aliyun/aliyun-oss-go-sdk v3.0.2+incompatible h1:8psS8a+wKfiLt1iVDX79F7Y6wUM49Lcha2FMXt4UM8g= | github.com/aliyun/aliyun-oss-go-sdk v3.0.2+incompatible h1:8psS8a+wKfiLt1iVDX79F7Y6wUM49Lcha2FMXt4UM8g= | ||||||
| github.com/aliyun/aliyun-oss-go-sdk v3.0.2+incompatible/go.mod h1:T/Aws4fEfogEE9v+HPhhw+CntffsBHJ8nXQCwKr0/g8= | github.com/aliyun/aliyun-oss-go-sdk v3.0.2+incompatible/go.mod h1:T/Aws4fEfogEE9v+HPhhw+CntffsBHJ8nXQCwKr0/g8= | ||||||
| github.com/aws/aws-sdk-go-v2 v1.32.5 h1:U8vdWJuY7ruAkzaOdD7guwJjD06YSKmnKCJs7s3IkIo= | github.com/aws/aws-sdk-go-v2 v1.32.6 h1:7BokKRgRPuGmKkFMhEg/jSul+tB9VvXhcViILtfG8b4= | ||||||
| github.com/aws/aws-sdk-go-v2 v1.32.5/go.mod h1:P5WJBrYqqbWVaOxgH0X/FYYD47/nooaPOZPlQdmiN2U= | github.com/aws/aws-sdk-go-v2 v1.32.6/go.mod h1:P5WJBrYqqbWVaOxgH0X/FYYD47/nooaPOZPlQdmiN2U= | ||||||
| github.com/aws/aws-sdk-go-v2/aws/protocol/eventstream v1.5.1 h1:ZY3108YtBNq96jNZTICHxN1gSBSbnvIdYwwqnvCV4Mc= | github.com/aws/aws-sdk-go-v2/aws/protocol/eventstream v1.5.1 h1:ZY3108YtBNq96jNZTICHxN1gSBSbnvIdYwwqnvCV4Mc= | ||||||
| github.com/aws/aws-sdk-go-v2/aws/protocol/eventstream v1.5.1/go.mod h1:t8PYl/6LzdAqsU4/9tz28V/kU+asFePvpOMkdul0gEQ= | github.com/aws/aws-sdk-go-v2/aws/protocol/eventstream v1.5.1/go.mod h1:t8PYl/6LzdAqsU4/9tz28V/kU+asFePvpOMkdul0gEQ= | ||||||
| github.com/aws/aws-sdk-go-v2/config v1.28.5 h1:Za41twdCXbuyyWv9LndXxZZv3QhTG1DinqlFsSuvtI0= | github.com/aws/aws-sdk-go-v2/config v1.28.5 h1:Za41twdCXbuyyWv9LndXxZZv3QhTG1DinqlFsSuvtI0= | ||||||
| @ -86,6 +90,7 @@ github.com/coreos/go-systemd/v22 v22.3.2 h1:D9/bQk5vlXQFZ6Kwuu6zaiXJ9oTPe68++AzA | |||||||
| github.com/coreos/go-systemd/v22 v22.3.2/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc= | github.com/coreos/go-systemd/v22 v22.3.2/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc= | ||||||
| github.com/cpuguy83/go-md2man/v2 v2.0.3/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= | github.com/cpuguy83/go-md2man/v2 v2.0.3/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= | ||||||
| github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= | github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= | ||||||
|  | github.com/dave/jennifer v1.6.1/go.mod h1:nXbxhEmQfOZhWml3D1cDK5M1FLnMSozpbFN/m3RmGZc= | ||||||
| github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= | github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= | ||||||
| github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= | github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= | ||||||
| github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc h1:U9qPSI2PIWSS1VwoXQT9A3Wy9MM3WgvqSxFWenqJduM= | github.com/davecgh/go-spew v1.1.2-0.20180830191138-d8f796af33cc h1:U9qPSI2PIWSS1VwoXQT9A3Wy9MM3WgvqSxFWenqJduM= | ||||||
| @ -103,6 +108,10 @@ 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/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 h1:YOEu7KNc61ntiQlcEeUIoDTJ2o8mQznoNvUhiigpIqc= | ||||||
| github.com/eapache/queue v1.1.0/go.mod h1:6eCeP0CKFpHLu8blIFXhExK/dRa7WDZfr6jVFPTqq+I= | 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 h1:rAQeMHw1c7zTmncogyy8VvRZwtkmkZ4FxERmMY4rD+g= | ||||||
| github.com/emicklei/go-restful/v3 v3.11.0/go.mod h1:6n3XBCmQQb25CM2LCACGz8ukIrRry+4bhvbpWn3mrbc= | 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.0/go.mod h1:YTl/9mNaCwkRvm6d1a2C3ymFceY/DCBVvsKhRF0iEA4= | ||||||
| @ -123,6 +132,8 @@ github.com/fxamacker/cbor/v2 v2.7.0 h1:iM5WgngdRBanHcxugY4JySA0nk1wZorNOpTgCMedv | |||||||
| github.com/fxamacker/cbor/v2 v2.7.0/go.mod h1:pxXPTn3joSm21Gbwsv0w9OSA2y1HFR9qXEeXQVeNoDQ= | 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 h1:in2uUcidCuFcDKtdcBxlR0rJ1+fsokWf+uqxgUFjbI0= | ||||||
| github.com/gabriel-vasile/mimetype v1.4.3/go.mod h1:d8uq/6HKRL6CGdk+aubisF/M5GcPfT7nKyLpA0lbSSk= | github.com/gabriel-vasile/mimetype v1.4.3/go.mod h1:d8uq/6HKRL6CGdk+aubisF/M5GcPfT7nKyLpA0lbSSk= | ||||||
|  | github.com/gammazero/toposort v0.1.1 h1:OivGxsWxF3U3+U80VoLJ+f50HcPU1MIqE1JlKzoJ2Eg= | ||||||
|  | github.com/gammazero/toposort v0.1.1/go.mod h1:H2cozTnNpMw0hg2VHAYsAxmkHXBYroNangj2NTBQDvw= | ||||||
| github.com/gin-contrib/gzip v1.0.1 h1:HQ8ENHODeLY7a4g1Au/46Z92bdGFl74OhxcZble9WJE= | github.com/gin-contrib/gzip v1.0.1 h1:HQ8ENHODeLY7a4g1Au/46Z92bdGFl74OhxcZble9WJE= | ||||||
| github.com/gin-contrib/gzip v1.0.1/go.mod h1:njt428fdUNRvjuJf16tZMYZ2Yl+WQB53X5wmhDwXvC4= | github.com/gin-contrib/gzip v1.0.1/go.mod h1:njt428fdUNRvjuJf16tZMYZ2Yl+WQB53X5wmhDwXvC4= | ||||||
| github.com/gin-contrib/sse v0.1.0 h1:Y/yl/+YNO8GZSjAhjMsSuLt29uWRFHdHYUb5lYOV9qE= | github.com/gin-contrib/sse v0.1.0 h1:Y/yl/+YNO8GZSjAhjMsSuLt29uWRFHdHYUb5lYOV9qE= | ||||||
| @ -154,7 +165,7 @@ github.com/go-playground/universal-translator v0.17.0/go.mod h1:UkSxE5sNxxRwHyU+ | |||||||
| github.com/go-playground/universal-translator v0.18.0/go.mod h1:UvRDBj+xPUEGrFYl+lu/H90nyDXpg0fqeB/AQUGNTVA= | github.com/go-playground/universal-translator v0.18.0/go.mod h1:UvRDBj+xPUEGrFYl+lu/H90nyDXpg0fqeB/AQUGNTVA= | ||||||
| github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJnYK9S473LQFuzCbDbfSFY= | github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJnYK9S473LQFuzCbDbfSFY= | ||||||
| github.com/go-playground/universal-translator v0.18.1/go.mod h1:xekY+UJKNuX9WP91TpwSH2VMlDf28Uj24BCp08ZFTUY= | github.com/go-playground/universal-translator v0.18.1/go.mod h1:xekY+UJKNuX9WP91TpwSH2VMlDf28Uj24BCp08ZFTUY= | ||||||
| github.com/go-playground/validator/v10 v10.8.0/go.mod h1:9JhgTzTaE31GZDpH/HSvHiRJrJ3iKAgqqH0Bl/Ocjdk= | github.com/go-playground/validator/v10 v10.7.0/go.mod h1:xm76BBt941f7yWdGnI2DVPFFg1UK3YY04qifoXU3lOk= | ||||||
| github.com/go-playground/validator/v10 v10.20.0 h1:K9ISHbSaI0lyB2eWMPJo+kOS/FBExVwjEviJTixqxL8= | github.com/go-playground/validator/v10 v10.20.0 h1:K9ISHbSaI0lyB2eWMPJo+kOS/FBExVwjEviJTixqxL8= | ||||||
| github.com/go-playground/validator/v10 v10.20.0/go.mod h1:dbuPbCMFw/DrkbEynArYaCwl3amGuJotoKCe95atGMM= | github.com/go-playground/validator/v10 v10.20.0/go.mod h1:dbuPbCMFw/DrkbEynArYaCwl3amGuJotoKCe95atGMM= | ||||||
| github.com/go-redis/redis v6.15.9+incompatible h1:K0pv1D7EQUjfyoMql+r/jZqCLizCGKFlFgcHWWmHQjg= | github.com/go-redis/redis v6.15.9+incompatible h1:K0pv1D7EQUjfyoMql+r/jZqCLizCGKFlFgcHWWmHQjg= | ||||||
| @ -168,6 +179,8 @@ github.com/go-zookeeper/zk v1.0.3/go.mod h1:nOB03cncLtlp4t+UAkGSV+9beXP/akpekBwL | |||||||
| github.com/goccy/go-json v0.10.2 h1:CrxCmQqYDkv1z7lO7Wbh2HN93uovUHgrECaO5ZrCXAU= | github.com/goccy/go-json v0.10.2 h1:CrxCmQqYDkv1z7lO7Wbh2HN93uovUHgrECaO5ZrCXAU= | ||||||
| github.com/goccy/go-json v0.10.2/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I= | github.com/goccy/go-json v0.10.2/go.mod h1:6MelG93GURQebXPDq3khkgXZkazVtN9CRI+MGFi0w8I= | ||||||
| github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA= | github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA= | ||||||
|  | github.com/gofrs/flock v0.8.1 h1:+gYjHKf32LDeiEEFhQaotPbLuUXjY5ZqxKgXy7n59aw= | ||||||
|  | github.com/gofrs/flock v0.8.1/go.mod h1:F1TvTiK9OcQqauNUHlbJvyl9Qa1QvF/gOUDKA14jxHU= | ||||||
| github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= | github.com/gogo/protobuf v1.3.2 h1:Ov1cvc58UF3b5XjBnZv7+opcTcQFZebYjWzi34vdm4Q= | ||||||
| github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= | github.com/gogo/protobuf v1.3.2/go.mod h1:P1XiOD3dCwIKUDQYPy72D8LYyHL2YPYrpS2s69NZV8Q= | ||||||
| github.com/golang-jwt/jwt/v4 v4.4.2/go.mod h1:m21LjoU+eqJr34lmDMbreY2eSTRJ1cv77w39/MY0Ch0= | github.com/golang-jwt/jwt/v4 v4.4.2/go.mod h1:m21LjoU+eqJr34lmDMbreY2eSTRJ1cv77w39/MY0Ch0= | ||||||
| @ -224,6 +237,8 @@ github.com/googleapis/enterprise-certificate-proxy v0.3.2 h1:Vie5ybvEvT75RniqhfF | |||||||
| github.com/googleapis/enterprise-certificate-proxy v0.3.2/go.mod h1:VLSiSSBs/ksPL8kq3OBOQ6WRI2QnaFynd1DCjZ62+V0= | github.com/googleapis/enterprise-certificate-proxy v0.3.2/go.mod h1:VLSiSSBs/ksPL8kq3OBOQ6WRI2QnaFynd1DCjZ62+V0= | ||||||
| github.com/googleapis/gax-go/v2 v2.12.3 h1:5/zPPDvw8Q1SuXjrqrZslrqT7dL/uJT2CQii/cLCKqA= | github.com/googleapis/gax-go/v2 v2.12.3 h1:5/zPPDvw8Q1SuXjrqrZslrqT7dL/uJT2CQii/cLCKqA= | ||||||
| github.com/googleapis/gax-go/v2 v2.12.3/go.mod h1:AKloxT6GtNbaLm8QTNSidHUVsHYcBHwWRvkNFJUQcS4= | github.com/googleapis/gax-go/v2 v2.12.3/go.mod h1:AKloxT6GtNbaLm8QTNSidHUVsHYcBHwWRvkNFJUQcS4= | ||||||
|  | github.com/gorilla/mux v1.8.1 h1:TuBL49tXwgrFYWhqrNgrUNEY92u81SPhu7sTdzQEiWY= | ||||||
|  | github.com/gorilla/mux v1.8.1/go.mod h1:AKf9I4AEqPTmMytcMc0KkNouC66V3BtZ4qD5fmWSiMQ= | ||||||
| github.com/gorilla/securecookie v1.1.1/go.mod h1:ra0sb63/xPlUeL+yeDciTfxMRAA+MP+HVt/4epWDjd4= | github.com/gorilla/securecookie v1.1.1/go.mod h1:ra0sb63/xPlUeL+yeDciTfxMRAA+MP+HVt/4epWDjd4= | ||||||
| github.com/gorilla/sessions v1.2.1/go.mod h1:dk2InVEVJ0sfLlnXv9EAgkf6ecYs/i80K/zI+bUmuGM= | github.com/gorilla/sessions v1.2.1/go.mod h1:dk2InVEVJ0sfLlnXv9EAgkf6ecYs/i80K/zI+bUmuGM= | ||||||
| github.com/gorilla/websocket v1.5.1 h1:gmztn0JnHVt9JZquRuzLw3g4wouNVzKL15iLr/zn/QY= | github.com/gorilla/websocket v1.5.1 h1:gmztn0JnHVt9JZquRuzLw3g4wouNVzKL15iLr/zn/QY= | ||||||
| @ -242,6 +257,7 @@ github.com/hashicorp/golang-lru/v2 v2.0.7 h1:a+bsQ5rvGLjzHuww6tVxozPZFVghXaHOwFs | |||||||
| github.com/hashicorp/golang-lru/v2 v2.0.7/go.mod h1:QeFd9opnmA6QUJc5vARoKUSoFhyfM2/ZepoAG6RGpeM= | github.com/hashicorp/golang-lru/v2 v2.0.7/go.mod h1:QeFd9opnmA6QUJc5vARoKUSoFhyfM2/ZepoAG6RGpeM= | ||||||
| github.com/hashicorp/hcl v1.0.0 h1:0Anlzjpi4vEasTeNFn2mLJgTSwt0+6sfsiTG8qcWGx4= | github.com/hashicorp/hcl v1.0.0 h1:0Anlzjpi4vEasTeNFn2mLJgTSwt0+6sfsiTG8qcWGx4= | ||||||
| github.com/hashicorp/hcl v1.0.0/go.mod h1:E5yfLk+7swimpb2L/Alb/PJmXilQ/rhwaUYs4T20WEQ= | github.com/hashicorp/hcl v1.0.0/go.mod h1:E5yfLk+7swimpb2L/Alb/PJmXilQ/rhwaUYs4T20WEQ= | ||||||
|  | github.com/iancoleman/strcase v0.3.0/go.mod h1:iwCmte+B7n89clKwxIoIXy/HfoL7AsD47ZCWhYzw7ho= | ||||||
| github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8= | github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8= | ||||||
| github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw= | github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw= | ||||||
| github.com/jcmturner/aescts/v2 v2.0.0 h1:9YKLH6ey7H4eDBXW8khjYslgyqG2xZikXP0EQFKrle8= | github.com/jcmturner/aescts/v2 v2.0.0 h1:9YKLH6ey7H4eDBXW8khjYslgyqG2xZikXP0EQFKrle8= | ||||||
| @ -256,12 +272,15 @@ github.com/jcmturner/gokrb5/v8 v8.4.4 h1:x1Sv4HaTpepFkXbt2IkL29DXRf8sOfZXo8eRKh6 | |||||||
| github.com/jcmturner/gokrb5/v8 v8.4.4/go.mod h1:1btQEpgT6k+unzCwX1KdWMEwPPkkgBtP+F6aCACiMrs= | github.com/jcmturner/gokrb5/v8 v8.4.4/go.mod h1:1btQEpgT6k+unzCwX1KdWMEwPPkkgBtP+F6aCACiMrs= | ||||||
| github.com/jcmturner/rpc/v2 v2.0.3 h1:7FXXj8Ti1IaVFpSAziCZWNzbNuZmnvw/i6CqLNdWfZY= | github.com/jcmturner/rpc/v2 v2.0.3 h1:7FXXj8Ti1IaVFpSAziCZWNzbNuZmnvw/i6CqLNdWfZY= | ||||||
| github.com/jcmturner/rpc/v2 v2.0.3/go.mod h1:VUJYCIDm3PVOEHw8sgt091/20OJjskO/YJki3ELg/Hc= | github.com/jcmturner/rpc/v2 v2.0.3/go.mod h1:VUJYCIDm3PVOEHw8sgt091/20OJjskO/YJki3ELg/Hc= | ||||||
|  | github.com/jessevdk/go-flags v1.4.0/go.mod h1:4FA24M0QyGHXBuZZK/XkWh8h0e1EYbRYJSGM75WSRxI= | ||||||
| github.com/jinzhu/copier v0.4.0 h1:w3ciUoD19shMCRargcpm0cm91ytaBhDvuRpz1ODO/U8= | github.com/jinzhu/copier v0.4.0 h1:w3ciUoD19shMCRargcpm0cm91ytaBhDvuRpz1ODO/U8= | ||||||
| github.com/jinzhu/copier v0.4.0/go.mod h1:DfbEm0FYsaqBcKcFuvmOZb218JkPGtvSHsKg8S8hyyg= | github.com/jinzhu/copier v0.4.0/go.mod h1:DfbEm0FYsaqBcKcFuvmOZb218JkPGtvSHsKg8S8hyyg= | ||||||
| github.com/jinzhu/inflection v1.0.0 h1:K317FqzuhWc8YvSVlFMCCUb36O/S9MCKRDI7QkRKD/E= | github.com/jinzhu/inflection v1.0.0 h1:K317FqzuhWc8YvSVlFMCCUb36O/S9MCKRDI7QkRKD/E= | ||||||
| github.com/jinzhu/inflection v1.0.0/go.mod h1:h+uFLlag+Qp1Va5pdKtLDYj+kHp5pxUVkryuEj+Srlc= | github.com/jinzhu/inflection v1.0.0/go.mod h1:h+uFLlag+Qp1Va5pdKtLDYj+kHp5pxUVkryuEj+Srlc= | ||||||
| github.com/jinzhu/now v1.1.5 h1:/o9tlHleP7gOFmsnYNz3RGnqzefHA47wQpKrrdTIwXQ= | github.com/jinzhu/now v1.1.5 h1:/o9tlHleP7gOFmsnYNz3RGnqzefHA47wQpKrrdTIwXQ= | ||||||
| github.com/jinzhu/now v1.1.5/go.mod h1:d3SSVoowX0Lcu0IBviAWJpolVfI5UJVZZ7cO71lE/z8= | github.com/jinzhu/now v1.1.5/go.mod h1:d3SSVoowX0Lcu0IBviAWJpolVfI5UJVZZ7cO71lE/z8= | ||||||
|  | github.com/joeshaw/multierror v0.0.0-20140124173710-69b34d4ec901 h1:rp+c0RAYOWj8l6qbCUTSiRLG/iKnW3K3/QfPPuSsBt4= | ||||||
|  | github.com/joeshaw/multierror v0.0.0-20140124173710-69b34d4ec901/go.mod h1:Z86h9688Y0wesXCyonoVr47MasHilkuLMqGhRZ4Hpak= | ||||||
| github.com/jonboulle/clockwork v0.4.0 h1:p4Cf1aMWXnXAUh8lVfewRBx1zaTSYKrKMF2g3ST4RZ4= | github.com/jonboulle/clockwork v0.4.0 h1:p4Cf1aMWXnXAUh8lVfewRBx1zaTSYKrKMF2g3ST4RZ4= | ||||||
| github.com/jonboulle/clockwork v0.4.0/go.mod h1:xgRqUGwRcjKCO1vbZUEtSLrqKoPSsUpK7fnezOII0kc= | 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 h1:vlS4z54oSdjm0bgjRigI+G1HpF+tI+9rE5LLzOg8HmY= | ||||||
| @ -290,6 +309,7 @@ github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= | |||||||
| github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= | github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= | ||||||
| github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= | github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= | ||||||
| github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= | github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= | ||||||
|  | github.com/leodido/go-urn v1.2.0/go.mod h1:+8+nEpDfqqsY+g338gtMEUOtuK+4dEMhiQEgxpxOKII= | ||||||
| github.com/leodido/go-urn v1.2.1/go.mod h1:zt4jvISO2HfUBqxjfIshjdMTYS56ZS/qv49ictyFfxY= | github.com/leodido/go-urn v1.2.1/go.mod h1:zt4jvISO2HfUBqxjfIshjdMTYS56ZS/qv49ictyFfxY= | ||||||
| github.com/leodido/go-urn v1.4.0 h1:WT9HwE9SGECu3lg4d/dIA+jxlljEa1/ffXKmRjqdmIQ= | github.com/leodido/go-urn v1.4.0 h1:WT9HwE9SGECu3lg4d/dIA+jxlljEa1/ffXKmRjqdmIQ= | ||||||
| github.com/leodido/go-urn v1.4.0/go.mod h1:bvxc+MVxLKB4z00jd1z+Dvzr47oO32F/QSNjSBOlFxI= | github.com/leodido/go-urn v1.4.0/go.mod h1:bvxc+MVxLKB4z00jd1z+Dvzr47oO32F/QSNjSBOlFxI= | ||||||
| @ -347,15 +367,16 @@ 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/onsi/gomega v1.25.0/go.mod h1:r+zV744Re+DiYCIPRlYOTxn0YkOLcAnW8k1xXdMPGhM= | ||||||
| github.com/openimsdk/gomake v0.0.15-alpha.1 h1:a3U0gayzEJJucOoIOt9Jju+HQTG2BtKcuLG4AVjeVF4= | 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/gomake v0.0.15-alpha.1/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.61 h1:RuZR9/Sg3p6Bpb2CKPjPoA2AUmTvHITmhZ3PT/RbWMs= | ||||||
| github.com/openimsdk/protocol v0.0.72-alpha.59/go.mod h1:Iet+piS/jaS+kWWyj6EEr36mk4ISzIRYjoMSVA4dq2M= | github.com/openimsdk/protocol v0.0.72-alpha.61/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.45 h1:bu3HCkdzLNQAPUR1VhF40XA9OhaNGHGxZqcC4rIYJyY= | ||||||
| github.com/openimsdk/tools v0.0.50-alpha.38/go.mod h1:/Em/fQH46CuWf60+hcmvZyboGCQpSDEb2MdQ4nmQRAk= | 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 h1:aYUidT7k73Pcl9nb2gScu7NSrKCSHIDE89b3+6Wq+LM= | ||||||
| github.com/pelletier/go-toml/v2 v2.2.2/go.mod h1:1t835xjRzz80PqgE6HHgN2JOsmgYu/h4qDAS4n929Rs= | 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= | github.com/pierrec/lz4/v4 v4.1.21 h1:yOVMLb6qSIDP67pl/5F7RepeKYu/VmTyEXvuMI5d9mQ= | ||||||
| github.com/pierrec/lz4/v4 v4.1.21/go.mod h1:gZWDp/Ze/IJXGXf23ltt2EXimqmTUXEy0GFuRQyBid4= | github.com/pierrec/lz4/v4 v4.1.21/go.mod h1:gZWDp/Ze/IJXGXf23ltt2EXimqmTUXEy0GFuRQyBid4= | ||||||
| github.com/pkg/diff v0.0.0-20210226163009-20ebb0f2a09e/go.mod h1:pJLUxLENpZxwdsKMEsNbx1VGcRFpLqf3715MtcvvzbA= | github.com/pkg/diff v0.0.0-20210226163009-20ebb0f2a09e/go.mod h1:pJLUxLENpZxwdsKMEsNbx1VGcRFpLqf3715MtcvvzbA= | ||||||
|  | github.com/pkg/errors v0.8.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= | ||||||
| github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4= | github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4= | ||||||
| github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= | github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= | ||||||
| github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= | github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= | ||||||
| @ -370,11 +391,12 @@ github.com/prometheus/client_model v0.5.0 h1:VQw1hfvPvk3Uv6Qf29VrPF32JB6rtbgI6cY | |||||||
| github.com/prometheus/client_model v0.5.0/go.mod h1:dTiFglRmd66nLR9Pv9f0mZi7B7fk5Pm3gvsjB5tr+kI= | github.com/prometheus/client_model v0.5.0/go.mod h1:dTiFglRmd66nLR9Pv9f0mZi7B7fk5Pm3gvsjB5tr+kI= | ||||||
| github.com/prometheus/common v0.45.0 h1:2BGz0eBc2hdMDLnO/8n0jeB3oPrt2D08CekT0lneoxM= | github.com/prometheus/common v0.45.0 h1:2BGz0eBc2hdMDLnO/8n0jeB3oPrt2D08CekT0lneoxM= | ||||||
| github.com/prometheus/common v0.45.0/go.mod h1:YJmSTw9BoKxJplESWWxlbyttQR4uaEcGyv9MZjVOJsY= | github.com/prometheus/common v0.45.0/go.mod h1:YJmSTw9BoKxJplESWWxlbyttQR4uaEcGyv9MZjVOJsY= | ||||||
|  | github.com/prometheus/procfs v0.0.0-20190425082905-87a4384529e0/go.mod h1:TjEm7ze935MbeOT/UhFTIMYKhuLP4wbCsTZCD3I8kEA= | ||||||
| github.com/prometheus/procfs v0.12.0 h1:jluTpSng7V9hY0O2R9DzzJHYb2xULk9VTR1V1R/k6Bo= | github.com/prometheus/procfs v0.12.0 h1:jluTpSng7V9hY0O2R9DzzJHYb2xULk9VTR1V1R/k6Bo= | ||||||
| github.com/prometheus/procfs v0.12.0/go.mod h1:pcuDEFsWDnvcgNzo4EEweacyhjeA9Zk3cnaOZAZEfOo= | github.com/prometheus/procfs v0.12.0/go.mod h1:pcuDEFsWDnvcgNzo4EEweacyhjeA9Zk3cnaOZAZEfOo= | ||||||
| github.com/qiniu/dyn v1.3.0/go.mod h1:E8oERcm8TtwJiZvkQPbcAh0RL8jO1G0VXJMW3FAWdkk= | github.com/qiniu/dyn v1.3.0/go.mod h1:E8oERcm8TtwJiZvkQPbcAh0RL8jO1G0VXJMW3FAWdkk= | ||||||
| github.com/qiniu/go-sdk/v7 v7.18.2 h1:vk9eo5OO7aqgAOPF0Ytik/gt7CMKuNgzC/IPkhda6rk= | github.com/qiniu/go-sdk/v7 v7.25.0 h1:Roi4XMxRly9K4wb87DhQOKaQylyiphEXC7/l8uqJZaQ= | ||||||
| github.com/qiniu/go-sdk/v7 v7.18.2/go.mod h1:nqoYCNo53ZlGA521RvRethvxUDvXKt4gtYXOwye868w= | github.com/qiniu/go-sdk/v7 v7.25.0/go.mod h1:uZE85Pi0ftIHT/UNLShosdzwsovqpdas0LwAGO7cPao= | ||||||
| github.com/qiniu/x v1.10.5/go.mod h1:03Ni9tj+N2h2aKnAz+6N0Xfl8FwMEDRC2PAlxekASDs= | github.com/qiniu/x v1.10.5/go.mod h1:03Ni9tj+N2h2aKnAz+6N0Xfl8FwMEDRC2PAlxekASDs= | ||||||
| github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 h1:N/ElC8H3+5XpJzTSTfLsJV/mx9Q9g7kxmchpfZyxgzM= | github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475 h1:N/ElC8H3+5XpJzTSTfLsJV/mx9Q9g7kxmchpfZyxgzM= | ||||||
| github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4= | github.com/rcrowley/go-metrics v0.0.0-20201227073835-cf1acfcdf475/go.mod h1:bCqnVzQkZxMG4s8nGwiZ5l3QUCyqpo9Y+/ZMZ9VjZe4= | ||||||
| @ -407,8 +429,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/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg= | ||||||
| github.com/spf13/viper v1.18.2 h1:LUXCnvUvSM6FXAsj6nnfc8Q2tp1dIgUfY9Kc8GsSOiQ= | github.com/spf13/viper v1.18.2 h1:LUXCnvUvSM6FXAsj6nnfc8Q2tp1dIgUfY9Kc8GsSOiQ= | ||||||
| github.com/spf13/viper v1.18.2/go.mod h1:EKmWIqdnk5lOcmR72yw6hS+8OPYcwD0jteitLMVB+yk= | 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.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.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw= | ||||||
| github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= | github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= | ||||||
| @ -491,9 +511,7 @@ golang.org/x/arch v0.7.0/go.mod h1:FEVrYAQjsQXMVJ1nsMoVVXPZg6p2JE2mx8psSWTDQys= | |||||||
| golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= | golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w= | ||||||
| golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= | ||||||
| golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= | golang.org/x/crypto v0.0.0-20200622213623-75b288015ac9/go.mod h1:LzIPMQfyMNhhGPhUkYOs5KpL4U8rLKemX1yGLhDgUto= | ||||||
| golang.org/x/crypto v0.0.0-20210711020723-a769d52b0f97/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= |  | ||||||
| golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= | golang.org/x/crypto v0.0.0-20210921155107-089bfa567519/go.mod h1:GvvjBRRGRdwPK5ydBHafDWAxML/pGHZbMvKqRZ5+Abc= | ||||||
| golang.org/x/crypto v0.1.0/go.mod h1:RecgLatLF4+eUMCP1PoPZQb+cVrJcOPbHkTkbkB9sbw= |  | ||||||
| golang.org/x/crypto v0.6.0/go.mod h1:OFC/31mSvZgRz0V1QTNCzfAI1aIRzbiufJtkMIlEp58= | golang.org/x/crypto v0.6.0/go.mod h1:OFC/31mSvZgRz0V1QTNCzfAI1aIRzbiufJtkMIlEp58= | ||||||
| golang.org/x/crypto v0.27.0 h1:GXm2NjJrPaiv/h1tb2UH8QfgC/hOf/+z0p6PT8o1w7A= | golang.org/x/crypto v0.27.0 h1:GXm2NjJrPaiv/h1tb2UH8QfgC/hOf/+z0p6PT8o1w7A= | ||||||
| golang.org/x/crypto v0.27.0/go.mod h1:1Xngt8kV6Dvbssa53Ziq6Eqn0HqbZi5Z6R0ZpwQzt70= | golang.org/x/crypto v0.27.0/go.mod h1:1Xngt8kV6Dvbssa53Ziq6Eqn0HqbZi5Z6R0ZpwQzt70= | ||||||
| @ -521,7 +539,6 @@ golang.org/x/net v0.0.0-20201110031124-69a78807bb2b/go.mod h1:sp8m0HH+o8qH0wwXwY | |||||||
| golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= | golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= | ||||||
| golang.org/x/net v0.0.0-20220708220712-1185a9018129/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= | golang.org/x/net v0.0.0-20220708220712-1185a9018129/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= | ||||||
| golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= | golang.org/x/net v0.0.0-20220722155237-a158d28d115b/go.mod h1:XRhObCWvk6IyKnWLug+ECip1KBveYUHfp+8e9klMJ9c= | ||||||
| golang.org/x/net v0.1.0/go.mod h1:Cx3nUiGt4eDBEyega/BKRp+/AlGL8hYe7U9odMt2Cco= |  | ||||||
| golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= | golang.org/x/net v0.6.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= | ||||||
| golang.org/x/net v0.7.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= | golang.org/x/net v0.7.0/go.mod h1:2Tu9+aMcznHK/AK1HMvgo6xiTLG5rD5rZLDS+rp2Bjs= | ||||||
| golang.org/x/net v0.29.0 h1:5ORfpBpCs4HzDYoodCDBbwHzdR5UrLBZ3sOnUJmFoHo= | golang.org/x/net v0.29.0 h1:5ORfpBpCs4HzDYoodCDBbwHzdR5UrLBZ3sOnUJmFoHo= | ||||||
| @ -531,6 +548,7 @@ golang.org/x/oauth2 v0.23.0 h1:PbgcYx2W7i4LvjJWEbf0ngHV6qJYr86PkAV3bXdLEbs= | |||||||
| golang.org/x/oauth2 v0.23.0/go.mod h1:XYTD2NtWslqkgxebSiOHnXEap4TF09sJSc7H1sXbhtI= | golang.org/x/oauth2 v0.23.0/go.mod h1:XYTD2NtWslqkgxebSiOHnXEap4TF09sJSc7H1sXbhtI= | ||||||
| golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | golang.org/x/sync v0.0.0-20180314180146-1d60e4601c6f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||||
| golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | golang.org/x/sync v0.0.0-20181108010431-42b317875d0f/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||||
|  | golang.org/x/sync v0.0.0-20181221193216-37e7f081c4d4/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||||
| golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||||
| golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | golang.org/x/sync v0.0.0-20190911185100-cd5d95a43a6e/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||||
| golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | golang.org/x/sync v0.0.0-20201020160332-67f06af15bc9/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM= | ||||||
| @ -540,22 +558,20 @@ golang.org/x/sync v0.8.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= | |||||||
| golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | golang.org/x/sys v0.0.0-20180830151530-49385e6e1522/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||||
| golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY= | ||||||
| golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||||
|  | golang.org/x/sys v0.0.0-20190425145619-16072639606e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||||
| golang.org/x/sys v0.0.0-20190916202348-b4ddaad3f8a3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | golang.org/x/sys v0.0.0-20190916202348-b4ddaad3f8a3/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||||
| golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | golang.org/x/sys v0.0.0-20200930185726-fdedc70b468f/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||||
| golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= | ||||||
| golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | golang.org/x/sys v0.0.0-20210615035016-665e8c7367d1/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||||
| golang.org/x/sys v0.0.0-20210630005230-0f9fa26af87c/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |  | ||||||
| golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | golang.org/x/sys v0.0.0-20220520151302-bc2c85ada10a/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||||
| golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | golang.org/x/sys v0.0.0-20220722155257-8c9f86f7a55f/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||||
| golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||||
| golang.org/x/sys v0.1.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |  | ||||||
| golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||||
| golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||||
| golang.org/x/sys v0.25.0 h1:r+8e+loiHxRqhXVl6ML1nO3l1+oFoWbnlu2Ehimmi34= | golang.org/x/sys v0.25.0 h1:r+8e+loiHxRqhXVl6ML1nO3l1+oFoWbnlu2Ehimmi34= | ||||||
| golang.org/x/sys v0.25.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= | golang.org/x/sys v0.25.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= | ||||||
| golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= | golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= | ||||||
| golang.org/x/term v0.0.0-20210927222741-03fcf44c2211/go.mod h1:jbD1KX2456YbFQfuXm/mYQcufACuNUgVhRMnK/tPxf8= | 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.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 h1:Mh5cbb+Zk2hqqXNO7S1iTjEphVL+jb8ZWaqh/g+JWkM= | ||||||
| golang.org/x/term v0.24.0/go.mod h1:lOBK/LVxemqiMij05LGJ0tzNr8xlmwBRJ81PX6wVLH8= | golang.org/x/term v0.24.0/go.mod h1:lOBK/LVxemqiMij05LGJ0tzNr8xlmwBRJ81PX6wVLH8= | ||||||
| @ -565,7 +581,6 @@ golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= | |||||||
| golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= | golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= | ||||||
| golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ= | golang.org/x/text v0.3.7/go.mod h1:u+2+/6zg+i71rQMx5EYifcz6MCKuco9NR6JIITiCfzQ= | ||||||
| golang.org/x/text v0.3.8/go.mod h1:E6s5w1FMmriuDzIBO73fBruAKo1PCIq6d2Q6DHfQ8WQ= | golang.org/x/text v0.3.8/go.mod h1:E6s5w1FMmriuDzIBO73fBruAKo1PCIq6d2Q6DHfQ8WQ= | ||||||
| golang.org/x/text v0.4.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= |  | ||||||
| golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= | golang.org/x/text v0.7.0/go.mod h1:mrYo+phRRbMaCq/xk9113O4dZlRixOauAjOtrjsXDZ8= | ||||||
| golang.org/x/text v0.18.0 h1:XvMDiNzPAl0jr17s6W9lcaIhGUfUORdGCNsuLmPG224= | golang.org/x/text v0.18.0 h1:XvMDiNzPAl0jr17s6W9lcaIhGUfUORdGCNsuLmPG224= | ||||||
| golang.org/x/text v0.18.0/go.mod h1:BuEKDfySbSR4drPmRPG/7iBdf8hvFMuRexcpahXilzY= | golang.org/x/text v0.18.0/go.mod h1:BuEKDfySbSR4drPmRPG/7iBdf8hvFMuRexcpahXilzY= | ||||||
| @ -632,6 +647,7 @@ 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/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 h1:uRGJdciOHaEIrze2W8Q3AKkepLTh2hOroT7a+7czfdQ= | ||||||
| gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw= | gopkg.in/tomb.v1 v1.0.0-20141024135613-dd632973f1e7/go.mod h1:dt/ZhP58zS4L8KSrWDmTeBkI65Dw0HsyUHuEVlX15mw= | ||||||
|  | gopkg.in/yaml.v2 v2.2.1/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= | ||||||
| gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= | 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.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 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY= | ||||||
| @ -644,6 +660,8 @@ gorm.io/gorm v1.25.8 h1:WAGEZ/aEcznN4D03laj8DKnehe1e9gYQAjW8xyPRdeo= | |||||||
| gorm.io/gorm v1.25.8/go.mod h1:hbnx/Oo0ChWMn1BIhpy1oYozzpM15i4YPuHDmfYtwg8= | 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-20190102054323-c2f93a96b099/go.mod h1:rf3lG4BRIbNafJWhAfAdb/ePZxsR/4RtNHQocxwk9r4= | ||||||
| honnef.co/go/tools v0.0.0-20190523083050-ea95bdfd59fc/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 h1:3wLBbL5Uom/8Zy98GRPXpJ254nEFpl+hwndmk9RwmL0= | ||||||
| k8s.io/api v0.31.2/go.mod h1:bWmGvrGPssSK1ljmLzd3pwCQ9MgoTsRCuK35u6SygUk= | 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 h1:i4vUt2hPK56W6mlT7Ry+AO8eEsyxMD1U44NR22CLTYw= | ||||||
| @ -656,6 +674,8 @@ k8s.io/kube-openapi v0.0.0-20240228011516-70dd3763d340 h1:BZqlfIlq5YbRMFko6/PM7F | |||||||
| k8s.io/kube-openapi v0.0.0-20240228011516-70dd3763d340/go.mod h1:yD4MZYeKMBwQKVht279WycxKyM84kkAx2DPrTXaeb98= | 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 h1:pUdcCO1Lk/tbT5ztQWOBi5HBgbBP1J8+AsQnQCKsi8A= | ||||||
| k8s.io/utils v0.0.0-20240711033017-18e509b52bc8/go.mod h1:OLgZIPagt7ERELqWJFomSt595RzquPNLL48iOWgYOg0= | 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= | nullprogram.com/x/optparse v1.0.0/go.mod h1:KdyPE+Igbe0jQUrVfMqDMeJQIJZEuyV7pjYmp6pbG50= | ||||||
| rsc.io/pdf v0.1.1/go.mod h1:n8OzWcQ6Sp37PL01nO98y4iUCRdTGarVfzxY20ICaU4= | rsc.io/pdf v0.1.1/go.mod h1:n8OzWcQ6Sp37PL01nO98y4iUCRdTGarVfzxY20ICaU4= | ||||||
| sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd h1:EDPBXCAspyGV4jQlpZSudPeMmr1bNJefnuqLsRAsHZo= | sigs.k8s.io/json v0.0.0-20221116044647-bc3834ca7abd h1:EDPBXCAspyGV4jQlpZSudPeMmr1bNJefnuqLsRAsHZo= | ||||||
| @ -664,5 +684,3 @@ sigs.k8s.io/structured-merge-diff/v4 v4.4.1 h1:150L+0vs/8DA78h1u02ooW1/fFq/Lwr+s | |||||||
| sigs.k8s.io/structured-merge-diff/v4 v4.4.1/go.mod h1:N8hJocpFajUSSeSJ9bOZ77VzejKZaXsTtZo4/u7Io08= | 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 h1:Mk1wCc2gy/F0THH0TAp1QYyJNzRm2KCLy3o5ASXVI5E= | ||||||
| sigs.k8s.io/yaml v1.4.0/go.mod h1:Ejl7/uTz7PSA4eKMyQCUTnhZYNmLIl+5c2lQPGR2BPY= | sigs.k8s.io/yaml v1.4.0/go.mod h1:Ejl7/uTz7PSA4eKMyQCUTnhZYNmLIl+5c2lQPGR2BPY= | ||||||
| stathat.com/c/consistent v1.0.0 h1:ezyc51EGcRPJUxfHGSgJjWzJdj3NiMU9pNfLNGiXV0c= |  | ||||||
| stathat.com/c/consistent v1.0.0/go.mod h1:QkzMWzcbB+yQBL2AttO6sgsQS/JSTapcDISJalmCDS0= |  | ||||||
|  | |||||||
| @ -17,9 +17,6 @@ package api | |||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
| 	"fmt" | 	"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" | ||||||
| 	"net/http" | 	"net/http" | ||||||
| 	"os" | 	"os" | ||||||
| @ -28,6 +25,11 @@ import ( | |||||||
| 	"syscall" | 	"syscall" | ||||||
| 	"time" | 	"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" | 	kdisc "github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister" | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/prommetrics" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/prommetrics" | ||||||
| 	"github.com/openimsdk/tools/discovery" | 	"github.com/openimsdk/tools/discovery" | ||||||
| @ -40,6 +42,8 @@ type Config struct { | |||||||
| 	API       config.API | 	API       config.API | ||||||
| 	Share     config.Share | 	Share     config.Share | ||||||
| 	Discovery config.Discovery | 	Discovery config.Discovery | ||||||
|  | 
 | ||||||
|  | 	RuntimeEnv string | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func Start(ctx context.Context, index int, config *Config) error { | 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 | 		return err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	config.RuntimeEnv = runtimeenv.PrintRuntimeEnvironment() | ||||||
|  | 
 | ||||||
| 	var client discovery.SvcDiscoveryRegistry | 	var client discovery.SvcDiscoveryRegistry | ||||||
| 
 | 
 | ||||||
| 	// Determine whether zk is passed according to whether it is a clustered deployment | 	// 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 { | 	if err != nil { | ||||||
| 		return errs.WrapMsg(err, "failed to register discovery service") | 		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)) | 	address := net.JoinHostPort(network.GetListenIP(config.API.Api.ListenIP), strconv.Itoa(apiPort)) | ||||||
| 
 | 
 | ||||||
| 	server := http.Server{Addr: address, Handler: router} | 	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() { | 	go func() { | ||||||
| 		err = server.ListenAndServe() | 		err = server.ListenAndServe() | ||||||
| 		if err != nil && err != http.ErrServerClosed { | 		if err != nil && err != http.ErrServerClosed { | ||||||
|  | |||||||
| @ -57,14 +57,14 @@ func newGinRouter(disCov discovery.SvcDiscoveryRegistry, config *Config) *gin.En | |||||||
| 		_ = v.RegisterValidation("required_if", RequiredIf) | 		_ = v.RegisterValidation("required_if", RequiredIf) | ||||||
| 	} | 	} | ||||||
| 	// init rpc client here | 	// init rpc client here | ||||||
| 	userRpc := rpcclient.NewUser(disCov, config.Share.RpcRegisterName.User, config.Share.RpcRegisterName.MessageGateway, | 	userRpc := rpcclient.NewUser(disCov, config.Discovery.RpcService.User, config.Discovery.RpcService.MessageGateway, | ||||||
| 		config.Share.IMAdminUserID) | 		config.Share.IMAdminUserID) | ||||||
| 	groupRpc := rpcclient.NewGroup(disCov, config.Share.RpcRegisterName.Group) | 	groupRpc := rpcclient.NewGroup(disCov, config.Discovery.RpcService.Group) | ||||||
| 	friendRpc := rpcclient.NewFriend(disCov, config.Share.RpcRegisterName.Friend) | 	friendRpc := rpcclient.NewFriend(disCov, config.Discovery.RpcService.Friend) | ||||||
| 	messageRpc := rpcclient.NewMessage(disCov, config.Share.RpcRegisterName.Msg) | 	messageRpc := rpcclient.NewMessage(disCov, config.Discovery.RpcService.Msg) | ||||||
| 	conversationRpc := rpcclient.NewConversation(disCov, config.Share.RpcRegisterName.Conversation) | 	conversationRpc := rpcclient.NewConversation(disCov, config.Discovery.RpcService.Conversation) | ||||||
| 	authRpc := rpcclient.NewAuth(disCov, config.Share.RpcRegisterName.Auth) | 	authRpc := rpcclient.NewAuth(disCov, config.Discovery.RpcService.Auth) | ||||||
| 	thirdRpc := rpcclient.NewThird(disCov, config.Share.RpcRegisterName.Third, config.API.Prometheus.GrafanaURL) | 	thirdRpc := rpcclient.NewThird(disCov, config.Discovery.RpcService.Third, config.API.Prometheus.GrafanaURL) | ||||||
| 	switch config.API.Api.CompressionLevel { | 	switch config.API.Api.CompressionLevel { | ||||||
| 	case NoCompression: | 	case NoCompression: | ||||||
| 	case DefaultCompression: | 	case DefaultCompression: | ||||||
|  | |||||||
| @ -37,7 +37,7 @@ import ( | |||||||
| func (s *Server) InitServer(ctx context.Context, config *Config, disCov discovery.SvcDiscoveryRegistry, server *grpc.Server) error { | func (s *Server) InitServer(ctx context.Context, config *Config, disCov discovery.SvcDiscoveryRegistry, server *grpc.Server) error { | ||||||
| 	s.LongConnServer.SetDiscoveryRegistry(disCov, config) | 	s.LongConnServer.SetDiscoveryRegistry(disCov, config) | ||||||
| 	msggateway.RegisterMsgGatewayServer(server, s) | 	msggateway.RegisterMsgGatewayServer(server, s) | ||||||
| 	s.userRcp = rpcclient.NewUserRpcClient(disCov, config.Share.RpcRegisterName.User, config.Share.IMAdminUserID) | 	s.userRcp = rpcclient.NewUserRpcClient(disCov, config.Discovery.RpcService.User, config.Share.IMAdminUserID) | ||||||
| 	if s.ready != nil { | 	if s.ready != nil { | ||||||
| 		return s.ready(s) | 		return s.ready(s) | ||||||
| 	} | 	} | ||||||
| @ -47,8 +47,8 @@ func (s *Server) InitServer(ctx context.Context, config *Config, disCov discover | |||||||
| func (s *Server) Start(ctx context.Context, index int, conf *Config) error { | func (s *Server) Start(ctx context.Context, index int, conf *Config) error { | ||||||
| 	return startrpc.Start(ctx, &conf.Discovery, &conf.MsgGateway.Prometheus, conf.MsgGateway.ListenIP, | 	return startrpc.Start(ctx, &conf.Discovery, &conf.MsgGateway.Prometheus, conf.MsgGateway.ListenIP, | ||||||
| 		conf.MsgGateway.RPC.RegisterIP, | 		conf.MsgGateway.RPC.RegisterIP, | ||||||
| 		conf.MsgGateway.RPC.Ports, index, | 		conf.MsgGateway.RPC.AutoSetPorts, conf.MsgGateway.RPC.Ports, index, | ||||||
| 		conf.Share.RpcRegisterName.MessageGateway, | 		conf.Discovery.RpcService.MessageGateway, | ||||||
| 		&conf.Share, | 		&conf.Share, | ||||||
| 		conf, | 		conf, | ||||||
| 		s.InitServer, | 		s.InitServer, | ||||||
| @ -57,7 +57,7 @@ func (s *Server) Start(ctx context.Context, index int, conf *Config) error { | |||||||
| 
 | 
 | ||||||
| type Server struct { | type Server struct { | ||||||
| 	msggateway.UnimplementedMsgGatewayServer | 	msggateway.UnimplementedMsgGatewayServer | ||||||
| 	rpcPort        int | 
 | ||||||
| 	LongConnServer LongConnServer | 	LongConnServer LongConnServer | ||||||
| 	config         *Config | 	config         *Config | ||||||
| 	pushTerminal   map[int]struct{} | 	pushTerminal   map[int]struct{} | ||||||
| @ -70,9 +70,8 @@ func (s *Server) SetLongConnServer(LongConnServer LongConnServer) { | |||||||
| 	s.LongConnServer = LongConnServer | 	s.LongConnServer = LongConnServer | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func NewServer(rpcPort int, longConnServer LongConnServer, conf *Config, ready func(srv *Server) error) *Server { | func NewServer(longConnServer LongConnServer, conf *Config, ready func(srv *Server) error) *Server { | ||||||
| 	s := &Server{ | 	s := &Server{ | ||||||
| 		rpcPort:        rpcPort, |  | ||||||
| 		LongConnServer: longConnServer, | 		LongConnServer: longConnServer, | ||||||
| 		pushTerminal:   make(map[int]struct{}), | 		pushTerminal:   make(map[int]struct{}), | ||||||
| 		config:         conf, | 		config:         conf, | ||||||
|  | |||||||
| @ -16,11 +16,13 @@ package msggateway | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
|  | 	"time" | ||||||
|  | 
 | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpccache" | 	"github.com/openimsdk/open-im-server/v3/pkg/rpccache" | ||||||
| 	"github.com/openimsdk/tools/db/redisutil" | 	"github.com/openimsdk/tools/db/redisutil" | ||||||
| 	"github.com/openimsdk/tools/utils/datautil" | 	"github.com/openimsdk/tools/utils/datautil" | ||||||
| 	"time" | 	"github.com/openimsdk/tools/utils/runtimeenv" | ||||||
| 
 | 
 | ||||||
| 	"github.com/openimsdk/tools/log" | 	"github.com/openimsdk/tools/log" | ||||||
| ) | ) | ||||||
| @ -31,20 +33,22 @@ type Config struct { | |||||||
| 	RedisConfig    config.Redis | 	RedisConfig    config.Redis | ||||||
| 	WebhooksConfig config.Webhooks | 	WebhooksConfig config.Webhooks | ||||||
| 	Discovery      config.Discovery | 	Discovery      config.Discovery | ||||||
|  | 
 | ||||||
|  | 	RuntimeEnv string | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Start run ws server. | // Start run ws server. | ||||||
| func Start(ctx context.Context, index int, conf *Config) error { | func Start(ctx context.Context, index int, conf *Config) error { | ||||||
| 	log.CInfo(ctx, "MSG-GATEWAY server is initializing", "rpcPorts", conf.MsgGateway.RPC.Ports, | 	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", conf.MsgGateway.LongConnSvr.Ports, "prometheusPorts", conf.MsgGateway.Prometheus.Ports) | ||||||
| 	wsPort, err := datautil.GetElemByIndex(conf.MsgGateway.LongConnSvr.Ports, index) | 	wsPort, err := datautil.GetElemByIndex(conf.MsgGateway.LongConnSvr.Ports, index) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	rpcPort, err := datautil.GetElemByIndex(conf.MsgGateway.RPC.Ports, index) | 
 | ||||||
| 	if err != nil { |  | ||||||
| 		return err |  | ||||||
| 	} |  | ||||||
| 	rdb, err := redisutil.NewRedisClient(ctx, conf.RedisConfig.Build()) | 	rdb, err := redisutil.NewRedisClient(ctx, conf.RedisConfig.Build()) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| @ -57,7 +61,7 @@ func Start(ctx context.Context, index int, conf *Config) error { | |||||||
| 		WithMessageMaxMsgLength(conf.MsgGateway.LongConnSvr.WebsocketMaxMsgLen), | 		WithMessageMaxMsgLength(conf.MsgGateway.LongConnSvr.WebsocketMaxMsgLen), | ||||||
| 	) | 	) | ||||||
| 
 | 
 | ||||||
| 	hubServer := NewServer(rpcPort, longServer, conf, func(srv *Server) error { | 	hubServer := NewServer(longServer, conf, func(srv *Server) error { | ||||||
| 		longServer.online, _ = rpccache.NewOnlineCache(srv.userRcp, nil, rdb, false, longServer.subscriberUserOnlineStatusChanges) | 		longServer.online, _ = rpccache.NewOnlineCache(srv.userRcp, nil, rdb, false, longServer.subscriberUserOnlineStatusChanges) | ||||||
| 		return nil | 		return nil | ||||||
| 	}) | 	}) | ||||||
|  | |||||||
| @ -120,7 +120,7 @@ type GrpcHandler struct { | |||||||
| 	validate     *validator.Validate | 	validate     *validator.Validate | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func NewGrpcHandler(validate *validator.Validate, client discovery.SvcDiscoveryRegistry, rpcRegisterName *config.RpcRegisterName) *GrpcHandler { | func NewGrpcHandler(validate *validator.Validate, client discovery.SvcDiscoveryRegistry, rpcRegisterName *config.RpcService) *GrpcHandler { | ||||||
| 	msgRpcClient := rpcclient.NewMessageRpcClient(client, rpcRegisterName.Msg) | 	msgRpcClient := rpcclient.NewMessageRpcClient(client, rpcRegisterName.Msg) | ||||||
| 	pushRpcClient := rpcclient.NewPushRpcClient(client, rpcRegisterName.Push) | 	pushRpcClient := rpcclient.NewPushRpcClient(client, rpcRegisterName.Push) | ||||||
| 	return &GrpcHandler{ | 	return &GrpcHandler{ | ||||||
|  | |||||||
| @ -72,9 +72,9 @@ type kickHandler struct { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (ws *WsServer) SetDiscoveryRegistry(disCov discovery.SvcDiscoveryRegistry, config *Config) { | func (ws *WsServer) SetDiscoveryRegistry(disCov discovery.SvcDiscoveryRegistry, config *Config) { | ||||||
| 	ws.MessageHandler = NewGrpcHandler(ws.validate, disCov, &config.Share.RpcRegisterName) | 	ws.MessageHandler = NewGrpcHandler(ws.validate, disCov, &config.Discovery.RpcService) | ||||||
| 	u := rpcclient.NewUserRpcClient(disCov, config.Share.RpcRegisterName.User, config.Share.IMAdminUserID) | 	u := rpcclient.NewUserRpcClient(disCov, config.Discovery.RpcService.User, config.Share.IMAdminUserID) | ||||||
| 	ws.authClient = rpcclient.NewAuth(disCov, config.Share.RpcRegisterName.Auth) | 	ws.authClient = rpcclient.NewAuth(disCov, config.Discovery.RpcService.Auth) | ||||||
| 	ws.userClient = &u | 	ws.userClient = &u | ||||||
| 	ws.disCov = disCov | 	ws.disCov = disCov | ||||||
| } | } | ||||||
| @ -113,7 +113,7 @@ func NewWsServer(msgGatewayConfig *Config, opts ...Option) *WsServer { | |||||||
| 	for _, o := range opts { | 	for _, o := range opts { | ||||||
| 		o(&config) | 		o(&config) | ||||||
| 	} | 	} | ||||||
| 	//userRpcClient := rpcclient.NewUserRpcClient(client, config.Share.RpcRegisterName.User, config.Share.IMAdminUserID) | 	//userRpcClient := rpcclient.NewUserRpcClient(client, config.Discovery.RpcService.User, config.Share.IMAdminUserID) | ||||||
| 
 | 
 | ||||||
| 	v := validator.New() | 	v := validator.New() | ||||||
| 	return &WsServer{ | 	return &WsServer{ | ||||||
| @ -192,7 +192,7 @@ func (ws *WsServer) Run(done chan error) error { | |||||||
| var concurrentRequest = 3 | var concurrentRequest = 3 | ||||||
| 
 | 
 | ||||||
| func (ws *WsServer) sendUserOnlineInfoToOtherNode(ctx context.Context, client *Client) error { | func (ws *WsServer) sendUserOnlineInfoToOtherNode(ctx context.Context, client *Client) error { | ||||||
| 	conns, err := ws.disCov.GetConns(ctx, ws.msgGatewayConfig.Share.RpcRegisterName.MessageGateway) | 	conns, err := ws.disCov.GetConns(ctx, ws.msgGatewayConfig.Discovery.RpcService.MessageGateway) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -29,6 +29,7 @@ import ( | |||||||
| 	"github.com/openimsdk/tools/db/mongoutil" | 	"github.com/openimsdk/tools/db/mongoutil" | ||||||
| 	"github.com/openimsdk/tools/db/redisutil" | 	"github.com/openimsdk/tools/db/redisutil" | ||||||
| 	"github.com/openimsdk/tools/utils/datautil" | 	"github.com/openimsdk/tools/utils/datautil" | ||||||
|  | 	"github.com/openimsdk/tools/utils/runtimeenv" | ||||||
| 
 | 
 | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||||
| 	discRegister "github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister" | 	discRegister "github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister" | ||||||
| @ -51,6 +52,8 @@ type MsgTransfer struct { | |||||||
| 	historyMongoCH *OnlineHistoryMongoConsumerHandler | 	historyMongoCH *OnlineHistoryMongoConsumerHandler | ||||||
| 	ctx            context.Context | 	ctx            context.Context | ||||||
| 	cancel         context.CancelFunc | 	cancel         context.CancelFunc | ||||||
|  | 
 | ||||||
|  | 	runTimeEnv string | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| type Config struct { | type Config struct { | ||||||
| @ -64,7 +67,9 @@ type Config struct { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func Start(ctx context.Context, index int, config *Config) error { | 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) | 		config.MsgTransfer.Prometheus.Ports, "index", index) | ||||||
| 
 | 
 | ||||||
| 	mgocli, err := mongoutil.NewMongoDB(ctx, config.MongodbConfig.Build()) | 	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 { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	client, err := discRegister.NewDiscoveryRegister(&config.Discovery, &config.Share) | 	client, err := discRegister.NewDiscoveryRegister(&config.Discovery, runTimeEnv) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| @ -101,8 +106,8 @@ func Start(ctx context.Context, index int, config *Config) error { | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	conversationRpcClient := rpcclient.NewConversationRpcClient(client, config.Share.RpcRegisterName.Conversation) | 	conversationRpcClient := rpcclient.NewConversationRpcClient(client, config.Discovery.RpcService.Conversation) | ||||||
| 	groupRpcClient := rpcclient.NewGroupRpcClient(client, config.Share.RpcRegisterName.Group) | 	groupRpcClient := rpcclient.NewGroupRpcClient(client, config.Discovery.RpcService.Group) | ||||||
| 	historyCH, err := NewOnlineHistoryRedisConsumerHandler(&config.KafkaConfig, msgTransferDatabase, &conversationRpcClient, &groupRpcClient) | 	historyCH, err := NewOnlineHistoryRedisConsumerHandler(&config.KafkaConfig, msgTransferDatabase, &conversationRpcClient, &groupRpcClient) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| @ -115,6 +120,7 @@ func Start(ctx context.Context, index int, config *Config) error { | |||||||
| 	msgTransfer := &MsgTransfer{ | 	msgTransfer := &MsgTransfer{ | ||||||
| 		historyCH:      historyCH, | 		historyCH:      historyCH, | ||||||
| 		historyMongoCH: historyMongoCH, | 		historyMongoCH: historyMongoCH, | ||||||
|  | 		runTimeEnv:     runTimeEnv, | ||||||
| 	} | 	} | ||||||
| 	return msgTransfer.Start(index, config) | 	return msgTransfer.Start(index, config) | ||||||
| } | } | ||||||
|  | |||||||
| @ -60,7 +60,7 @@ func NewDefaultAllNode(disCov discovery.SvcDiscoveryRegistry, config *Config) *D | |||||||
| 
 | 
 | ||||||
| func (d *DefaultAllNode) GetConnsAndOnlinePush(ctx context.Context, msg *sdkws.MsgData, | func (d *DefaultAllNode) GetConnsAndOnlinePush(ctx context.Context, msg *sdkws.MsgData, | ||||||
| 	pushToUserIDs []string) (wsResults []*msggateway.SingleMsgToUserResults, err error) { | 	pushToUserIDs []string) (wsResults []*msggateway.SingleMsgToUserResults, err error) { | ||||||
| 	conns, err := d.disCov.GetConns(ctx, d.config.Share.RpcRegisterName.MessageGateway) | 	conns, err := d.disCov.GetConns(ctx, d.config.Discovery.RpcService.MessageGateway) | ||||||
| 	if len(conns) == 0 { | 	if len(conns) == 0 { | ||||||
| 		log.ZWarn(ctx, "get gateway conn 0 ", nil) | 		log.ZWarn(ctx, "get gateway conn 0 ", nil) | ||||||
| 	} else { | 	} else { | ||||||
|  | |||||||
| @ -58,14 +58,14 @@ func NewConsumerHandler(config *Config, database controller.PushDatabase, offlin | |||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	userRpcClient := rpcclient.NewUserRpcClient(client, config.Share.RpcRegisterName.User, config.Share.IMAdminUserID) | 	userRpcClient := rpcclient.NewUserRpcClient(client, config.Discovery.RpcService.User, config.Share.IMAdminUserID) | ||||||
| 
 | 
 | ||||||
| 	consumerHandler.offlinePusher = offlinePusher | 	consumerHandler.offlinePusher = offlinePusher | ||||||
| 	consumerHandler.onlinePusher = NewOnlinePusher(client, config) | 	consumerHandler.onlinePusher = NewOnlinePusher(client, config) | ||||||
| 	consumerHandler.groupRpcClient = rpcclient.NewGroupRpcClient(client, config.Share.RpcRegisterName.Group) | 	consumerHandler.groupRpcClient = rpcclient.NewGroupRpcClient(client, config.Discovery.RpcService.Group) | ||||||
| 	consumerHandler.groupLocalCache = rpccache.NewGroupLocalCache(consumerHandler.groupRpcClient, &config.LocalCacheConfig, rdb) | 	consumerHandler.groupLocalCache = rpccache.NewGroupLocalCache(consumerHandler.groupRpcClient, &config.LocalCacheConfig, rdb) | ||||||
| 	consumerHandler.msgRpcClient = rpcclient.NewMessageRpcClient(client, config.Share.RpcRegisterName.Msg) | 	consumerHandler.msgRpcClient = rpcclient.NewMessageRpcClient(client, config.Discovery.RpcService.Msg) | ||||||
| 	consumerHandler.conversationRpcClient = rpcclient.NewConversationRpcClient(client, config.Share.RpcRegisterName.Conversation) | 	consumerHandler.conversationRpcClient = rpcclient.NewConversationRpcClient(client, config.Discovery.RpcService.Conversation) | ||||||
| 	consumerHandler.conversationLocalCache = rpccache.NewConversationLocalCache(consumerHandler.conversationRpcClient, &config.LocalCacheConfig, rdb) | 	consumerHandler.conversationLocalCache = rpccache.NewConversationLocalCache(consumerHandler.conversationRpcClient, &config.LocalCacheConfig, rdb) | ||||||
| 	consumerHandler.webhookClient = webhook.NewWebhookClient(config.WebhooksConfig.URL) | 	consumerHandler.webhookClient = webhook.NewWebhookClient(config.WebhooksConfig.URL) | ||||||
| 	consumerHandler.config = config | 	consumerHandler.config = config | ||||||
|  | |||||||
| @ -59,7 +59,7 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	userRpcClient := rpcclient.NewUserRpcClient(client, config.Share.RpcRegisterName.User, config.Share.IMAdminUserID) | 	userRpcClient := rpcclient.NewUserRpcClient(client, config.Discovery.RpcService.User, config.Share.IMAdminUserID) | ||||||
| 	pbauth.RegisterAuthServer(server, &authServer{ | 	pbauth.RegisterAuthServer(server, &authServer{ | ||||||
| 		userRpcClient:  &userRpcClient, | 		userRpcClient:  &userRpcClient, | ||||||
| 		RegisterCenter: client, | 		RegisterCenter: client, | ||||||
| @ -182,7 +182,7 @@ func (s *authServer) ForceLogout(ctx context.Context, req *pbauth.ForceLogoutReq | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (s *authServer) forceKickOff(ctx context.Context, userID string, platformID int32) error { | func (s *authServer) forceKickOff(ctx context.Context, userID string, platformID int32) error { | ||||||
| 	conns, err := s.RegisterCenter.GetConns(ctx, s.config.Share.RpcRegisterName.MessageGateway) | 	conns, err := s.RegisterCenter.GetConns(ctx, s.config.Discovery.RpcService.MessageGateway) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -16,6 +16,8 @@ package conversation | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
|  | 	"github.com/openimsdk/open-im-server/v3/pkg/msgprocessor" | ||||||
|  | 	pbmsg "github.com/openimsdk/protocol/msg" | ||||||
| 	"sort" | 	"sort" | ||||||
| 	"time" | 	"time" | ||||||
| 
 | 
 | ||||||
| @ -76,9 +78,9 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	groupRpcClient := rpcclient.NewGroupRpcClient(client, config.Share.RpcRegisterName.Group) | 	groupRpcClient := rpcclient.NewGroupRpcClient(client, config.Discovery.RpcService.Group) | ||||||
| 	msgRpcClient := rpcclient.NewMessageRpcClient(client, config.Share.RpcRegisterName.Msg) | 	msgRpcClient := rpcclient.NewMessageRpcClient(client, config.Discovery.RpcService.Msg) | ||||||
| 	userRpcClient := rpcclient.NewUserRpcClient(client, config.Share.RpcRegisterName.User, config.Share.IMAdminUserID) | 	userRpcClient := rpcclient.NewUserRpcClient(client, config.Discovery.RpcService.User, config.Share.IMAdminUserID) | ||||||
| 	localcache.InitLocalCache(&config.LocalCacheConfig) | 	localcache.InitLocalCache(&config.LocalCacheConfig) | ||||||
| 	pbconversation.RegisterConversationServer(server, &conversationServer{ | 	pbconversation.RegisterConversationServer(server, &conversationServer{ | ||||||
| 		msgRpcClient:                   &msgRpcClient, | 		msgRpcClient:                   &msgRpcClient, | ||||||
| @ -433,23 +435,38 @@ func (c *conversationServer) CreateGroupChatConversations(ctx context.Context, r | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
|  | 	conversationID := msgprocessor.GetConversationIDBySessionType(constant.ReadGroupChatType, req.GroupID) | ||||||
|  | 	if _, err := c.msgRpcClient.Client.SetUserConversationMaxSeq(ctx, &pbmsg.SetUserConversationMaxSeqReq{ConversationID: conversationID, OwnerUserID: req.UserIDs, MaxSeq: 0}); err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
| 	return &pbconversation.CreateGroupChatConversationsResp{}, nil | 	return &pbconversation.CreateGroupChatConversationsResp{}, nil | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (c *conversationServer) SetConversationMaxSeq(ctx context.Context, req *pbconversation.SetConversationMaxSeqReq) (*pbconversation.SetConversationMaxSeqResp, error) { | func (c *conversationServer) SetConversationMaxSeq(ctx context.Context, req *pbconversation.SetConversationMaxSeqReq) (*pbconversation.SetConversationMaxSeqResp, error) { | ||||||
|  | 	if _, err := c.msgRpcClient.Client.SetUserConversationMaxSeq(ctx, &pbmsg.SetUserConversationMaxSeqReq{ConversationID: req.ConversationID, OwnerUserID: req.OwnerUserID, MaxSeq: req.MaxSeq}); err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
| 	if err := c.conversationDatabase.UpdateUsersConversationField(ctx, req.OwnerUserID, req.ConversationID, | 	if err := c.conversationDatabase.UpdateUsersConversationField(ctx, req.OwnerUserID, req.ConversationID, | ||||||
| 		map[string]any{"max_seq": req.MaxSeq}); err != nil { | 		map[string]any{"max_seq": req.MaxSeq}); err != nil { | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
| 
 | 	for _, userID := range req.OwnerUserID { | ||||||
|  | 		c.conversationNotificationSender.ConversationChangeNotification(ctx, userID, []string{req.ConversationID}) | ||||||
|  | 	} | ||||||
| 	return &pbconversation.SetConversationMaxSeqResp{}, nil | 	return &pbconversation.SetConversationMaxSeqResp{}, nil | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (c *conversationServer) SetConversationMinSeq(ctx context.Context, req *pbconversation.SetConversationMinSeqReq) (*pbconversation.SetConversationMinSeqResp, error) { | func (c *conversationServer) SetConversationMinSeq(ctx context.Context, req *pbconversation.SetConversationMinSeqReq) (*pbconversation.SetConversationMinSeqResp, error) { | ||||||
|  | 	if _, err := c.msgRpcClient.Client.SetUserConversationMinSeq(ctx, &pbmsg.SetUserConversationMinSeqReq{ConversationID: req.ConversationID, OwnerUserID: req.OwnerUserID, MinSeq: req.MinSeq}); err != nil { | ||||||
|  | 		return nil, err | ||||||
|  | 	} | ||||||
| 	if err := c.conversationDatabase.UpdateUsersConversationField(ctx, req.OwnerUserID, req.ConversationID, | 	if err := c.conversationDatabase.UpdateUsersConversationField(ctx, req.OwnerUserID, req.ConversationID, | ||||||
| 		map[string]any{"min_seq": req.MinSeq}); err != nil { | 		map[string]any{"min_seq": req.MinSeq}); err != nil { | ||||||
| 		return nil, err | 		return nil, err | ||||||
| 	} | 	} | ||||||
|  | 	for _, userID := range req.OwnerUserID { | ||||||
|  | 		c.conversationNotificationSender.ConversationChangeNotification(ctx, userID, []string{req.ConversationID}) | ||||||
|  | 	} | ||||||
| 	return &pbconversation.SetConversationMinSeqResp{}, nil | 	return &pbconversation.SetConversationMinSeqResp{}, nil | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -99,9 +99,9 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	userRpcClient := rpcclient.NewUserRpcClient(client, config.Share.RpcRegisterName.User, config.Share.IMAdminUserID) | 	userRpcClient := rpcclient.NewUserRpcClient(client, config.Discovery.RpcService.User, config.Share.IMAdminUserID) | ||||||
| 	msgRpcClient := rpcclient.NewMessageRpcClient(client, config.Share.RpcRegisterName.Msg) | 	msgRpcClient := rpcclient.NewMessageRpcClient(client, config.Discovery.RpcService.Msg) | ||||||
| 	conversationRpcClient := rpcclient.NewConversationRpcClient(client, config.Share.RpcRegisterName.Conversation) | 	conversationRpcClient := rpcclient.NewConversationRpcClient(client, config.Discovery.RpcService.Conversation) | ||||||
| 	var gs groupServer | 	var gs groupServer | ||||||
| 	database := controller.NewGroupDatabase(rdb, &config.LocalCacheConfig, groupDB, groupMemberDB, groupRequestDB, mgocli.GetTx(), grouphash.NewGroupHashFromGroupServer(&gs)) | 	database := controller.NewGroupDatabase(rdb, &config.LocalCacheConfig, groupDB, groupMemberDB, groupRequestDB, mgocli.GetTx(), grouphash.NewGroupHashFromGroupServer(&gs)) | ||||||
| 	gs.db = database | 	gs.db = database | ||||||
| @ -964,7 +964,6 @@ func (g *groupServer) deleteMemberAndSetConversationSeq(ctx context.Context, gro | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 
 |  | ||||||
| 	return g.conversationRpcClient.SetConversationMaxSeq(ctx, userIDs, conevrsationID, maxSeq) | 	return g.conversationRpcClient.SetConversationMaxSeq(ctx, userIDs, conevrsationID, maxSeq) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -84,3 +84,21 @@ func (m *msgServer) GetActiveConversation(ctx context.Context, req *pbmsg.GetAct | |||||||
| 	} | 	} | ||||||
| 	return &pbmsg.GetActiveConversationResp{Conversations: conversations}, nil | 	return &pbmsg.GetActiveConversationResp{Conversations: conversations}, nil | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | func (m *msgServer) SetUserConversationMaxSeq(ctx context.Context, req *pbmsg.SetUserConversationMaxSeqReq) (*pbmsg.SetUserConversationMaxSeqResp, error) { | ||||||
|  | 	for _, userID := range req.OwnerUserID { | ||||||
|  | 		if err := m.MsgDatabase.SetUserConversationsMaxSeq(ctx, req.ConversationID, userID, req.MaxSeq); err != nil { | ||||||
|  | 			return nil, err | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	return &pbmsg.SetUserConversationMaxSeqResp{}, nil | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (m *msgServer) SetUserConversationMinSeq(ctx context.Context, req *pbmsg.SetUserConversationMinSeqReq) (*pbmsg.SetUserConversationMinSeqResp, error) { | ||||||
|  | 	for _, userID := range req.OwnerUserID { | ||||||
|  | 		if err := m.MsgDatabase.SetUserConversationsMinSeq(ctx, req.ConversationID, userID, req.MinSeq); err != nil { | ||||||
|  | 			return nil, err | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 	return &pbmsg.SetUserConversationMinSeqResp{}, nil | ||||||
|  | } | ||||||
|  | |||||||
| @ -16,7 +16,6 @@ package msg | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
| 
 |  | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache/redis" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache/redis" | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/database/mgo" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/database/mgo" | ||||||
| @ -90,10 +89,10 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | |||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 	msgModel := redis.NewMsgCache(rdb) | 	msgModel := redis.NewMsgCache(rdb) | ||||||
| 	conversationClient := rpcclient.NewConversationRpcClient(client, config.Share.RpcRegisterName.Conversation) | 	conversationClient := rpcclient.NewConversationRpcClient(client, config.Discovery.RpcService.Conversation) | ||||||
| 	userRpcClient := rpcclient.NewUserRpcClient(client, config.Share.RpcRegisterName.User, config.Share.IMAdminUserID) | 	userRpcClient := rpcclient.NewUserRpcClient(client, config.Discovery.RpcService.User, config.Share.IMAdminUserID) | ||||||
| 	groupRpcClient := rpcclient.NewGroupRpcClient(client, config.Share.RpcRegisterName.Group) | 	groupRpcClient := rpcclient.NewGroupRpcClient(client, config.Discovery.RpcService.Group) | ||||||
| 	friendRpcClient := rpcclient.NewFriendRpcClient(client, config.Share.RpcRegisterName.Friend) | 	friendRpcClient := rpcclient.NewFriendRpcClient(client, config.Discovery.RpcService.Friend) | ||||||
| 	seqConversation, err := mgo.NewSeqConversationMongo(mgocli.GetDB()) | 	seqConversation, err := mgo.NewSeqConversationMongo(mgocli.GetDB()) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
|  | |||||||
| @ -93,8 +93,8 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | |||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Initialize RPC clients | 	// Initialize RPC clients | ||||||
| 	userRpcClient := rpcclient.NewUserRpcClient(client, config.Share.RpcRegisterName.User, config.Share.IMAdminUserID) | 	userRpcClient := rpcclient.NewUserRpcClient(client, config.Discovery.RpcService.User, config.Share.IMAdminUserID) | ||||||
| 	msgRpcClient := rpcclient.NewMessageRpcClient(client, config.Share.RpcRegisterName.Msg) | 	msgRpcClient := rpcclient.NewMessageRpcClient(client, config.Discovery.RpcService.Msg) | ||||||
| 
 | 
 | ||||||
| 	// Initialize notification sender | 	// Initialize notification sender | ||||||
| 	notificationSender := NewFriendNotificationSender( | 	notificationSender := NewFriendNotificationSender( | ||||||
| @ -119,7 +119,7 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | |||||||
| 		userRpcClient:         &userRpcClient, | 		userRpcClient:         &userRpcClient, | ||||||
| 		notificationSender:    notificationSender, | 		notificationSender:    notificationSender, | ||||||
| 		RegisterCenter:        client, | 		RegisterCenter:        client, | ||||||
| 		conversationRpcClient: rpcclient.NewConversationRpcClient(client, config.Share.RpcRegisterName.Conversation), | 		conversationRpcClient: rpcclient.NewConversationRpcClient(client, config.Discovery.RpcService.Conversation), | ||||||
| 		config:                config, | 		config:                config, | ||||||
| 		webhookClient:         webhook.NewWebhookClient(config.WebhooksConfig.URL), | 		webhookClient:         webhook.NewWebhookClient(config.WebhooksConfig.URL), | ||||||
| 		queue:                 memamq.NewMemoryQueue(16, 1024*1024), | 		queue:                 memamq.NewMemoryQueue(16, 1024*1024), | ||||||
|  | |||||||
| @ -55,7 +55,7 @@ func (t *thirdServer) UploadLogs(ctx context.Context, req *third.UploadLogsReq) | |||||||
| 			CreateTime: time.Now(), | 			CreateTime: time.Now(), | ||||||
| 			Url:        fileURL.URL, | 			Url:        fileURL.URL, | ||||||
| 			FileName:   fileURL.Filename, | 			FileName:   fileURL.Filename, | ||||||
| 			SystemType: req.SystemType, | 			SystemType: req.AppFramework, | ||||||
| 			Version:    req.Version, | 			Version:    req.Version, | ||||||
| 			Ex:         req.Ex, | 			Ex:         req.Ex, | ||||||
| 		} | 		} | ||||||
|  | |||||||
| @ -21,6 +21,8 @@ import ( | |||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache/redis" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache/redis" | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/database/mgo" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/database/mgo" | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/localcache" | 	"github.com/openimsdk/open-im-server/v3/pkg/localcache" | ||||||
|  | 	"github.com/openimsdk/tools/s3/aws" | ||||||
|  | 	"github.com/openimsdk/tools/s3/kodo" | ||||||
| 	"time" | 	"time" | ||||||
| 
 | 
 | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/controller" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/controller" | ||||||
| @ -31,7 +33,6 @@ import ( | |||||||
| 	"github.com/openimsdk/tools/discovery" | 	"github.com/openimsdk/tools/discovery" | ||||||
| 	"github.com/openimsdk/tools/s3" | 	"github.com/openimsdk/tools/s3" | ||||||
| 	"github.com/openimsdk/tools/s3/cos" | 	"github.com/openimsdk/tools/s3/cos" | ||||||
| 	"github.com/openimsdk/tools/s3/kodo" |  | ||||||
| 	"github.com/openimsdk/tools/s3/minio" | 	"github.com/openimsdk/tools/s3/minio" | ||||||
| 	"github.com/openimsdk/tools/s3/oss" | 	"github.com/openimsdk/tools/s3/oss" | ||||||
| 	"google.golang.org/grpc" | 	"google.golang.org/grpc" | ||||||
| @ -92,6 +93,8 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | |||||||
| 		o, err = oss.NewOSS(*config.RpcConfig.Object.Oss.Build()) | 		o, err = oss.NewOSS(*config.RpcConfig.Object.Oss.Build()) | ||||||
| 	case "kodo": | 	case "kodo": | ||||||
| 		o, err = kodo.NewKodo(*config.RpcConfig.Object.Kodo.Build()) | 		o, err = kodo.NewKodo(*config.RpcConfig.Object.Kodo.Build()) | ||||||
|  | 	case "aws": | ||||||
|  | 		o, err = aws.NewAws(*config.RpcConfig.Object.Aws.Build()) | ||||||
| 	default: | 	default: | ||||||
| 		err = fmt.Errorf("invalid object enable: %s", enable) | 		err = fmt.Errorf("invalid object enable: %s", enable) | ||||||
| 	} | 	} | ||||||
| @ -101,7 +104,7 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | |||||||
| 	localcache.InitLocalCache(&config.LocalCacheConfig) | 	localcache.InitLocalCache(&config.LocalCacheConfig) | ||||||
| 	third.RegisterThirdServer(server, &thirdServer{ | 	third.RegisterThirdServer(server, &thirdServer{ | ||||||
| 		thirdDatabase: controller.NewThirdDatabase(redis.NewThirdCache(rdb), logdb), | 		thirdDatabase: controller.NewThirdDatabase(redis.NewThirdCache(rdb), logdb), | ||||||
| 		userRpcClient: rpcclient.NewUserRpcClient(client, config.Share.RpcRegisterName.User, config.Share.IMAdminUserID), | 		userRpcClient: rpcclient.NewUserRpcClient(client, config.Discovery.RpcService.User, config.Share.IMAdminUserID), | ||||||
| 		s3dataBase:    controller.NewS3Database(rdb, o, s3db), | 		s3dataBase:    controller.NewS3Database(rdb, o, s3db), | ||||||
| 		defaultExpire: time.Hour * 24 * 7, | 		defaultExpire: time.Hour * 24 * 7, | ||||||
| 		config:        config, | 		config:        config, | ||||||
|  | |||||||
| @ -96,9 +96,9 @@ func Start(ctx context.Context, config *Config, client registry.SvcDiscoveryRegi | |||||||
| 	} | 	} | ||||||
| 	userCache := redis.NewUserCacheRedis(rdb, &config.LocalCacheConfig, userDB, redis.GetRocksCacheOptions()) | 	userCache := redis.NewUserCacheRedis(rdb, &config.LocalCacheConfig, userDB, redis.GetRocksCacheOptions()) | ||||||
| 	database := controller.NewUserDatabase(userDB, userCache, mgocli.GetTx()) | 	database := controller.NewUserDatabase(userDB, userCache, mgocli.GetTx()) | ||||||
| 	friendRpcClient := rpcclient.NewFriendRpcClient(client, config.Share.RpcRegisterName.Friend) | 	friendRpcClient := rpcclient.NewFriendRpcClient(client, config.Discovery.RpcService.Friend) | ||||||
| 	groupRpcClient := rpcclient.NewGroupRpcClient(client, config.Share.RpcRegisterName.Group) | 	groupRpcClient := rpcclient.NewGroupRpcClient(client, config.Discovery.RpcService.Group) | ||||||
| 	msgRpcClient := rpcclient.NewMessageRpcClient(client, config.Share.RpcRegisterName.Msg) | 	msgRpcClient := rpcclient.NewMessageRpcClient(client, config.Discovery.RpcService.Msg) | ||||||
| 	localcache.InitLocalCache(&config.LocalCacheConfig) | 	localcache.InitLocalCache(&config.LocalCacheConfig) | ||||||
| 	u := &userServer{ | 	u := &userServer{ | ||||||
| 		online:                   redis.NewUserOnline(rdb), | 		online:                   redis.NewUserOnline(rdb), | ||||||
|  | |||||||
| @ -1,17 +1,3 @@ | |||||||
| // 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. |  | ||||||
| 
 |  | ||||||
| package tools | package tools | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| @ -28,6 +14,7 @@ import ( | |||||||
| 
 | 
 | ||||||
| 	"github.com/openimsdk/tools/mcontext" | 	"github.com/openimsdk/tools/mcontext" | ||||||
| 	"github.com/openimsdk/tools/mw" | 	"github.com/openimsdk/tools/mw" | ||||||
|  | 	"github.com/openimsdk/tools/utils/runtimeenv" | ||||||
| 	"google.golang.org/grpc" | 	"google.golang.org/grpc" | ||||||
| 	"google.golang.org/grpc/credentials/insecure" | 	"google.golang.org/grpc/credentials/insecure" | ||||||
| 
 | 
 | ||||||
| @ -40,31 +27,35 @@ type CronTaskConfig struct { | |||||||
| 	CronTask  config.CronTask | 	CronTask  config.CronTask | ||||||
| 	Share     config.Share | 	Share     config.Share | ||||||
| 	Discovery config.Discovery | 	Discovery config.Discovery | ||||||
|  | 
 | ||||||
|  | 	runTimeEnv string | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func Start(ctx context.Context, config *CronTaskConfig) error { | 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 { | 	if config.CronTask.RetainChatRecords < 1 { | ||||||
| 		return errs.New("msg destruct time must be greater than 1").Wrap() | 		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 { | 	if err != nil { | ||||||
| 		return errs.WrapMsg(err, "failed to register discovery service") | 		return errs.WrapMsg(err, "failed to register discovery service") | ||||||
| 	} | 	} | ||||||
| 	client.AddOption(mw.GrpcClient(), grpc.WithTransportCredentials(insecure.NewCredentials())) | 	client.AddOption(mw.GrpcClient(), grpc.WithTransportCredentials(insecure.NewCredentials())) | ||||||
| 	ctx = mcontext.SetOpUserID(ctx, config.Share.IMAdminUserID[0]) | 	ctx = mcontext.SetOpUserID(ctx, config.Share.IMAdminUserID[0]) | ||||||
| 
 | 
 | ||||||
| 	msgConn, err := client.GetConn(ctx, config.Share.RpcRegisterName.Msg) | 	msgConn, err := client.GetConn(ctx, config.Discovery.RpcService.Msg) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	thirdConn, err := client.GetConn(ctx, config.Share.RpcRegisterName.Third) | 	thirdConn, err := client.GetConn(ctx, config.Discovery.RpcService.Third) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	conversationConn, err := client.GetConn(ctx, config.Share.RpcRegisterName.Conversation) | 	conversationConn, err := client.GetConn(ctx, config.Discovery.RpcService.Conversation) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -55,6 +55,6 @@ func (a *AuthRpcCmd) Exec() error { | |||||||
| 
 | 
 | ||||||
| func (a *AuthRpcCmd) runE() error { | func (a *AuthRpcCmd) runE() error { | ||||||
| 	return startrpc.Start(a.ctx, &a.authConfig.Discovery, &a.authConfig.RpcConfig.Prometheus, a.authConfig.RpcConfig.RPC.ListenIP, | 	return startrpc.Start(a.ctx, &a.authConfig.Discovery, &a.authConfig.RpcConfig.Prometheus, a.authConfig.RpcConfig.RPC.ListenIP, | ||||||
| 		a.authConfig.RpcConfig.RPC.RegisterIP, a.authConfig.RpcConfig.RPC.Ports, | 		a.authConfig.RpcConfig.RPC.RegisterIP, a.authConfig.RpcConfig.RPC.AutoSetPorts, a.authConfig.RpcConfig.RPC.Ports, | ||||||
| 		a.Index(), a.authConfig.Share.RpcRegisterName.Auth, &a.authConfig.Share, a.authConfig, auth.Start) | 		a.Index(), a.authConfig.Discovery.RpcService.Auth, &a.authConfig.Share, a.authConfig, auth.Start) | ||||||
| } | } | ||||||
|  | |||||||
| @ -57,6 +57,6 @@ func (a *ConversationRpcCmd) Exec() error { | |||||||
| 
 | 
 | ||||||
| func (a *ConversationRpcCmd) runE() error { | func (a *ConversationRpcCmd) runE() error { | ||||||
| 	return startrpc.Start(a.ctx, &a.conversationConfig.Discovery, &a.conversationConfig.RpcConfig.Prometheus, a.conversationConfig.RpcConfig.RPC.ListenIP, | 	return startrpc.Start(a.ctx, &a.conversationConfig.Discovery, &a.conversationConfig.RpcConfig.Prometheus, a.conversationConfig.RpcConfig.RPC.ListenIP, | ||||||
| 		a.conversationConfig.RpcConfig.RPC.RegisterIP, a.conversationConfig.RpcConfig.RPC.Ports, | 		a.conversationConfig.RpcConfig.RPC.RegisterIP, a.conversationConfig.RpcConfig.RPC.AutoSetPorts, a.conversationConfig.RpcConfig.RPC.Ports, | ||||||
| 		a.Index(), a.conversationConfig.Share.RpcRegisterName.Conversation, &a.conversationConfig.Share, a.conversationConfig, conversation.Start) | 		a.Index(), a.conversationConfig.Discovery.RpcService.Conversation, &a.conversationConfig.Share, a.conversationConfig, conversation.Start) | ||||||
| } | } | ||||||
|  | |||||||
| @ -58,6 +58,6 @@ func (a *FriendRpcCmd) Exec() error { | |||||||
| 
 | 
 | ||||||
| func (a *FriendRpcCmd) runE() error { | func (a *FriendRpcCmd) runE() error { | ||||||
| 	return startrpc.Start(a.ctx, &a.relationConfig.Discovery, &a.relationConfig.RpcConfig.Prometheus, a.relationConfig.RpcConfig.RPC.ListenIP, | 	return startrpc.Start(a.ctx, &a.relationConfig.Discovery, &a.relationConfig.RpcConfig.Prometheus, a.relationConfig.RpcConfig.RPC.ListenIP, | ||||||
| 		a.relationConfig.RpcConfig.RPC.RegisterIP, a.relationConfig.RpcConfig.RPC.Ports, | 		a.relationConfig.RpcConfig.RPC.RegisterIP, a.relationConfig.RpcConfig.RPC.AutoSetPorts, a.relationConfig.RpcConfig.RPC.Ports, | ||||||
| 		a.Index(), a.relationConfig.Share.RpcRegisterName.Friend, &a.relationConfig.Share, a.relationConfig, relation.Start) | 		a.Index(), a.relationConfig.Discovery.RpcService.Friend, &a.relationConfig.Share, a.relationConfig, relation.Start) | ||||||
| } | } | ||||||
|  | |||||||
| @ -59,6 +59,6 @@ func (a *GroupRpcCmd) Exec() error { | |||||||
| 
 | 
 | ||||||
| func (a *GroupRpcCmd) runE() error { | func (a *GroupRpcCmd) runE() error { | ||||||
| 	return startrpc.Start(a.ctx, &a.groupConfig.Discovery, &a.groupConfig.RpcConfig.Prometheus, a.groupConfig.RpcConfig.RPC.ListenIP, | 	return startrpc.Start(a.ctx, &a.groupConfig.Discovery, &a.groupConfig.RpcConfig.Prometheus, a.groupConfig.RpcConfig.RPC.ListenIP, | ||||||
| 		a.groupConfig.RpcConfig.RPC.RegisterIP, a.groupConfig.RpcConfig.RPC.Ports, | 		a.groupConfig.RpcConfig.RPC.RegisterIP, a.groupConfig.RpcConfig.RPC.AutoSetPorts, a.groupConfig.RpcConfig.RPC.Ports, | ||||||
| 		a.Index(), a.groupConfig.Share.RpcRegisterName.Group, &a.groupConfig.Share, a.groupConfig, group.Start, versionctx.EnableVersionCtx()) | 		a.Index(), a.groupConfig.Discovery.RpcService.Group, &a.groupConfig.Share, a.groupConfig, group.Start, versionctx.EnableVersionCtx()) | ||||||
| } | } | ||||||
|  | |||||||
| @ -59,6 +59,6 @@ func (a *MsgRpcCmd) Exec() error { | |||||||
| 
 | 
 | ||||||
| func (a *MsgRpcCmd) runE() error { | func (a *MsgRpcCmd) runE() error { | ||||||
| 	return startrpc.Start(a.ctx, &a.msgConfig.Discovery, &a.msgConfig.RpcConfig.Prometheus, a.msgConfig.RpcConfig.RPC.ListenIP, | 	return startrpc.Start(a.ctx, &a.msgConfig.Discovery, &a.msgConfig.RpcConfig.Prometheus, a.msgConfig.RpcConfig.RPC.ListenIP, | ||||||
| 		a.msgConfig.RpcConfig.RPC.RegisterIP, a.msgConfig.RpcConfig.RPC.Ports, | 		a.msgConfig.RpcConfig.RPC.RegisterIP, a.msgConfig.RpcConfig.RPC.AutoSetPorts, a.msgConfig.RpcConfig.RPC.Ports, | ||||||
| 		a.Index(), a.msgConfig.Share.RpcRegisterName.Msg, &a.msgConfig.Share, a.msgConfig, msg.Start) | 		a.Index(), a.msgConfig.Discovery.RpcService.Msg, &a.msgConfig.Share, a.msgConfig, msg.Start) | ||||||
| } | } | ||||||
|  | |||||||
| @ -59,6 +59,6 @@ func (a *PushRpcCmd) Exec() error { | |||||||
| 
 | 
 | ||||||
| func (a *PushRpcCmd) runE() error { | func (a *PushRpcCmd) runE() error { | ||||||
| 	return startrpc.Start(a.ctx, &a.pushConfig.Discovery, &a.pushConfig.RpcConfig.Prometheus, a.pushConfig.RpcConfig.RPC.ListenIP, | 	return startrpc.Start(a.ctx, &a.pushConfig.Discovery, &a.pushConfig.RpcConfig.Prometheus, a.pushConfig.RpcConfig.RPC.ListenIP, | ||||||
| 		a.pushConfig.RpcConfig.RPC.RegisterIP, a.pushConfig.RpcConfig.RPC.Ports, | 		a.pushConfig.RpcConfig.RPC.RegisterIP, a.pushConfig.RpcConfig.RPC.AutoSetPorts, a.pushConfig.RpcConfig.RPC.Ports, | ||||||
| 		a.Index(), a.pushConfig.Share.RpcRegisterName.Push, &a.pushConfig.Share, a.pushConfig, push.Start) | 		a.Index(), a.pushConfig.Discovery.RpcService.Push, &a.pushConfig.Share, a.pushConfig, push.Start) | ||||||
| } | } | ||||||
|  | |||||||
| @ -21,6 +21,7 @@ import ( | |||||||
| 	"github.com/openimsdk/open-im-server/v3/version" | 	"github.com/openimsdk/open-im-server/v3/version" | ||||||
| 	"github.com/openimsdk/tools/errs" | 	"github.com/openimsdk/tools/errs" | ||||||
| 	"github.com/openimsdk/tools/log" | 	"github.com/openimsdk/tools/log" | ||||||
|  | 	"github.com/openimsdk/tools/utils/runtimeenv" | ||||||
| 	"github.com/spf13/cobra" | 	"github.com/spf13/cobra" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| @ -104,16 +105,19 @@ func (r *RootCmd) initializeConfiguration(cmd *cobra.Command, opts *CmdOpts) err | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	runtimeEnv := runtimeenv.PrintRuntimeEnvironment() | ||||||
|  | 
 | ||||||
| 	// Load common configuration file | 	// Load common configuration file | ||||||
| 	//opts.configMap[ShareFileName] = StructEnvPrefix{EnvPrefix: shareEnvPrefix, ConfigStruct: &r.share} | 	//opts.configMap[ShareFileName] = StructEnvPrefix{EnvPrefix: shareEnvPrefix, ConfigStruct: &r.share} | ||||||
| 	for configFileName, configStruct := range opts.configMap { | 	for configFileName, configStruct := range opts.configMap { | ||||||
| 		err := config.Load(configDirectory, configFileName, ConfigEnvPrefixMap[configFileName], configStruct) | 		err := config.Load(configDirectory, configFileName, ConfigEnvPrefixMap[configFileName], runtimeEnv, configStruct) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return err | 			return err | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	// Load common log configuration file | 	// Load common log configuration file | ||||||
| 	return config.Load(configDirectory, LogConfigFileName, ConfigEnvPrefixMap[LogConfigFileName], &r.log) | 	return config.Load(configDirectory, LogConfigFileName, ConfigEnvPrefixMap[LogConfigFileName], runtimeEnv, &r.log) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (r *RootCmd) applyOptions(opts ...func(*CmdOpts)) *CmdOpts { | func (r *RootCmd) applyOptions(opts ...func(*CmdOpts)) *CmdOpts { | ||||||
|  | |||||||
| @ -58,6 +58,6 @@ func (a *ThirdRpcCmd) Exec() error { | |||||||
| 
 | 
 | ||||||
| func (a *ThirdRpcCmd) runE() error { | func (a *ThirdRpcCmd) runE() error { | ||||||
| 	return startrpc.Start(a.ctx, &a.thirdConfig.Discovery, &a.thirdConfig.RpcConfig.Prometheus, a.thirdConfig.RpcConfig.RPC.ListenIP, | 	return startrpc.Start(a.ctx, &a.thirdConfig.Discovery, &a.thirdConfig.RpcConfig.Prometheus, a.thirdConfig.RpcConfig.RPC.ListenIP, | ||||||
| 		a.thirdConfig.RpcConfig.RPC.RegisterIP, a.thirdConfig.RpcConfig.RPC.Ports, | 		a.thirdConfig.RpcConfig.RPC.RegisterIP, a.thirdConfig.RpcConfig.RPC.AutoSetPorts, a.thirdConfig.RpcConfig.RPC.Ports, | ||||||
| 		a.Index(), a.thirdConfig.Share.RpcRegisterName.Third, &a.thirdConfig.Share, a.thirdConfig, third.Start) | 		a.Index(), a.thirdConfig.Discovery.RpcService.Third, &a.thirdConfig.Share, a.thirdConfig, third.Start) | ||||||
| } | } | ||||||
|  | |||||||
| @ -59,6 +59,6 @@ func (a *UserRpcCmd) Exec() error { | |||||||
| 
 | 
 | ||||||
| func (a *UserRpcCmd) runE() error { | func (a *UserRpcCmd) runE() error { | ||||||
| 	return startrpc.Start(a.ctx, &a.userConfig.Discovery, &a.userConfig.RpcConfig.Prometheus, a.userConfig.RpcConfig.RPC.ListenIP, | 	return startrpc.Start(a.ctx, &a.userConfig.Discovery, &a.userConfig.RpcConfig.Prometheus, a.userConfig.RpcConfig.RPC.ListenIP, | ||||||
| 		a.userConfig.RpcConfig.RPC.RegisterIP, a.userConfig.RpcConfig.RPC.Ports, | 		a.userConfig.RpcConfig.RPC.RegisterIP, a.userConfig.RpcConfig.RPC.AutoSetPorts, a.userConfig.RpcConfig.RPC.Ports, | ||||||
| 		a.Index(), a.userConfig.Share.RpcRegisterName.User, &a.userConfig.Share, a.userConfig, user.Start) | 		a.Index(), a.userConfig.Discovery.RpcService.User, &a.userConfig.Share, a.userConfig, user.Start) | ||||||
| } | } | ||||||
|  | |||||||
| @ -18,6 +18,8 @@ import ( | |||||||
| 	"strings" | 	"strings" | ||||||
| 	"time" | 	"time" | ||||||
| 
 | 
 | ||||||
|  | 	"github.com/openimsdk/tools/s3/aws" | ||||||
|  | 
 | ||||||
| 	"github.com/openimsdk/tools/db/mongoutil" | 	"github.com/openimsdk/tools/db/mongoutil" | ||||||
| 	"github.com/openimsdk/tools/db/redisutil" | 	"github.com/openimsdk/tools/db/redisutil" | ||||||
| 	"github.com/openimsdk/tools/mq/kafka" | 	"github.com/openimsdk/tools/mq/kafka" | ||||||
| @ -177,6 +179,7 @@ type Prometheus struct { | |||||||
| type MsgGateway struct { | type MsgGateway struct { | ||||||
| 	RPC struct { | 	RPC struct { | ||||||
| 		RegisterIP   string `mapstructure:"registerIP"` | 		RegisterIP   string `mapstructure:"registerIP"` | ||||||
|  | 		AutoSetPorts bool   `mapstructure:"autoSetPorts"` | ||||||
| 		Ports        []int  `mapstructure:"ports"` | 		Ports        []int  `mapstructure:"ports"` | ||||||
| 	} `mapstructure:"rpc"` | 	} `mapstructure:"rpc"` | ||||||
| 	Prometheus  Prometheus `mapstructure:"prometheus"` | 	Prometheus  Prometheus `mapstructure:"prometheus"` | ||||||
| @ -197,6 +200,7 @@ type Push struct { | |||||||
| 	RPC struct { | 	RPC struct { | ||||||
| 		RegisterIP   string `mapstructure:"registerIP"` | 		RegisterIP   string `mapstructure:"registerIP"` | ||||||
| 		ListenIP     string `mapstructure:"listenIP"` | 		ListenIP     string `mapstructure:"listenIP"` | ||||||
|  | 		AutoSetPorts bool   `mapstructure:"autoSetPorts"` | ||||||
| 		Ports        []int  `mapstructure:"ports"` | 		Ports        []int  `mapstructure:"ports"` | ||||||
| 	} `mapstructure:"rpc"` | 	} `mapstructure:"rpc"` | ||||||
| 	Prometheus           Prometheus `mapstructure:"prometheus"` | 	Prometheus           Prometheus `mapstructure:"prometheus"` | ||||||
| @ -232,6 +236,7 @@ type Auth struct { | |||||||
| 	RPC struct { | 	RPC struct { | ||||||
| 		RegisterIP   string `mapstructure:"registerIP"` | 		RegisterIP   string `mapstructure:"registerIP"` | ||||||
| 		ListenIP     string `mapstructure:"listenIP"` | 		ListenIP     string `mapstructure:"listenIP"` | ||||||
|  | 		AutoSetPorts bool   `mapstructure:"autoSetPorts"` | ||||||
| 		Ports        []int  `mapstructure:"ports"` | 		Ports        []int  `mapstructure:"ports"` | ||||||
| 	} `mapstructure:"rpc"` | 	} `mapstructure:"rpc"` | ||||||
| 	Prometheus  Prometheus `mapstructure:"prometheus"` | 	Prometheus  Prometheus `mapstructure:"prometheus"` | ||||||
| @ -244,6 +249,7 @@ type Conversation struct { | |||||||
| 	RPC struct { | 	RPC struct { | ||||||
| 		RegisterIP   string `mapstructure:"registerIP"` | 		RegisterIP   string `mapstructure:"registerIP"` | ||||||
| 		ListenIP     string `mapstructure:"listenIP"` | 		ListenIP     string `mapstructure:"listenIP"` | ||||||
|  | 		AutoSetPorts bool   `mapstructure:"autoSetPorts"` | ||||||
| 		Ports        []int  `mapstructure:"ports"` | 		Ports        []int  `mapstructure:"ports"` | ||||||
| 	} `mapstructure:"rpc"` | 	} `mapstructure:"rpc"` | ||||||
| 	Prometheus Prometheus `mapstructure:"prometheus"` | 	Prometheus Prometheus `mapstructure:"prometheus"` | ||||||
| @ -253,6 +259,7 @@ type Friend struct { | |||||||
| 	RPC struct { | 	RPC struct { | ||||||
| 		RegisterIP   string `mapstructure:"registerIP"` | 		RegisterIP   string `mapstructure:"registerIP"` | ||||||
| 		ListenIP     string `mapstructure:"listenIP"` | 		ListenIP     string `mapstructure:"listenIP"` | ||||||
|  | 		AutoSetPorts bool   `mapstructure:"autoSetPorts"` | ||||||
| 		Ports        []int  `mapstructure:"ports"` | 		Ports        []int  `mapstructure:"ports"` | ||||||
| 	} `mapstructure:"rpc"` | 	} `mapstructure:"rpc"` | ||||||
| 	Prometheus Prometheus `mapstructure:"prometheus"` | 	Prometheus Prometheus `mapstructure:"prometheus"` | ||||||
| @ -262,6 +269,7 @@ type Group struct { | |||||||
| 	RPC struct { | 	RPC struct { | ||||||
| 		RegisterIP   string `mapstructure:"registerIP"` | 		RegisterIP   string `mapstructure:"registerIP"` | ||||||
| 		ListenIP     string `mapstructure:"listenIP"` | 		ListenIP     string `mapstructure:"listenIP"` | ||||||
|  | 		AutoSetPorts bool   `mapstructure:"autoSetPorts"` | ||||||
| 		Ports        []int  `mapstructure:"ports"` | 		Ports        []int  `mapstructure:"ports"` | ||||||
| 	} `mapstructure:"rpc"` | 	} `mapstructure:"rpc"` | ||||||
| 	Prometheus                 Prometheus `mapstructure:"prometheus"` | 	Prometheus                 Prometheus `mapstructure:"prometheus"` | ||||||
| @ -272,6 +280,7 @@ type Msg struct { | |||||||
| 	RPC struct { | 	RPC struct { | ||||||
| 		RegisterIP   string `mapstructure:"registerIP"` | 		RegisterIP   string `mapstructure:"registerIP"` | ||||||
| 		ListenIP     string `mapstructure:"listenIP"` | 		ListenIP     string `mapstructure:"listenIP"` | ||||||
|  | 		AutoSetPorts bool   `mapstructure:"autoSetPorts"` | ||||||
| 		Ports        []int  `mapstructure:"ports"` | 		Ports        []int  `mapstructure:"ports"` | ||||||
| 	} `mapstructure:"rpc"` | 	} `mapstructure:"rpc"` | ||||||
| 	Prometheus   Prometheus `mapstructure:"prometheus"` | 	Prometheus   Prometheus `mapstructure:"prometheus"` | ||||||
| @ -282,6 +291,7 @@ type Third struct { | |||||||
| 	RPC struct { | 	RPC struct { | ||||||
| 		RegisterIP   string `mapstructure:"registerIP"` | 		RegisterIP   string `mapstructure:"registerIP"` | ||||||
| 		ListenIP     string `mapstructure:"listenIP"` | 		ListenIP     string `mapstructure:"listenIP"` | ||||||
|  | 		AutoSetPorts bool   `mapstructure:"autoSetPorts"` | ||||||
| 		Ports        []int  `mapstructure:"ports"` | 		Ports        []int  `mapstructure:"ports"` | ||||||
| 	} `mapstructure:"rpc"` | 	} `mapstructure:"rpc"` | ||||||
| 	Prometheus Prometheus `mapstructure:"prometheus"` | 	Prometheus Prometheus `mapstructure:"prometheus"` | ||||||
| @ -290,14 +300,7 @@ type Third struct { | |||||||
| 		Cos    Cos    `mapstructure:"cos"` | 		Cos    Cos    `mapstructure:"cos"` | ||||||
| 		Oss    Oss    `mapstructure:"oss"` | 		Oss    Oss    `mapstructure:"oss"` | ||||||
| 		Kodo   Kodo   `mapstructure:"kodo"` | 		Kodo   Kodo   `mapstructure:"kodo"` | ||||||
| 		Aws    struct { | 		Aws    Aws    `mapstructure:"aws"` | ||||||
| 			Endpoint        string `mapstructure:"endpoint"` |  | ||||||
| 			Region          string `mapstructure:"region"` |  | ||||||
| 			Bucket          string `mapstructure:"bucket"` |  | ||||||
| 			AccessKeyID     string `mapstructure:"accessKeyID"` |  | ||||||
| 			AccessKeySecret string `mapstructure:"accessKeySecret"` |  | ||||||
| 			PublicRead      bool   `mapstructure:"publicRead"` |  | ||||||
| 		} `mapstructure:"aws"` |  | ||||||
| 	} `mapstructure:"object"` | 	} `mapstructure:"object"` | ||||||
| } | } | ||||||
| type Cos struct { | type Cos struct { | ||||||
| @ -327,10 +330,20 @@ type Kodo struct { | |||||||
| 	PublicRead      bool   `mapstructure:"publicRead"` | 	PublicRead      bool   `mapstructure:"publicRead"` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | type Aws struct { | ||||||
|  | 	Region          string `mapstructure:"region"` | ||||||
|  | 	Bucket          string `mapstructure:"bucket"` | ||||||
|  | 	AccessKeyID     string `mapstructure:"accessKeyID"` | ||||||
|  | 	SecretAccessKey string `mapstructure:"secretAccessKey"` | ||||||
|  | 	SessionToken    string `mapstructure:"sessionToken"` | ||||||
|  | 	PublicRead      bool   `mapstructure:"publicRead"` | ||||||
|  | } | ||||||
|  | 
 | ||||||
| type User struct { | type User struct { | ||||||
| 	RPC struct { | 	RPC struct { | ||||||
| 		RegisterIP   string `mapstructure:"registerIP"` | 		RegisterIP   string `mapstructure:"registerIP"` | ||||||
| 		ListenIP     string `mapstructure:"listenIP"` | 		ListenIP     string `mapstructure:"listenIP"` | ||||||
|  | 		AutoSetPorts bool   `mapstructure:"autoSetPorts"` | ||||||
| 		Ports        []int  `mapstructure:"ports"` | 		Ports        []int  `mapstructure:"ports"` | ||||||
| 	} `mapstructure:"rpc"` | 	} `mapstructure:"rpc"` | ||||||
| 	Prometheus Prometheus `mapstructure:"prometheus"` | 	Prometheus Prometheus `mapstructure:"prometheus"` | ||||||
| @ -364,7 +377,6 @@ type AfterConfig struct { | |||||||
| 
 | 
 | ||||||
| type Share struct { | type Share struct { | ||||||
| 	Secret        string     `mapstructure:"secret"` | 	Secret        string     `mapstructure:"secret"` | ||||||
| 	RpcRegisterName RpcRegisterName `mapstructure:"rpcRegisterName"` |  | ||||||
| 	IMAdminUserID []string   `mapstructure:"imAdminUserID"` | 	IMAdminUserID []string   `mapstructure:"imAdminUserID"` | ||||||
| 	MultiLogin    MultiLogin `mapstructure:"multiLogin"` | 	MultiLogin    MultiLogin `mapstructure:"multiLogin"` | ||||||
| } | } | ||||||
| @ -374,7 +386,7 @@ type MultiLogin struct { | |||||||
| 	MaxNumOneEnd int `mapstructure:"maxNumOneEnd"` | 	MaxNumOneEnd int `mapstructure:"maxNumOneEnd"` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| type RpcRegisterName struct { | type RpcService struct { | ||||||
| 	User           string `mapstructure:"user"` | 	User           string `mapstructure:"user"` | ||||||
| 	Friend         string `mapstructure:"friend"` | 	Friend         string `mapstructure:"friend"` | ||||||
| 	Msg            string `mapstructure:"msg"` | 	Msg            string `mapstructure:"msg"` | ||||||
| @ -386,7 +398,7 @@ type RpcRegisterName struct { | |||||||
| 	Third          string `mapstructure:"third"` | 	Third          string `mapstructure:"third"` | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (r *RpcRegisterName) GetServiceNames() []string { | func (r *RpcService) GetServiceNames() []string { | ||||||
| 	return []string{ | 	return []string{ | ||||||
| 		r.User, | 		r.User, | ||||||
| 		r.Friend, | 		r.Friend, | ||||||
| @ -463,7 +475,12 @@ type ZooKeeper struct { | |||||||
| type Discovery struct { | type Discovery struct { | ||||||
| 	Enable     string     `mapstructure:"enable"` | 	Enable     string     `mapstructure:"enable"` | ||||||
| 	Etcd       Etcd       `mapstructure:"etcd"` | 	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 { | type Etcd struct { | ||||||
| @ -533,6 +550,7 @@ func (m *Minio) Build() *minio.Config { | |||||||
| 		SignEndpoint:    formatEndpoint(m.ExternalAddress), | 		SignEndpoint:    formatEndpoint(m.ExternalAddress), | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | 
 | ||||||
| func (c *Cos) Build() *cos.Config { | func (c *Cos) Build() *cos.Config { | ||||||
| 	return &cos.Config{ | 	return &cos.Config{ | ||||||
| 		BucketURL:    c.BucketURL, | 		BucketURL:    c.BucketURL, | ||||||
| @ -567,6 +585,16 @@ func (o *Kodo) Build() *kodo.Config { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (o *Aws) Build() *aws.Config { | ||||||
|  | 	return &aws.Config{ | ||||||
|  | 		Region:          o.Region, | ||||||
|  | 		Bucket:          o.Bucket, | ||||||
|  | 		AccessKeyID:     o.AccessKeyID, | ||||||
|  | 		SecretAccessKey: o.SecretAccessKey, | ||||||
|  | 		SessionToken:    o.SessionToken, | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func (l *CacheConfig) Failed() time.Duration { | func (l *CacheConfig) Failed() time.Duration { | ||||||
| 	return time.Second * time.Duration(l.FailedExpire) | 	return time.Second * time.Duration(l.FailedExpire) | ||||||
| } | } | ||||||
|  | |||||||
| @ -10,15 +10,16 @@ import ( | |||||||
| 	"github.com/spf13/viper" | 	"github.com/spf13/viper" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| func Load(configDirectory string, configFileName string, envPrefix string, config any) error { | func Load(configDirectory string, configFileName string, envPrefix string, runtimeEnv string, config any) error { | ||||||
| 	if os.Getenv(DeploymentType) == KUBERNETES { | 	if runtimeEnv == KUBERNETES { | ||||||
| 		mountPath := os.Getenv(MountConfigFilePath) | 		mountPath := os.Getenv(MountConfigFilePath) | ||||||
| 		if mountPath == "" { | 		if mountPath == "" { | ||||||
| 			return errs.ErrArgs.WrapMsg(MountConfigFilePath + " env is empty") | 			return errs.ErrArgs.WrapMsg(MountConfigFilePath + " env is empty") | ||||||
| 		} | 		} | ||||||
| 		return loadConfigK8s(filepath.Join(mountPath, configFileName), envPrefix, config) |  | ||||||
| 
 | 
 | ||||||
|  | 		return loadConfig(filepath.Join(mountPath, configFileName), envPrefix, config) | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	return loadConfig(filepath.Join(configDirectory, configFileName), envPrefix, config) | 	return loadConfig(filepath.Join(configDirectory, configFileName), envPrefix, config) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,6 +1,7 @@ | |||||||
| package config | package config | ||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
|  | 	"os" | ||||||
| 	"testing" | 	"testing" | ||||||
| 
 | 
 | ||||||
| 	"github.com/stretchr/testify/assert" | 	"github.com/stretchr/testify/assert" | ||||||
| @ -8,21 +9,43 @@ import ( | |||||||
| 
 | 
 | ||||||
| func TestLoadLogConfig(t *testing.T) { | func TestLoadLogConfig(t *testing.T) { | ||||||
| 	var log Log | 	var log Log | ||||||
| 	err := Load("../../../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.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) { | func TestLoadMinioConfig(t *testing.T) { | ||||||
| 	var storageConfig Minio | 	var storageConfig Minio | ||||||
| 	err := Load("../../../config/minio.yml", "IMENV_MINIO", "", &storageConfig) | 	err := Load("../../../config/minio.yml", "IMENV_MINIO", "", "source", &storageConfig) | ||||||
| 	assert.Nil(t, err) | 	assert.Nil(t, err) | ||||||
| 	assert.Equal(t, "openim", storageConfig.Bucket) | 	assert.Equal(t, "openim", storageConfig.Bucket) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func TestLoadWebhooksConfig(t *testing.T) { | func TestLoadWebhooksConfig(t *testing.T) { | ||||||
| 	var webhooks Webhooks | 	var webhooks Webhooks | ||||||
| 	err := Load("../../../config/webhooks.yml", "IMENV_WEBHOOKS", "", &webhooks) | 	err := Load("../../../config/webhooks.yml", "IMENV_WEBHOOKS", "", "source", &webhooks) | ||||||
| 	assert.Nil(t, err) | 	assert.Nil(t, err) | ||||||
| 	assert.Equal(t, 5, webhooks.BeforeAddBlack.Timeout) | 	assert.Equal(t, 5, webhooks.BeforeAddBlack.Timeout) | ||||||
| 
 | 
 | ||||||
| @ -30,7 +53,7 @@ func TestLoadWebhooksConfig(t *testing.T) { | |||||||
| 
 | 
 | ||||||
| func TestLoadOpenIMRpcUserConfig(t *testing.T) { | func TestLoadOpenIMRpcUserConfig(t *testing.T) { | ||||||
| 	var user User | 	var user User | ||||||
| 	err := Load("../../../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) | 	assert.Nil(t, err) | ||||||
| 	//export IMENV_OPENIM_RPC_USER_RPC_LISTENIP="0.0.0.0" | 	//export IMENV_OPENIM_RPC_USER_RPC_LISTENIP="0.0.0.0" | ||||||
| 	assert.Equal(t, "0.0.0.0", user.RPC.ListenIP) | 	assert.Equal(t, "0.0.0.0", user.RPC.ListenIP) | ||||||
| @ -40,14 +63,14 @@ func TestLoadOpenIMRpcUserConfig(t *testing.T) { | |||||||
| 
 | 
 | ||||||
| func TestLoadNotificationConfig(t *testing.T) { | func TestLoadNotificationConfig(t *testing.T) { | ||||||
| 	var noti Notification | 	var noti Notification | ||||||
| 	err := Load("../../../config/notification.yml", "IMENV_NOTIFICATION", "", ¬i) | 	err := Load("../../../config/notification.yml", "IMENV_NOTIFICATION", "", "source", ¬i) | ||||||
| 	assert.Nil(t, err) | 	assert.Nil(t, err) | ||||||
| 	assert.Equal(t, "Your friend's profile has been changed", noti.FriendRemarkSet.OfflinePush.Title) | 	assert.Equal(t, "Your friend's profile has been changed", noti.FriendRemarkSet.OfflinePush.Title) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func TestLoadOpenIMThirdConfig(t *testing.T) { | func TestLoadOpenIMThirdConfig(t *testing.T) { | ||||||
| 	var third Third | 	var third Third | ||||||
| 	err := Load("../../../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.Nil(t, err) | ||||||
| 	assert.Equal(t, "enabled", third.Object.Enable) | 	assert.Equal(t, "enabled", third.Object.Enable) | ||||||
| 	assert.Equal(t, "https://oss-cn-chengdu.aliyuncs.com", third.Object.Oss.Endpoint) | 	assert.Equal(t, "https://oss-cn-chengdu.aliyuncs.com", third.Object.Oss.Endpoint) | ||||||
|  | |||||||
| @ -19,14 +19,20 @@ import ( | |||||||
| 
 | 
 | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||||
| 	"github.com/openimsdk/tools/discovery" | 	"github.com/openimsdk/tools/discovery" | ||||||
| 	"github.com/openimsdk/tools/discovery/etcd" | 
 | ||||||
| 	"github.com/openimsdk/tools/discovery/kubernetes" | 	"github.com/openimsdk/tools/discovery/kubernetes" | ||||||
|  | 
 | ||||||
|  | 	"github.com/openimsdk/tools/discovery/etcd" | ||||||
| 	"github.com/openimsdk/tools/discovery/zookeeper" | 	"github.com/openimsdk/tools/discovery/zookeeper" | ||||||
| 	"github.com/openimsdk/tools/errs" | 	"github.com/openimsdk/tools/errs" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| // NewDiscoveryRegister creates a new service discovery and registry client based on the provided environment type. | // 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 { | 	switch discovery.Enable { | ||||||
| 	case "zookeeper": | 	case "zookeeper": | ||||||
| 		return zookeeper.NewZkClient( | 		return zookeeper.NewZkClient( | ||||||
| @ -37,8 +43,8 @@ func NewDiscoveryRegister(discovery *config.Discovery, share *config.Share) (dis | |||||||
| 			zookeeper.WithRoundRobin(), | 			zookeeper.WithRoundRobin(), | ||||||
| 			zookeeper.WithTimeout(10), | 			zookeeper.WithTimeout(10), | ||||||
| 		) | 		) | ||||||
| 	case "kubernetes": | 	case "k8s": | ||||||
| 		return kubernetes.NewKubernetesConnManager("default") | 		return kubernetes.NewK8sDiscoveryRegister(share.RpcRegisterName.MessageGateway) | ||||||
| 	case "etcd": | 	case "etcd": | ||||||
| 		return etcd.NewSvcDiscoveryRegistry( | 		return etcd.NewSvcDiscoveryRegistry( | ||||||
| 			discovery.Etcd.RootDirectory, | 			discovery.Etcd.RootDirectory, | ||||||
|  | |||||||
| @ -16,184 +16,281 @@ package kubernetes | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
| 	"errors" |  | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"os" | 	"sync" | ||||||
| 	"strconv" | 	"time" | ||||||
| 	"strings" |  | ||||||
| 
 | 
 | ||||||
| 	"github.com/openimsdk/tools/discovery" |  | ||||||
| 	"github.com/openimsdk/tools/log" |  | ||||||
| 	"github.com/stathat/consistent" |  | ||||||
| 	"google.golang.org/grpc" | 	"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 KubernetesConnManager struct { | ||||||
| type K8sDR struct { | 	clientset   *kubernetes.Clientset | ||||||
| 	options               []grpc.DialOption | 	namespace   string | ||||||
| 	rpcRegisterAddr       string | 	dialOptions []grpc.DialOption | ||||||
| 	gatewayHostConsistent *consistent.Consistent | 
 | ||||||
| 	gatewayName           string | 	selfTarget string | ||||||
|  | 
 | ||||||
|  | 	mu      sync.RWMutex | ||||||
|  | 	connMap map[string][]*grpc.ClientConn | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func NewK8sDiscoveryRegister(gatewayName string) (discovery.SvcDiscoveryRegistry, error) { | // NewKubernetesConnManager creates a new connection manager that uses Kubernetes services for service discovery. | ||||||
| 	gatewayConsistent := consistent.New() | func NewKubernetesConnManager(namespace string, options ...grpc.DialOption) (*KubernetesConnManager, error) { | ||||||
| 	gatewayHosts := getMsgGatewayHost(context.Background(), gatewayName) | 	config, err := rest.InClusterConfig() | ||||||
| 	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) |  | ||||||
| 	if err != nil { | 	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 { | func (k *KubernetesConnManager) initializeConns(serviceName string) error { | ||||||
| 	port := 88 | 	port, err := k.getServicePort(serviceName) | ||||||
| 	instance := "openimserver" | 	if err != nil { | ||||||
| 	selfPodName := os.Getenv("MY_POD_NAME") | 		return err | ||||||
| 	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]) |  | ||||||
| 	} | 	} | ||||||
| 	podInfo := strings.Split(selfPodName, "-") | 
 | ||||||
| 	instance = podInfo[0] | 	endpoints, err := k.clientset.CoreV1().Endpoints(k.namespace).Get(context.Background(), serviceName, metav1.GetOptions{}) | ||||||
| 	count := len(podInfo) | 	if err != nil { | ||||||
| 	statefuleIndex, _ = strconv.Atoi(podInfo[count-1]) | 		return fmt.Errorf("failed to get endpoints for service %s: %v", serviceName, err) | ||||||
| 	host := fmt.Sprintf("%s-openim-msggateway-%d.%s-openim-msggateway-headless.%s.svc.cluster.local:%d", instance, statefuleIndex, instance, ns, port) | 	} | ||||||
| 	return host | 
 | ||||||
|  | 	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. | // GetConns returns gRPC client connections for a given Kubernetes service name. | ||||||
| // Replica set in kubernetes environment | func (k *KubernetesConnManager) GetConns(ctx context.Context, serviceName string, opts ...grpc.DialOption) ([]*grpc.ClientConn, error) { | ||||||
| func getMsgGatewayHost(ctx context.Context, gatewayName string) []string { | 	k.mu.RLock() | ||||||
| 	port := 88 | 	conns, exists := k.connMap[serviceName] | ||||||
| 	instance := "openimserver" | 	defer k.mu.RUnlock() | ||||||
| 	selfPodName := os.Getenv("MY_POD_NAME") | 
 | ||||||
| 	replicas := os.Getenv("MY_MSGGATEWAY_REPLICACOUNT") | 	if exists { | ||||||
| 	ns := os.Getenv("MY_POD_NAMESPACE") | 		return conns, nil | ||||||
| 	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]) |  | ||||||
| 	} | 	} | ||||||
| 	nReplicas, _ := strconv.Atoi(replicas) | 
 | ||||||
| 	podInfo := strings.Split(selfPodName, "-") | 	k.mu.Lock() | ||||||
| 	instance = podInfo[0] | 	defer k.mu.Unlock() | ||||||
| 	var ret []string | 
 | ||||||
| 	for i := 0; i < nReplicas; i++ { | 	// Check if another goroutine has already initialized the connections when we released the read lock | ||||||
| 		host := fmt.Sprintf("%s-openim-msggateway-%d.%s-openim-msggateway-headless.%s.svc.cluster.local:%d", instance, i, instance, ns, port) | 	conns, exists = k.connMap[serviceName] | ||||||
| 		ret = append(ret, host) | 	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. | // GetConn returns a single gRPC client connection for a given Kubernetes service name. | ||||||
| func (cli *K8sDR) GetConns(ctx context.Context, serviceName string, opts ...grpc.DialOption) ([]*grpc.ClientConn, error) { | func (k *KubernetesConnManager) GetConn(ctx context.Context, serviceName string, opts ...grpc.DialOption) (*grpc.ClientConn, error) { | ||||||
| 
 | 	port, err := k.getServicePort(serviceName) | ||||||
| 	// 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. |  | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, err | 		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) { | // GetSelfConnTarget returns the connection target for the current service. | ||||||
| 
 | func (k *KubernetesConnManager) GetSelfConnTarget() string { | ||||||
| 	return grpc.DialContext(ctx, serviceName, append(cli.options, opts...)...) | 	return k.selfTarget | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (cli *K8sDR) GetSelfConnTarget() string { | // AddOption appends gRPC dial options to the existing options. | ||||||
| 
 | func (k *KubernetesConnManager) AddOption(opts ...grpc.DialOption) { | ||||||
| 	return cli.rpcRegisterAddr | 	k.mu.Lock() | ||||||
|  | 	defer k.mu.Unlock() | ||||||
|  | 	k.dialOptions = append(k.dialOptions, opts...) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func (cli *K8sDR) AddOption(opts ...grpc.DialOption) { | // CloseConn closes a given gRPC client connection. | ||||||
| 	cli.options = append(cli.options, opts...) | func (k *KubernetesConnManager) CloseConn(conn *grpc.ClientConn) { | ||||||
| } |  | ||||||
| 
 |  | ||||||
| func (cli *K8sDR) CloseConn(conn *grpc.ClientConn) { |  | ||||||
| 	conn.Close() | 	conn.Close() | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // do not use this method for call rpc. | // Close closes all gRPC connections managed by KubernetesConnManager. | ||||||
| func (cli *K8sDR) GetClientLocalConns() map[string][]*grpc.ClientConn { | func (k *KubernetesConnManager) Close() { | ||||||
| 	log.ZError(context.Background(), "should not call this function!", nil) | 	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 | 	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) | ||||||
|  | // } | ||||||
|  | |||||||
| @ -42,25 +42,25 @@ func GetGrpcServerMetrics() *gp.ServerMetrics { | |||||||
| 	return grpcMetrics | 	return grpcMetrics | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func GetGrpcCusMetrics(registerName string, share *config.Share) []prometheus.Collector { | func GetGrpcCusMetrics(registerName string, discovery *config.Discovery) []prometheus.Collector { | ||||||
| 	switch registerName { | 	switch registerName { | ||||||
| 	case share.RpcRegisterName.MessageGateway: | 	case discovery.RpcService.MessageGateway: | ||||||
| 		return []prometheus.Collector{OnlineUserGauge} | 		return []prometheus.Collector{OnlineUserGauge} | ||||||
| 	case share.RpcRegisterName.Msg: | 	case discovery.RpcService.Msg: | ||||||
| 		return []prometheus.Collector{ | 		return []prometheus.Collector{ | ||||||
| 			SingleChatMsgProcessSuccessCounter, | 			SingleChatMsgProcessSuccessCounter, | ||||||
| 			SingleChatMsgProcessFailedCounter, | 			SingleChatMsgProcessFailedCounter, | ||||||
| 			GroupChatMsgProcessSuccessCounter, | 			GroupChatMsgProcessSuccessCounter, | ||||||
| 			GroupChatMsgProcessFailedCounter, | 			GroupChatMsgProcessFailedCounter, | ||||||
| 		} | 		} | ||||||
| 	case share.RpcRegisterName.Push: | 	case discovery.RpcService.Push: | ||||||
| 		return []prometheus.Collector{ | 		return []prometheus.Collector{ | ||||||
| 			MsgOfflinePushFailedCounter, | 			MsgOfflinePushFailedCounter, | ||||||
| 			MsgLoneTimePushCounter, | 			MsgLoneTimePushCounter, | ||||||
| 		} | 		} | ||||||
| 	case share.RpcRegisterName.Auth: | 	case discovery.RpcService.Auth: | ||||||
| 		return []prometheus.Collector{UserLoginCounter} | 		return []prometheus.Collector{UserLoginCounter} | ||||||
| 	case share.RpcRegisterName.User: | 	case discovery.RpcService.User: | ||||||
| 		return []prometheus.Collector{UserRegisterCounter} | 		return []prometheus.Collector{UserRegisterCounter} | ||||||
| 	default: | 	default: | ||||||
| 		return nil | 		return nil | ||||||
|  | |||||||
| @ -16,18 +16,22 @@ package startrpc | |||||||
| 
 | 
 | ||||||
| import ( | import ( | ||||||
| 	"context" | 	"context" | ||||||
|  | 	"errors" | ||||||
| 	"fmt" | 	"fmt" | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" |  | ||||||
| 	"github.com/openimsdk/tools/utils/datautil" |  | ||||||
| 	"google.golang.org/grpc/status" |  | ||||||
| 	"net" | 	"net" | ||||||
| 	"net/http" | 	"net/http" | ||||||
| 	"os" | 	"os" | ||||||
| 	"os/signal" | 	"os/signal" | ||||||
| 	"strconv" |  | ||||||
| 	"syscall" | 	"syscall" | ||||||
| 	"time" | 	"time" | ||||||
| 
 | 
 | ||||||
|  | 	"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" | 	kdisc "github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister" | ||||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/prommetrics" | 	"github.com/openimsdk/open-im-server/v3/pkg/common/prommetrics" | ||||||
| 	"github.com/openimsdk/tools/discovery" | 	"github.com/openimsdk/tools/discovery" | ||||||
| @ -41,17 +45,60 @@ import ( | |||||||
| 
 | 
 | ||||||
| // Start rpc server. | // Start rpc server. | ||||||
| func Start[T any](ctx context.Context, discovery *config.Discovery, prometheusConfig *config.Prometheus, listenIP, | func Start[T any](ctx context.Context, discovery *config.Discovery, prometheusConfig *config.Prometheus, listenIP, | ||||||
| 	registerIP string, rpcPorts []int, index int, rpcRegisterName string, share *config.Share, config T, rpcFn func(ctx context.Context, | 	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 { | 	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) | 		rpcPort, err := datautil.GetElemByIndex(rpcPorts, index) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return err | 			return err | ||||||
| 		} | 		} | ||||||
|  | 		rpcTcpAddr = net.JoinHostPort(network.GetListenIP(listenIP), strconv.Itoa(rpcPort)) | ||||||
|  | 	} else { | ||||||
|  | 		rpcTcpAddr = net.JoinHostPort(network.GetListenIP(listenIP), "0") | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	log.CInfo(ctx, "RPC server is initializing", "rpcRegisterName", rpcRegisterName, "rpcPort", rpcPort, | 	// var reg *prometheus.Registry | ||||||
| 		"prometheusPorts", prometheusConfig.Ports) | 	// var metric *grpcprometheus.ServerMetrics | ||||||
| 	rpcTcpAddr := net.JoinHostPort(network.GetListenIP(listenIP), strconv.Itoa(rpcPort)) | 	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()) | ||||||
|  | 	} | ||||||
| 
 | 
 | ||||||
| 	listener, err := net.Listen( | 	listener, err := net.Listen( | ||||||
| 		"tcp", | 		"tcp", | ||||||
| @ -60,34 +107,22 @@ func Start[T any](ctx context.Context, discovery *config.Discovery, prometheusCo | |||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return errs.WrapMsg(err, "listen err", "rpcTcpAddr", rpcTcpAddr) | 		return errs.WrapMsg(err, "listen err", "rpcTcpAddr", rpcTcpAddr) | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	_, portStr, _ := net.SplitHostPort(listener.Addr().String()) | ||||||
|  | 	registerIP = network.GetListenIP(registerIP) | ||||||
|  | 	port, _ := strconv.Atoi(portStr) | ||||||
|  | 
 | ||||||
|  | 	log.CInfo(ctx, "RPC server is initializing", "runTimeEnv", runTimeEnv, "rpcRegisterName", rpcRegisterName, "rpcPort", portStr, | ||||||
|  | 		"prometheusPorts", prometheusConfig.Ports) | ||||||
|  | 
 | ||||||
| 	defer listener.Close() | 	defer listener.Close() | ||||||
| 	client, err := kdisc.NewDiscoveryRegister(discovery, share) | 	client, err := kdisc.NewDiscoveryRegister(discovery, runTimeEnv) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	defer client.Close() | 	defer client.Close() | ||||||
| 	client.AddOption(mw.GrpcClient(), grpc.WithTransportCredentials(insecure.NewCredentials()), grpc.WithDefaultServiceConfig(fmt.Sprintf(`{"LoadBalancingPolicy": "%s"}`, "round_robin"))) | 	client.AddOption(mw.GrpcClient(), grpc.WithTransportCredentials(insecure.NewCredentials()), grpc.WithDefaultServiceConfig(fmt.Sprintf(`{"LoadBalancingPolicy": "%s"}`, "round_robin"))) | ||||||
| 	registerIP, err = network.GetRpcRegisterIP(registerIP) |  | ||||||
| 	if err != nil { |  | ||||||
| 		return err |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	//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), |  | ||||||
| 		) |  | ||||||
| 	} else { |  | ||||||
| 		options = append(options, mw.GrpcServer()) |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	srv := grpc.NewServer(options...) | 	srv := grpc.NewServer(options...) | ||||||
| 
 | 
 | ||||||
| @ -99,40 +134,13 @@ func Start[T any](ctx context.Context, discovery *config.Discovery, prometheusCo | |||||||
| 	err = client.Register( | 	err = client.Register( | ||||||
| 		rpcRegisterName, | 		rpcRegisterName, | ||||||
| 		registerIP, | 		registerIP, | ||||||
| 		rpcPort, | 		port, | ||||||
| 		grpc.WithTransportCredentials(insecure.NewCredentials()), | 		grpc.WithTransportCredentials(insecure.NewCredentials()), | ||||||
| 	) | 	) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return err | 		return err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	var ( |  | ||||||
| 		netDone = make(chan struct{}, 2) |  | ||||||
| 		netErr  error |  | ||||||
| 	) |  | ||||||
| 	if prometheusConfig.Enable { |  | ||||||
| 		go func() { |  | ||||||
| 			prometheusPort, err := datautil.GetElemByIndex(prometheusConfig.Ports, index) |  | ||||||
| 			if err != nil { |  | ||||||
| 				netErr = err |  | ||||||
| 				netDone <- struct{}{} |  | ||||||
| 				return |  | ||||||
| 			} |  | ||||||
| 			cs := prommetrics.GetGrpcCusMetrics(rpcRegisterName, share) |  | ||||||
| 			if err := prommetrics.RpcInit(cs, prometheusPort); err != nil && 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{}{} |  | ||||||
| 			//} |  | ||||||
| 		}() |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	go func() { | 	go func() { | ||||||
| 		err := srv.Serve(listener) | 		err := srv.Serve(listener) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
|  | |||||||
| @ -97,6 +97,9 @@ type CommonMsgDatabase interface { | |||||||
| 	DeleteDocMsgBefore(ctx context.Context, ts int64, doc *model.MsgDocModel) ([]int, error) | 	DeleteDocMsgBefore(ctx context.Context, ts int64, doc *model.MsgDocModel) ([]int, error) | ||||||
| 
 | 
 | ||||||
| 	GetDocIDs(ctx context.Context) ([]string, error) | 	GetDocIDs(ctx context.Context) ([]string, error) | ||||||
|  | 
 | ||||||
|  | 	SetUserConversationsMaxSeq(ctx context.Context, conversationID string, userID string, seq int64) error | ||||||
|  | 	SetUserConversationsMinSeq(ctx context.Context, conversationID string, userID string, seq int64) error | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| func NewCommonMsgDatabase(msgDocModel database.Msg, msg cache.MsgCache, seqUser cache.SeqUser, seqConversation cache.SeqConversationCache, kafkaConf *config.Kafka) (CommonMsgDatabase, error) { | func NewCommonMsgDatabase(msgDocModel database.Msg, msg cache.MsgCache, seqUser cache.SeqUser, seqConversation cache.SeqConversationCache, kafkaConf *config.Kafka) (CommonMsgDatabase, error) { | ||||||
| @ -702,6 +705,14 @@ func (db *commonMsgDatabase) SetUserConversationsMinSeqs(ctx context.Context, us | |||||||
| 	return db.seqUser.SetUserMinSeqs(ctx, userID, seqs) | 	return db.seqUser.SetUserMinSeqs(ctx, userID, seqs) | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | func (db *commonMsgDatabase) SetUserConversationsMaxSeq(ctx context.Context, conversationID string, userID string, seq int64) error { | ||||||
|  | 	return db.seqUser.SetUserMaxSeq(ctx, conversationID, userID, seq) | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | func (db *commonMsgDatabase) SetUserConversationsMinSeq(ctx context.Context, conversationID string, userID string, seq int64) error { | ||||||
|  | 	return db.seqUser.SetUserMinSeq(ctx, conversationID, userID, seq) | ||||||
|  | } | ||||||
|  | 
 | ||||||
| func (db *commonMsgDatabase) UserSetHasReadSeqs(ctx context.Context, userID string, hasReadSeqs map[string]int64) error { | func (db *commonMsgDatabase) UserSetHasReadSeqs(ctx context.Context, userID string, hasReadSeqs map[string]int64) error { | ||||||
| 	return db.seqUser.SetUserReadSeqs(ctx, userID, hasReadSeqs) | 	return db.seqUser.SetUserReadSeqs(ctx, userID, hasReadSeqs) | ||||||
| } | } | ||||||
|  | |||||||
| @ -33,6 +33,7 @@ import ( | |||||||
| 	"github.com/openimsdk/tools/mq/kafka" | 	"github.com/openimsdk/tools/mq/kafka" | ||||||
| 	"github.com/openimsdk/tools/s3/minio" | 	"github.com/openimsdk/tools/s3/minio" | ||||||
| 	"github.com/openimsdk/tools/system/program" | 	"github.com/openimsdk/tools/system/program" | ||||||
|  | 	"github.com/openimsdk/tools/utils/runtimeenv" | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| const maxRetry = 180 | const maxRetry = 180 | ||||||
| @ -84,42 +85,37 @@ func initConfig(configDir string) (*config.Mongo, *config.Redis, *config.Kafka, | |||||||
| 		discovery   = &config.Discovery{} | 		discovery   = &config.Discovery{} | ||||||
| 		thirdConfig = &config.Third{} | 		thirdConfig = &config.Third{} | ||||||
| 	) | 	) | ||||||
| 	if os.Getenv(DeploymentType) == KUBERNETES { | 	runtimeEnv := runtimeenv.PrintRuntimeEnvironment() | ||||||
| 		configDir = os.Getenv(MountConfigFilePath) |  | ||||||
| 		if configDir == "" { |  | ||||||
| 			return nil, nil, nil, nil, nil, fmt.Errorf("%s env is empty", MountConfigFilePath) |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 
 | 
 | ||||||
| 	err := config.Load(configDir, cmd.MongodbConfigFileName, cmd.ConfigEnvPrefixMap[cmd.MongodbConfigFileName], mongoConfig) | 	err := config.Load(configDir, cmd.MongodbConfigFileName, cmd.ConfigEnvPrefixMap[cmd.MongodbConfigFileName], runtimeEnv, mongoConfig) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, nil, nil, nil, nil, err | 		return nil, nil, nil, nil, nil, err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	err = config.Load(configDir, cmd.RedisConfigFileName, cmd.ConfigEnvPrefixMap[cmd.RedisConfigFileName], redisConfig) | 	err = config.Load(configDir, cmd.RedisConfigFileName, cmd.ConfigEnvPrefixMap[cmd.RedisConfigFileName], runtimeEnv, redisConfig) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, nil, nil, nil, nil, err | 		return nil, nil, nil, nil, nil, err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	err = config.Load(configDir, cmd.KafkaConfigFileName, cmd.ConfigEnvPrefixMap[cmd.KafkaConfigFileName], kafkaConfig) | 	err = config.Load(configDir, cmd.KafkaConfigFileName, cmd.ConfigEnvPrefixMap[cmd.KafkaConfigFileName], runtimeEnv, kafkaConfig) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, nil, nil, nil, nil, err | 		return nil, nil, nil, nil, nil, err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	err = config.Load(configDir, cmd.OpenIMRPCThirdCfgFileName, cmd.ConfigEnvPrefixMap[cmd.OpenIMRPCThirdCfgFileName], thirdConfig) | 	err = config.Load(configDir, cmd.OpenIMRPCThirdCfgFileName, cmd.ConfigEnvPrefixMap[cmd.OpenIMRPCThirdCfgFileName], runtimeEnv, thirdConfig) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, nil, nil, nil, nil, err | 		return nil, nil, nil, nil, nil, err | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	if thirdConfig.Object.Enable == "minio" { | 	if thirdConfig.Object.Enable == "minio" { | ||||||
| 		err = config.Load(configDir, cmd.MinioConfigFileName, cmd.ConfigEnvPrefixMap[cmd.MinioConfigFileName], minioConfig) | 		err = config.Load(configDir, cmd.MinioConfigFileName, cmd.ConfigEnvPrefixMap[cmd.MinioConfigFileName], runtimeEnv, minioConfig) | ||||||
| 		if err != nil { | 		if err != nil { | ||||||
| 			return nil, nil, nil, nil, nil, err | 			return nil, nil, nil, nil, nil, err | ||||||
| 		} | 		} | ||||||
| 	} else { | 	} else { | ||||||
| 		minioConfig = nil | 		minioConfig = nil | ||||||
| 	} | 	} | ||||||
| 	err = config.Load(configDir, cmd.DiscoveryConfigFilename, cmd.ConfigEnvPrefixMap[cmd.DiscoveryConfigFilename], discovery) | 	err = config.Load(configDir, cmd.DiscoveryConfigFilename, cmd.ConfigEnvPrefixMap[cmd.DiscoveryConfigFilename], runtimeEnv, discovery) | ||||||
| 	if err != nil { | 	if err != nil { | ||||||
| 		return nil, nil, nil, nil, nil, err | 		return nil, nil, nil, nil, nil, err | ||||||
| 	} | 	} | ||||||
| @ -173,10 +169,6 @@ func performChecks(ctx context.Context, mongoConfig *config.Mongo, redisConfig * | |||||||
| 		checks["Etcd"] = func(ctx context.Context) error { | 		checks["Etcd"] = func(ctx context.Context) error { | ||||||
| 			return CheckEtcd(ctx, &discovery.Etcd) | 			return CheckEtcd(ctx, &discovery.Etcd) | ||||||
| 		} | 		} | ||||||
| 	} else if discovery.Enable == "zookeeper" { |  | ||||||
| 		checks["Zookeeper"] = func(ctx context.Context) error { |  | ||||||
| 			return CheckZookeeper(ctx, &discovery.ZooKeeper) |  | ||||||
| 		} |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	for i := 0; i < maxRetry; i++ { | 	for i := 0; i < maxRetry; i++ { | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user