ci: 添加docker-compose和swagger配置文件以及CI工作流
添加docker-compose.yaml和swagger.yaml配置文件用于容器部署 添加.gitea/workflows/docker.yaml实现CI/CD自动化流程
This commit is contained in:
parent
c291afd38e
commit
2f747770dd
100
.gitea/workflows/docker.yaml
Normal file
100
.gitea/workflows/docker.yaml
Normal 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
|
||||
15
deploy/project/docker-compose.yaml
Normal file
15
deploy/project/docker-compose.yaml
Normal 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
|
||||
26
deploy/project/swagger.yaml
Normal file
26
deploy/project/swagger.yaml
Normal 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
|
||||
Loading…
x
Reference in New Issue
Block a user