commit
e4003e6cb2
@ -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,24 +1,24 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# # Copyright © 2023 OpenIM. All rights reserved.
|
||||||
#
|
# #
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# # Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
# you may not use this file except in compliance with the License.
|
# # you may not use this file except in compliance with the License.
|
||||||
# You may obtain a copy of the License at
|
# # You may obtain a copy of the License at
|
||||||
#
|
# #
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
# # http://www.apache.org/licenses/LICENSE-2.0
|
||||||
#
|
# #
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
# # Unless required by applicable law or agreed to in writing, software
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
# # distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
# # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
# See the License for the specific language governing permissions and
|
# # See the License for the specific language governing permissions and
|
||||||
# limitations under the License.
|
# # limitations under the License.
|
||||||
|
|
||||||
FROM BASE_IMAGE
|
# FROM BASE_IMAGE
|
||||||
|
|
||||||
WORKDIR ${SERVER_WORKDIR}
|
# WORKDIR ${SERVER_WORKDIR}
|
||||||
|
|
||||||
# Set HTTP proxy
|
# # Set HTTP proxy
|
||||||
ARG BINARY_NAME
|
# ARG BINARY_NAME
|
||||||
|
|
||||||
COPY BINARY_NAME ./bin/BINARY_NAME
|
# COPY BINARY_NAME ./bin/BINARY_NAME
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/BINARY_NAME"]
|
# ENTRYPOINT ["./bin/BINARY_NAME"]
|
@ -1,44 +1,36 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# Use Go 1.22 Alpine as the base image for building the application
|
||||||
#
|
FROM golang:1.22-alpine AS builder
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
# Define the base directory for the application as an environment variable
|
||||||
|
ENV SERVER_DIR=/openim-server
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
# Set the working directory inside the container based on the environment variable
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
# Set the Go proxy to improve dependency resolution speed
|
||||||
|
#ENV GOPROXY=https://goproxy.io,direct
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
# Copy all files from the current directory into the container
|
||||||
|
COPY . .
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
|
||||||
ENV GOPROXY=$GOPROXY
|
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
RUN go mod tidy
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
COPY . .
|
RUN go build -o _output/openim-api ./cmd/openim-api
|
||||||
|
|
||||||
RUN make build BINS=openim-api
|
# Using Alpine Linux for the final image
|
||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-api /usr/bin/openim-api
|
# Install necessary packages, such as bash
|
||||||
|
RUN apk add --no-cache bash
|
||||||
|
|
||||||
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
# Set the environment and work directory
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
ENV SERVER_DIR=/openim-server
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
COPY --from=builder /usr/bin/openim-api ./bin/openim-api
|
# Copy the compiled binaries and mage from the builder image to the final image
|
||||||
|
COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output
|
||||||
|
COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/openim-api"]
|
# Set the command to run when the container starts
|
||||||
|
ENTRYPOINT ["sh", "-c", "_output/openim-api"]
|
||||||
|
@ -1,44 +0,0 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
|
||||||
#
|
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
# you may not use this file except in compliance with the License.
|
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
|
||||||
ENV GOPROXY=$GOPROXY
|
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
COPY . .
|
|
||||||
|
|
||||||
RUN make build BINS=openim-cmdutils
|
|
||||||
RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-cmdutils /usr/bin/openim-cmdutils
|
|
||||||
|
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
COPY --from=builder /usr/bin/openim-cmdutils ./bin/openim-cmdutils
|
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/openim-cmdutils"]
|
|
||||||
|
|
||||||
CMD ["--help"]
|
|
@ -1,44 +1,39 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# Use Go 1.22 Alpine as the base image for building the application
|
||||||
#
|
FROM golang:1.22-alpine AS builder
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Define the base directory for the application as an environment variable
|
||||||
# you may not use this file except in compliance with the License.
|
ENV SERVER_DIR=/openim-server
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
# Set the working directory inside the container based on the environment variable
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
# Set the Go proxy to improve dependency resolution speed
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
#ENV GOPROXY=https://goproxy.io,direct
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
# Copy all files from the current directory into the container
|
||||||
|
COPY . .
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
RUN go mod tidy
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
|
||||||
ENV GOPROXY=$GOPROXY
|
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
COPY . .
|
RUN go build -o _output/openim-crontask ./cmd/openim-crontask
|
||||||
|
|
||||||
|
|
||||||
RUN make build BINS=openim-crontask
|
# Using Alpine Linux for the final image
|
||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-crontask /usr/bin/openim-crontask
|
# Install necessary packages, such as bash
|
||||||
|
RUN apk add --no-cache bash
|
||||||
|
|
||||||
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
# Set the environment and work directory
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
ENV SERVER_DIR=/openim-server
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
COPY --from=builder /usr/bin/openim-crontask ./bin/openim-crontask
|
# Copy the compiled binaries and mage from the builder image to the final image
|
||||||
|
COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output
|
||||||
|
# COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/openim-crontask"]
|
# Set the command to run when the container starts
|
||||||
|
ENTRYPOINT ["sh", "-c", "_output/openim-crontask"]
|
@ -1,44 +1,39 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# Use Go 1.22 Alpine as the base image for building the application
|
||||||
#
|
FROM golang:1.22-alpine AS builder
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Define the base directory for the application as an environment variable
|
||||||
# you may not use this file except in compliance with the License.
|
ENV SERVER_DIR=/openim-server
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
# Set the working directory inside the container based on the environment variable
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
# Set the Go proxy to improve dependency resolution speed
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
#ENV GOPROXY=https://goproxy.io,direct
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
# Copy all files from the current directory into the container
|
||||||
|
COPY . .
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
RUN go mod tidy
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
|
||||||
ENV GOPROXY=$GOPROXY
|
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
COPY . .
|
RUN go build -o _output/openim-msggateway ./cmd/openim-msggateway
|
||||||
|
|
||||||
|
|
||||||
RUN make build BINS=openim-msggateway
|
# Using Alpine Linux for the final image
|
||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-msggateway /usr/bin/openim-msggateway
|
# Install necessary packages, such as bash
|
||||||
|
RUN apk add --no-cache bash
|
||||||
|
|
||||||
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
# Set the environment and work directory
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
ENV SERVER_DIR=/openim-server
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
COPY --from=builder /usr/bin/openim-msggateway ./bin/openim-msggateway
|
# Copy the compiled binaries and mage from the builder image to the final image
|
||||||
|
COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output
|
||||||
|
# COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/openim-msggateway"]
|
# Set the command to run when the container starts
|
||||||
|
ENTRYPOINT ["sh", "-c", "_output/openim-msggateway"]
|
@ -1,44 +1,39 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# Use Go 1.22 Alpine as the base image for building the application
|
||||||
#
|
FROM golang:1.22-alpine AS builder
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Define the base directory for the application as an environment variable
|
||||||
# you may not use this file except in compliance with the License.
|
ENV SERVER_DIR=/openim-server
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
# Set the working directory inside the container based on the environment variable
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
# Set the Go proxy to improve dependency resolution speed
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
#ENV GOPROXY=https://goproxy.io,direct
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
# Copy all files from the current directory into the container
|
||||||
|
COPY . .
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
RUN go mod tidy
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
|
||||||
ENV GOPROXY=$GOPROXY
|
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
COPY . .
|
RUN go build -o _output/openim-msgtransfer ./cmd/openim-msgtransfer
|
||||||
|
|
||||||
|
|
||||||
RUN make build BINS=openim-msgtransfer
|
# Using Alpine Linux for the final image
|
||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-msgtransfer /usr/bin/openim-msgtransfer
|
# Install necessary packages, such as bash
|
||||||
|
RUN apk add --no-cache bash
|
||||||
|
|
||||||
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
# Set the environment and work directory
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
ENV SERVER_DIR=/openim-server
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
COPY --from=builder /usr/bin/openim-msgtransfer ./bin/openim-msgtransfer
|
# Copy the compiled binaries and mage from the builder image to the final image
|
||||||
|
COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output
|
||||||
|
# COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/openim-msgtransfer"]
|
# Set the command to run when the container starts
|
||||||
|
ENTRYPOINT ["sh", "-c", "_output/openim-msgtransfer"]
|
@ -1,44 +1,39 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# Use Go 1.22 Alpine as the base image for building the application
|
||||||
#
|
FROM golang:1.22-alpine AS builder
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Define the base directory for the application as an environment variable
|
||||||
# you may not use this file except in compliance with the License.
|
ENV SERVER_DIR=/openim-server
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
# Set the working directory inside the container based on the environment variable
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
# Set the Go proxy to improve dependency resolution speed
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
#ENV GOPROXY=https://goproxy.io,direct
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
# Copy all files from the current directory into the container
|
||||||
|
COPY . .
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
RUN go mod tidy
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
|
||||||
ENV GOPROXY=$GOPROXY
|
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
COPY . .
|
RUN go build -o _output/openim-push ./cmd/openim-push
|
||||||
|
|
||||||
|
|
||||||
RUN make build BINS=openim-push
|
# Using Alpine Linux for the final image
|
||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-push /usr/bin/openim-push
|
# Install necessary packages, such as bash
|
||||||
|
RUN apk add --no-cache bash
|
||||||
|
|
||||||
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
# Set the environment and work directory
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
ENV SERVER_DIR=/openim-server
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
COPY --from=builder /usr/bin/openim-push ./bin/openim-push
|
# Copy the compiled binaries and mage from the builder image to the final image
|
||||||
|
COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output
|
||||||
|
# COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/openim-push"]
|
# Set the command to run when the container starts
|
||||||
|
ENTRYPOINT ["sh", "-c", "_output/openim-push"]
|
@ -1,44 +1,39 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# Use Go 1.22 Alpine as the base image for building the application
|
||||||
#
|
FROM golang:1.22-alpine AS builder
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Define the base directory for the application as an environment variable
|
||||||
# you may not use this file except in compliance with the License.
|
ENV SERVER_DIR=/openim-server
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
# Set the working directory inside the container based on the environment variable
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
# Set the Go proxy to improve dependency resolution speed
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
#ENV GOPROXY=https://goproxy.io,direct
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
# Copy all files from the current directory into the container
|
||||||
|
COPY . .
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
RUN go mod tidy
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
|
||||||
ENV GOPROXY=$GOPROXY
|
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
COPY . .
|
RUN go build -o _output/openim-rpc-auth ./cmd/openim-rpc/openim-rpc-auth
|
||||||
|
|
||||||
|
|
||||||
RUN make build BINS=openim-rpc-auth
|
# Using Alpine Linux for the final image
|
||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-auth /usr/bin/openim-rpc-auth
|
# Install necessary packages, such as bash
|
||||||
|
RUN apk add --no-cache bash
|
||||||
|
|
||||||
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
# Set the environment and work directory
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
ENV SERVER_DIR=/openim-server
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
COPY --from=builder /usr/bin/openim-rpc-auth ./bin/openim-rpc-auth
|
# Copy the compiled binaries and mage from the builder image to the final image
|
||||||
|
COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output
|
||||||
|
# COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/openim-rpc-auth"]
|
# Set the command to run when the container starts
|
||||||
|
ENTRYPOINT ["sh", "-c", "_output/openim-rpc-auth"]
|
@ -1,44 +1,39 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# Use Go 1.22 Alpine as the base image for building the application
|
||||||
#
|
FROM golang:1.22-alpine AS builder
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Define the base directory for the application as an environment variable
|
||||||
# you may not use this file except in compliance with the License.
|
ENV SERVER_DIR=/openim-server
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
# Set the working directory inside the container based on the environment variable
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
# Set the Go proxy to improve dependency resolution speed
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
#ENV GOPROXY=https://goproxy.io,direct
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
# Copy all files from the current directory into the container
|
||||||
|
COPY . .
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
RUN go mod tidy
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
|
||||||
ENV GOPROXY=$GOPROXY
|
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
COPY . .
|
RUN go build -o _output/openim-rpc-conversation ./cmd/openim-rpc/openim-rpc-conversation
|
||||||
|
|
||||||
|
|
||||||
RUN make build BINS=openim-rpc-conversation
|
# Using Alpine Linux for the final image
|
||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-conversation /usr/bin/openim-rpc-conversation
|
# Install necessary packages, such as bash
|
||||||
|
RUN apk add --no-cache bash
|
||||||
|
|
||||||
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
# Set the environment and work directory
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
ENV SERVER_DIR=/openim-server
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
COPY --from=builder /usr/bin/openim-rpc-conversation ./bin/openim-rpc-conversation
|
# Copy the compiled binaries and mage from the builder image to the final image
|
||||||
|
COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output
|
||||||
|
# COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/openim-rpc-conversation"]
|
# Set the command to run when the container starts
|
||||||
|
ENTRYPOINT ["sh", "-c", "_output/openim-rpc-conversation"]
|
@ -1,44 +1,39 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# Use Go 1.22 Alpine as the base image for building the application
|
||||||
#
|
FROM golang:1.22-alpine AS builder
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Define the base directory for the application as an environment variable
|
||||||
# you may not use this file except in compliance with the License.
|
ENV SERVER_DIR=/openim-server
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
# Set the working directory inside the container based on the environment variable
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
# Set the Go proxy to improve dependency resolution speed
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
#ENV GOPROXY=https://goproxy.io,direct
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
# Copy all files from the current directory into the container
|
||||||
|
COPY . .
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
RUN go mod tidy
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
|
||||||
ENV GOPROXY=$GOPROXY
|
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
COPY . .
|
RUN go build -o _output/openim-rpc-friend ./cmd/openim-rpc/openim-rpc-friend
|
||||||
|
|
||||||
|
|
||||||
RUN make build BINS=openim-rpc-friend
|
# Using Alpine Linux for the final image
|
||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-friend /usr/bin/openim-rpc-friend
|
# Install necessary packages, such as bash
|
||||||
|
RUN apk add --no-cache bash
|
||||||
|
|
||||||
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
# Set the environment and work directory
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
ENV SERVER_DIR=/openim-server
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
COPY --from=builder /usr/bin/openim-rpc-friend ./bin/openim-rpc-friend
|
# Copy the compiled binaries and mage from the builder image to the final image
|
||||||
|
COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output
|
||||||
|
# COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/openim-rpc-friend"]
|
# Set the command to run when the container starts
|
||||||
|
ENTRYPOINT ["sh", "-c", "_output/openim-rpc-friend"]
|
@ -1,44 +1,39 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# Use Go 1.22 Alpine as the base image for building the application
|
||||||
#
|
FROM golang:1.22-alpine AS builder
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Define the base directory for the application as an environment variable
|
||||||
# you may not use this file except in compliance with the License.
|
ENV SERVER_DIR=/openim-server
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
# Set the working directory inside the container based on the environment variable
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
# Set the Go proxy to improve dependency resolution speed
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
#ENV GOPROXY=https://goproxy.io,direct
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
# Copy all files from the current directory into the container
|
||||||
|
COPY . .
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
RUN go mod tidy
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
|
||||||
ENV GOPROXY=$GOPROXY
|
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
COPY . .
|
RUN go build -o _output/openim-rpc-group ./cmd/openim-rpc/openim-rpc-group
|
||||||
|
|
||||||
|
|
||||||
RUN make build BINS=openim-rpc-group
|
# Using Alpine Linux for the final image
|
||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-group /usr/bin/openim-rpc-group
|
# Install necessary packages, such as bash
|
||||||
|
RUN apk add --no-cache bash
|
||||||
|
|
||||||
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
# Set the environment and work directory
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
ENV SERVER_DIR=/openim-server
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
COPY --from=builder /usr/bin/openim-rpc-group ./bin/openim-rpc-group
|
# Copy the compiled binaries and mage from the builder image to the final image
|
||||||
|
COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output
|
||||||
|
# COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/openim-rpc-group"]
|
# Set the command to run when the container starts
|
||||||
|
ENTRYPOINT ["sh", "-c", "_output/openim-rpc-group"]
|
@ -1,44 +1,39 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# Use Go 1.22 Alpine as the base image for building the application
|
||||||
#
|
FROM golang:1.22-alpine AS builder
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Define the base directory for the application as an environment variable
|
||||||
# you may not use this file except in compliance with the License.
|
ENV SERVER_DIR=/openim-server
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
# Set the working directory inside the container based on the environment variable
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
# Set the Go proxy to improve dependency resolution speed
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
#ENV GOPROXY=https://goproxy.io,direct
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
# Copy all files from the current directory into the container
|
||||||
|
COPY . .
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
RUN go mod tidy
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
|
||||||
ENV GOPROXY=$GOPROXY
|
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
COPY . .
|
RUN go build -o _output/openim-rpc-msg ./cmd/openim-rpc/openim-rpc-msg
|
||||||
|
|
||||||
|
|
||||||
RUN make build BINS=openim-rpc-msg
|
# Using Alpine Linux for the final image
|
||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-msg /usr/bin/openim-rpc-msg
|
# Install necessary packages, such as bash
|
||||||
|
RUN apk add --no-cache bash
|
||||||
|
|
||||||
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
# Set the environment and work directory
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
ENV SERVER_DIR=/openim-server
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
COPY --from=builder /usr/bin/openim-rpc-msg ./bin/openim-rpc-msg
|
# Copy the compiled binaries and mage from the builder image to the final image
|
||||||
|
COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output
|
||||||
|
# COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/openim-rpc-msg"]
|
# Set the command to run when the container starts
|
||||||
|
ENTRYPOINT ["sh", "-c", "_output/openim-rpc-msg"]
|
@ -1,44 +1,39 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# Use Go 1.22 Alpine as the base image for building the application
|
||||||
#
|
FROM golang:1.22-alpine AS builder
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Define the base directory for the application as an environment variable
|
||||||
# you may not use this file except in compliance with the License.
|
ENV SERVER_DIR=/openim-server
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
# Set the working directory inside the container based on the environment variable
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
# Set the Go proxy to improve dependency resolution speed
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
#ENV GOPROXY=https://goproxy.io,direct
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
# Copy all files from the current directory into the container
|
||||||
|
COPY . .
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
RUN go mod tidy
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
|
||||||
ENV GOPROXY=$GOPROXY
|
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
COPY . .
|
RUN go build -o _output/openim-rpc-third ./cmd/openim-rpc/openim-rpc-third
|
||||||
|
|
||||||
|
|
||||||
RUN make build BINS=openim-rpc-third
|
# Using Alpine Linux for the final image
|
||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-third /usr/bin/openim-rpc-third
|
# Install necessary packages, such as bash
|
||||||
|
RUN apk add --no-cache bash
|
||||||
|
|
||||||
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
# Set the environment and work directory
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
ENV SERVER_DIR=/openim-server
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
COPY --from=builder /usr/bin/openim-rpc-third ./bin/openim-rpc-third
|
# Copy the compiled binaries and mage from the builder image to the final image
|
||||||
|
COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output
|
||||||
|
# COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/openim-rpc-third"]
|
# Set the command to run when the container starts
|
||||||
|
ENTRYPOINT ["sh", "-c", "_output/openim-rpc-third"]
|
@ -1,44 +1,37 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# Use Go 1.22 Alpine as the base image for building the application
|
||||||
#
|
FROM golang:1.22-alpine AS builder
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# Define the base directory for the application as an environment variable
|
||||||
# you may not use this file except in compliance with the License.
|
ENV SERVER_DIR=/openim-server
|
||||||
# You may obtain a copy of the License at
|
|
||||||
#
|
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
#
|
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
# Set the working directory inside the container based on the environment variable
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
# Set the Go proxy to improve dependency resolution speed
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
#ENV GOPROXY=https://goproxy.io,direct
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
# Copy all files from the current directory into the container
|
||||||
|
COPY . .
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
RUN go mod tidy
|
||||||
ENV GOPROXY=$GOPROXY
|
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
RUN go build -o _output/openim-rpc-user ./cmd/openim-rpc/openim-rpc-user
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
COPY . .
|
|
||||||
|
|
||||||
RUN make build BINS=openim-rpc-user
|
# Using Alpine Linux for the final image
|
||||||
|
FROM alpine:latest
|
||||||
|
|
||||||
RUN cp /openim/openim-server/_output/bin/platforms/$(go env GOOS)/$(go env GOARCH)/openim-rpc-user /usr/bin/openim-rpc-user
|
# Install necessary packages, such as bash
|
||||||
|
RUN apk add --no-cache bash
|
||||||
|
|
||||||
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
# Set the environment and work directory
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
ENV SERVER_DIR=/openim-server
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
|
||||||
|
|
||||||
COPY --from=builder /usr/bin/openim-rpc-user ./bin/openim-rpc-user
|
# Copy the compiled binaries and mage from the builder image to the final image
|
||||||
|
COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output
|
||||||
|
# COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config
|
||||||
|
|
||||||
ENTRYPOINT ["./bin/openim-rpc-user"]
|
# Set the command to run when the container starts
|
||||||
|
ENTRYPOINT ["sh", "-c", "_output/openim-rpc-user"]
|
@ -1,48 +1,108 @@
|
|||||||
# Copyright © 2023 OpenIM. All rights reserved.
|
# # Copyright © 2023 OpenIM. All rights reserved.
|
||||||
#
|
# #
|
||||||
# Licensed under the Apache License, Version 2.0 (the "License");
|
# # Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
# you may not use this file except in compliance with the License.
|
# # you may not use this file except in compliance with the License.
|
||||||
# You may obtain a copy of the License at
|
# # You may obtain a copy of the License at
|
||||||
|
# #
|
||||||
|
# # http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
# #
|
||||||
|
# # Unless required by applicable law or agreed to in writing, software
|
||||||
|
# # distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# # See the License for the specific language governing permissions and
|
||||||
|
# # limitations under the License.
|
||||||
|
|
||||||
|
# # OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
||||||
|
|
||||||
|
# # Set go mod installation source and proxy
|
||||||
|
|
||||||
|
# FROM golang:1.20 AS builder
|
||||||
|
|
||||||
#
|
#
|
||||||
# http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
|
# WORKDIR /openim/openim-server
|
||||||
|
|
||||||
#
|
#
|
||||||
# Unless required by applicable law or agreed to in writing, software
|
# ENV GOPROXY=$GOPROXY
|
||||||
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
# See the License for the specific language governing permissions and
|
|
||||||
# limitations under the License.
|
|
||||||
|
|
||||||
# OpenIM base image: https://github.com/openim-sigs/openim-base-image
|
# COPY go.mod go.sum ./
|
||||||
|
# RUN go mod download
|
||||||
|
|
||||||
# Set go mod installation source and proxy
|
# COPY . .
|
||||||
|
|
||||||
FROM golang:1.20 AS builder
|
# RUN make clean
|
||||||
|
# RUN make build BINS=component
|
||||||
|
|
||||||
ARG GO111MODULE=on
|
# # FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
||||||
|
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
# WORKDIR /openim/openim-server
|
||||||
|
|
||||||
ENV GO111MODULE=$GO111MODULE
|
# COPY --from=builder /openim/openim-server/_output/bin/tools /openim/openim-server/_output/bin/tools/
|
||||||
ENV GOPROXY=$GOPROXY
|
# COPY --from=builder /openim/openim-server/config /openim/openim-server/config
|
||||||
|
|
||||||
|
# ENV OPENIM_SERVER_CONFIG_NAME=/openim/openim-server/config
|
||||||
|
|
||||||
|
# RUN mv ${OPENIM_SERVER_BINDIR}/platforms/$(get_os)/$(get_arch)/component /usr/bin/component
|
||||||
|
|
||||||
|
# ENTRYPOINT ["bash", "-c", "component -c $OPENIM_SERVER_CONFIG_NAME"]
|
||||||
|
|
||||||
COPY go.mod go.sum ./
|
|
||||||
RUN go mod download
|
|
||||||
|
|
||||||
|
# Use Go 1.22 Alpine as the base image for building the application
|
||||||
|
FROM golang:1.22-alpine AS builder
|
||||||
|
# Define the base directory for the application as an environment variable
|
||||||
|
ENV SERVER_DIR=/openim-server
|
||||||
|
|
||||||
|
# Set the working directory inside the container based on the environment variable
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
|
# Set the Go proxy to improve dependency resolution speed
|
||||||
|
|
||||||
|
#ENV GOPROXY=https://goproxy.io,direct
|
||||||
|
|
||||||
|
# Copy all files from the current directory into the container
|
||||||
COPY . .
|
COPY . .
|
||||||
|
|
||||||
RUN make clean
|
RUN go mod download
|
||||||
RUN make build BINS=component
|
|
||||||
|
# Install Mage to use for building the application
|
||||||
|
RUN go install github.com/magefile/mage@v1.15.0
|
||||||
|
|
||||||
|
# ENV BINS=openim-rpc-user
|
||||||
|
|
||||||
|
# Optionally build your application if needed
|
||||||
|
# RUN mage build ${BINS} check-free-memory seq || true
|
||||||
|
RUN mage build 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
|
||||||
|
RUN apk add bash
|
||||||
|
|
||||||
|
# Set the environment and work directory
|
||||||
|
ENV SERVER_DIR=/openim-server
|
||||||
|
WORKDIR $SERVER_DIR
|
||||||
|
|
||||||
# FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
|
||||||
FROM ghcr.io/openim-sigs/openim-bash-image:latest
|
|
||||||
|
|
||||||
WORKDIR /openim/openim-server
|
# Copy the compiled binaries and mage from the builder image to the final image
|
||||||
|
COPY --from=builder $SERVER_DIR/_output $SERVER_DIR/_output
|
||||||
|
COPY --from=builder $SERVER_DIR/config $SERVER_DIR/config
|
||||||
|
COPY --from=builder /go/bin/mage /usr/local/bin/mage
|
||||||
|
COPY --from=builder $SERVER_DIR/magefile_windows.go $SERVER_DIR/
|
||||||
|
COPY --from=builder $SERVER_DIR/magefile_unix.go $SERVER_DIR/
|
||||||
|
COPY --from=builder $SERVER_DIR/magefile.go $SERVER_DIR/
|
||||||
|
# COPY --from=builder $SERVER_DIR/start-config.yml $SERVER_DIR/
|
||||||
|
COPY --from=builder $SERVER_DIR/go.mod $SERVER_DIR/
|
||||||
|
COPY --from=builder $SERVER_DIR/go.sum $SERVER_DIR/
|
||||||
|
|
||||||
COPY --from=builder /openim/openim-server/_output/bin/tools /openim/openim-server/_output/bin/tools/
|
|
||||||
COPY --from=builder /openim/openim-server/config /openim/openim-server/config
|
|
||||||
|
|
||||||
ENV OPENIM_SERVER_CONFIG_NAME=/openim/openim-server/config
|
RUN echo -e "serviceBinaries:\n \n" \
|
||||||
|
> $SERVER_DIR/start-config.yml && \
|
||||||
|
echo -e "toolBinaries:\n - check-free-memory\n - seq\n" >> $SERVER_DIR/start-config.yml && \
|
||||||
|
echo "maxFileDescriptors: 10000" >> $SERVER_DIR/start-config.yml
|
||||||
|
|
||||||
RUN mv ${OPENIM_SERVER_BINDIR}/platforms/$(get_os)/$(get_arch)/component /usr/bin/component
|
RUN go get github.com/openimsdk/gomake@v0.0.15-alpha.1
|
||||||
|
|
||||||
ENTRYPOINT ["bash", "-c", "component -c $OPENIM_SERVER_CONFIG_NAME"]
|
# Set the command to run when the container starts
|
||||||
|
ENTRYPOINT ["sh", "-c", "mage start && tail -f /dev/null"]
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
prometheus:
|
prometheus:
|
||||||
# Enable or disable Prometheus monitoring
|
# Enable or disable Prometheus monitoring
|
||||||
enable: true
|
enable: true
|
||||||
|
# autoSetPorts indicates whether to automatically set the ports
|
||||||
|
autoSetPorts: true
|
||||||
# List of ports that Prometheus listens on; each port corresponds to an instance of monitoring. Ensure these are managed accordingly
|
# List of ports that Prometheus listens on; each port corresponds to an instance of monitoring. Ensure these are managed accordingly
|
||||||
# Because four instances have been launched, four ports need to be specified
|
# It will only take effect when autoSetPorts is set to false.
|
||||||
ports: [ 12020, 12021, 12022, 12023, 12024, 12025, 12026, 12027, 12028, 12029, 12030, 12031, 12032, 12033, 12034, 12035 ]
|
ports: [ 12020, 12021, 12022, 12023, 12024, 12025, 12026, 12027, 12028, 12029, 12030, 12031, 12032, 12033, 12034, 12035 ]
|
||||||
|
@ -0,0 +1,113 @@
|
|||||||
|
package api
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"github.com/gin-gonic/gin"
|
||||||
|
"github.com/openimsdk/open-im-server/v3/pkg/common/discoveryregister"
|
||||||
|
"github.com/openimsdk/open-im-server/v3/pkg/common/prommetrics"
|
||||||
|
"github.com/openimsdk/tools/apiresp"
|
||||||
|
"github.com/openimsdk/tools/discovery"
|
||||||
|
"github.com/openimsdk/tools/discovery/etcd"
|
||||||
|
"github.com/openimsdk/tools/errs"
|
||||||
|
"github.com/openimsdk/tools/log"
|
||||||
|
clientv3 "go.etcd.io/etcd/client/v3"
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
type PrometheusDiscoveryApi struct {
|
||||||
|
config *Config
|
||||||
|
client *clientv3.Client
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewPrometheusDiscoveryApi(config *Config, client discovery.SvcDiscoveryRegistry) *PrometheusDiscoveryApi {
|
||||||
|
api := &PrometheusDiscoveryApi{
|
||||||
|
config: config,
|
||||||
|
}
|
||||||
|
if config.Discovery.Enable == discoveryregister.Etcd {
|
||||||
|
api.client = client.(*etcd.SvcDiscoveryRegistryImpl).GetClient()
|
||||||
|
}
|
||||||
|
return api
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PrometheusDiscoveryApi) Enable(c *gin.Context) {
|
||||||
|
if p.config.Discovery.Enable != discoveryregister.Etcd {
|
||||||
|
c.JSON(http.StatusOK, []struct{}{})
|
||||||
|
c.Abort()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PrometheusDiscoveryApi) discovery(c *gin.Context, key string) {
|
||||||
|
eResp, err := p.client.Get(c, prommetrics.BuildDiscoveryKey(key))
|
||||||
|
if err != nil {
|
||||||
|
// Log and respond with an error if preparation fails.
|
||||||
|
apiresp.GinError(c, errs.WrapMsg(err, "etcd get err"))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if len(eResp.Kvs) == 0 {
|
||||||
|
c.JSON(http.StatusOK, []*prommetrics.Target{})
|
||||||
|
}
|
||||||
|
|
||||||
|
var (
|
||||||
|
resp = &prommetrics.RespTarget{
|
||||||
|
Targets: make([]string, 0, len(eResp.Kvs)),
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
for i := range eResp.Kvs {
|
||||||
|
var target prommetrics.Target
|
||||||
|
err = json.Unmarshal(eResp.Kvs[i].Value, &target)
|
||||||
|
if err != nil {
|
||||||
|
log.ZError(c, "prometheus unmarshal err", errs.Wrap(err))
|
||||||
|
}
|
||||||
|
resp.Targets = append(resp.Targets, target.Target)
|
||||||
|
if resp.Labels == nil {
|
||||||
|
resp.Labels = target.Labels
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
c.JSON(200, []*prommetrics.RespTarget{resp})
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PrometheusDiscoveryApi) Api(c *gin.Context) {
|
||||||
|
p.discovery(c, prommetrics.APIKeyName)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PrometheusDiscoveryApi) User(c *gin.Context) {
|
||||||
|
p.discovery(c, p.config.Discovery.RpcService.User)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PrometheusDiscoveryApi) Group(c *gin.Context) {
|
||||||
|
p.discovery(c, p.config.Discovery.RpcService.Group)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PrometheusDiscoveryApi) Msg(c *gin.Context) {
|
||||||
|
p.discovery(c, p.config.Discovery.RpcService.Msg)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PrometheusDiscoveryApi) Friend(c *gin.Context) {
|
||||||
|
p.discovery(c, p.config.Discovery.RpcService.Friend)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PrometheusDiscoveryApi) Conversation(c *gin.Context) {
|
||||||
|
p.discovery(c, p.config.Discovery.RpcService.Conversation)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PrometheusDiscoveryApi) Third(c *gin.Context) {
|
||||||
|
p.discovery(c, p.config.Discovery.RpcService.Third)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PrometheusDiscoveryApi) Auth(c *gin.Context) {
|
||||||
|
p.discovery(c, p.config.Discovery.RpcService.Auth)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PrometheusDiscoveryApi) Push(c *gin.Context) {
|
||||||
|
p.discovery(c, p.config.Discovery.RpcService.Push)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PrometheusDiscoveryApi) MessageGateway(c *gin.Context) {
|
||||||
|
p.discovery(c, p.config.Discovery.RpcService.MessageGateway)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (p *PrometheusDiscoveryApi) MessageTransfer(c *gin.Context) {
|
||||||
|
p.discovery(c, prommetrics.MessageTransferKeyName)
|
||||||
|
}
|
@ -0,0 +1,31 @@
|
|||||||
|
package prommetrics
|
||||||
|
|
||||||
|
import "fmt"
|
||||||
|
|
||||||
|
const (
|
||||||
|
APIKeyName = "api"
|
||||||
|
MessageTransferKeyName = "message-transfer"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Target struct {
|
||||||
|
Target string `json:"target"`
|
||||||
|
Labels map[string]string `json:"labels"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type RespTarget struct {
|
||||||
|
Targets []string `json:"targets"`
|
||||||
|
Labels map[string]string `json:"labels"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func BuildDiscoveryKey(name string) string {
|
||||||
|
return fmt.Sprintf("%s/%s/%s", "openim", "prometheus_discovery", name)
|
||||||
|
}
|
||||||
|
|
||||||
|
func BuildDefaultTarget(host string, ip int) Target {
|
||||||
|
return Target{
|
||||||
|
Target: fmt.Sprintf("%s:%d", host, ip),
|
||||||
|
Labels: map[string]string{
|
||||||
|
"namespace": "default",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in new issue