ci: 添加docker-compose和swagger配置文件以及CI工作流

添加docker-compose.yaml和swagger.yaml配置文件用于容器部署
添加.gitea/workflows/docker.yaml实现CI/CD自动化流程
This commit is contained in:
邹方成 2025-10-16 13:58:39 +08:00
parent c291afd38e
commit 2f747770dd
3 changed files with 141 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
cd /install/cicd_env_files
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

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