Merge remote-tracking branch 'origin/main'

This commit is contained in:
summer 2025-10-16 14:27:07 +08:00
commit 2b69240710
4 changed files with 192 additions and 0 deletions

View File

@ -0,0 +1,100 @@
name: Build docker and publish
run-name: The pipeline for docker build
on:
push:
branches:
- main
pull_request:
branches:
- main
env:
# Docker
REPO: ${{ vars.REPO }}
DOCKER_USERNAME: ${{ vars.DOCKER_USERNAME }}
DOCKER_PASSWORD: ${{ vars.DOCKER_PASSWORD}}
# Gitea
GIT_USERNAME: ${{ vars.GIT_USERNAME }}
GIT_PASSWORD: ${{ vars.GIT_PASSWORD }}
# Host SSH
SSH_HOST: ${{ vars.SSH_HOST }}
SSH_PORT: ${{ vars.SSH_PORT }}
SSH_USER: ${{ vars.SSH_USER }}
SSH_PASSWORD: ${{ vars.SSH_PASSWORD }}
# SMTP
SMTP_SERVER_ADDRESS: ${{ vars.SMTP_SERVER_ADDRESS }}
SMTP_USERNAME: ${{ vars.SMTP_USERNAME }}
SMTP_PASSWORD: ${{ vars.SMTP_PASSWORD }}
jobs:
linux:
runs-on: ubuntu-latest
strategy:
matrix:
# 使用gitea-tool-cache需要指定具体的版本号
go: ["1.24.5"]
steps:
- name: Checkout
uses: https://${{ env.GIT_USERNAME }}:${{ env.GIT_PASSWORD }}@${{ vars.DOMAIN_OF_GITEA}}/actions/checkout@v4
# 将.env环境变量配置文件拷贝致gitea runner容器
- name: copy env file to runner container
uses: https://${{ env.GIT_USERNAME }}:${{ env.GIT_PASSWORD }}@${{ vars.DOMAIN_OF_GITEA}}/actions/ssh-action@v0.1.10
with:
host: ${{ env.SSH_HOST }}
username: ${{ env.SSH_USER }}
password: ${{ env.SSH_PASSWORD }}
port: ${{ env.SSH_PORT }}
debug: true
script: |
mkdir -p /install/cicd_env_files_mini_chat
cd /install/cicd_env_files_mini_chat
docker cp ${{env.JOB_CONTAINER_NAME}}:${{gitea.WORKSPACE}}/deploy/.env ./.env
source ./.env
docker cp ${{env.JOB_CONTAINER_NAME}}:${{gitea.WORKSPACE}}/docs/${SERVICE_NAME}.json .
docker cp .env ${{ vars.RUNNER_CONTAINER_NAME }}:/.env
docker exec ${{ vars.RUNNER_CONTAINER_NAME }} /bin/bash -c "source /.env"
- name: Install Go environment
uses: https://${{ env.GIT_USERNAME }}:${{ env.GIT_PASSWORD }}@${{ vars.DOMAIN_OF_GITEA}}/actions/gitea-tool-cache@v5
with:
# 需要指定具体版本号!
go-version: ${{ matrix.go }}
- uses: https://${{ env.GIT_USERNAME }}:${{ env.GIT_PASSWORD }}@${{ vars.DOMAIN_OF_GITEA}}/actions/setup-go@v2
with:
go-version: ${{ matrix.go }}
- uses: https://${{ env.GIT_USERNAME }}:${{ env.GIT_PASSWORD }}@${{ vars.DOMAIN_OF_GITEA}}/actions/cache@v3
with:
path: |
~/.cache/go-build
~/go/pkg/mod
key: ${{ runner.os }}-go-${{ hashFiles('**/go.sum') }}
restore-keys: |
${{ runner.os }}-go-
- name: Prepare GO environment
run: |
go env -w GOPROXY=https://goproxy.cn,direct
go env -w GOPRIVATE="${{ vars.DOMAIN_OF_GITEA}}"
git config --global url."https://${{ env.GIT_USERNAME }}:${{ env.GIT_PASSWORD }}@${{ vars.DOMAIN_OF_GITEA}}/".insteadOf "https://${{ vars.DOMAIN_OF_GITEA}}/"
- name: Build and push docker image
run: |
source ${{gitea.WORKSPACE}}/deploy/.env
go clean -modcache
go mod tidy
make build-linux
make docker
make publish-docker
make docker-run
- name: Build APIDOC docker image
run: |
source ${{gitea.WORKSPACE}}/deploy/.env
echo ${SERVICE_NAME}
echo ${APIDOC_CONTAINER_NAME}
echo ${SWAGGER_JSON}
make swagger-docker

51
Dockerfile Normal file
View File

@ -0,0 +1,51 @@
# Build stage
FROM golang:1.24.5-alpine AS builder
# Set working directory
WORKDIR /app
# Install dependencies
RUN apk add --no-cache git ca-certificates tzdata
# Copy go mod files
COPY go.mod go.sum ./
# Download dependencies
RUN go mod download
# Copy source code
COPY . .
# Build the application
RUN CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -a -ldflags '-w -s' -trimpath -o miniChat .
# Final stage
FROM alpine:latest
# Install ca-certificates for HTTPS requests
RUN apk --no-cache add ca-certificates tzdata
# Set timezone
ENV TZ=Asia/Shanghai
# Create app directory
WORKDIR /app
# Copy binary from builder stage
COPY --from=builder /app/miniChat .
# Copy configuration files if they exist
COPY --from=builder /app/configs ./configs
# Create logs directory
RUN mkdir -p /app/logs
# Expose port
EXPOSE 9991
# Health check
HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \
CMD wget --no-verbose --tries=1 --spider http://localhost:9991/system/health || exit 1
# Run the application
CMD ["./miniChat"]

View File

@ -0,0 +1,15 @@
services:
# need modify service name to your owner
blindbox-mms-api:
image: ${API_IMAGE_NAME}
container_name: ${API_CONTAINER_NAME}
restart: always
ports:
- ${API_EXTERNAL_PORT}:${API_INNTER_PORT}
volumes:
- ${API_LOG_DIR}:/app/logs
networks:
default:
name: ${DOCKER_NETWORK_NAME}
external: true

View File

@ -0,0 +1,26 @@
services:
apidoc:
image: swaggerapi/swagger-ui
container_name: ${APIDOC_CONTAINER_NAME}
restart: always
entrypoint:
[
"/bin/sh",
"-c",
"sed -i 's|localhost:${API_INNTER_PORT}|${SWAGGER_INVOKE_URL}|g' ${SWAGGER_JSON} && /docker-entrypoint.sh nginx && tail -f /dev/null",
]
ports:
- "${APIDOC_PORT_DEFINE}:8080"
environment:
SWAGGER_JSON: ${SWAGGER_JSON}
APIDOC_CONTAINER_NAME: ${APIDOC_CONTAINER_NAME}
APIDOC_PORT: ${APIDOC_PORT}
INVOKE_URL: ${SWAGGER_INVOKE_URL}
API_URL: https://${DOMAIN}/${SERVICE_NAME}-${APIDOC_BUILD_SUFFIX}/${SERVICE_NAME}.json
volumes:
- ${HOST_APIDOC_DIRCTORY}:${APIDOC_CONTAINER_DIRECOTRY}
networks:
default:
name: ${DOCKER_NETWORK_NAME}
external: true