This commit is contained in:
parent
7471fd8e3d
commit
bcf81ab683
@ -1,5 +1,6 @@
|
|||||||
name: Build docker and publish
|
name: Build docker and publish
|
||||||
run-name: The pipeline for docker build
|
run-name: 简化的Docker构建和部署流程
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
@ -9,75 +10,118 @@ on:
|
|||||||
- main
|
- main
|
||||||
|
|
||||||
env:
|
env:
|
||||||
# Docker
|
# Docker镜像仓库
|
||||||
REPO: ${{ vars.REPO }}
|
REPO: ${{ vars.REPO }}
|
||||||
# Gitea
|
# SSH连接信息
|
||||||
GIT_USERNAME: ${{ vars.GIT_USERNAME }}
|
|
||||||
GIT_PASSWORD: ${{ vars.GIT_PASSWORD }}
|
|
||||||
# Host SSH
|
|
||||||
SSH_HOST: ${{ vars.SSH_HOST }}
|
SSH_HOST: ${{ vars.SSH_HOST }}
|
||||||
SSH_PORT: ${{ vars.SSH_PORT }}
|
SSH_PORT: ${{ vars.SSH_PORT }}
|
||||||
SSH_USER: ${{ vars.SSH_USER }}
|
SSH_USER: ${{ vars.SSH_USER }}
|
||||||
SSH_PASSWORD: ${{ vars.SSH_PASSWORD }}
|
SSH_PASSWORD: ${{ vars.SSH_PASSWORD }}
|
||||||
|
# TG通知
|
||||||
|
TG_BOT_TOKEN: 8114337882:AAHkEx03HSu7RxN4IHBJJEnsK9aPPzNLIk0
|
||||||
|
TG_CHAT_ID: "-4940243803"
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
linux:
|
build:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ppanel-server
|
||||||
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
# 使用gitea-tool-cache需要指定具体的版本号
|
|
||||||
go: ["1.24.3"]
|
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout
|
# 步骤1: 下载代码
|
||||||
uses: https://${{ env.GIT_USERNAME }}:${{ env.GIT_PASSWORD }}@${{ vars.DOMAIN_OF_GITEA}}/actions/checkout@main
|
- name: 📥 下载代码
|
||||||
|
uses: actions/checkout@v4
|
||||||
# 将.env环境变量配置文件拷贝致gitea runner容器
|
|
||||||
- name: copy env file to runner container
|
# 步骤2: 打包编译 (执行dockerfile编译 + make build)
|
||||||
uses: https://${{ env.GIT_USERNAME }}:${{ env.GIT_PASSWORD }}@${{ vars.DOMAIN_OF_GITEA}}/actions/ssh-action@main
|
- name: 🔨 打包编译
|
||||||
|
run: |
|
||||||
|
echo "开始编译..."
|
||||||
|
make build
|
||||||
|
echo "编译完成,开始构建Docker镜像..."
|
||||||
|
make docker
|
||||||
|
echo "Docker镜像构建完成"
|
||||||
|
|
||||||
|
# 步骤3: 发布到镜像仓库
|
||||||
|
- name: 📤 发布到镜像仓库
|
||||||
|
run: |
|
||||||
|
echo "开始推送镜像到仓库..."
|
||||||
|
make publish-docker
|
||||||
|
echo "镜像推送完成"
|
||||||
|
|
||||||
|
# 步骤4: 连接服务器拉镜像启动
|
||||||
|
- name: 🚀 连接服务器拉镜像启动
|
||||||
|
uses: appleboy/ssh-action@v1.0.3
|
||||||
with:
|
with:
|
||||||
host: ${{ env.SSH_HOST }}
|
host: ${{ env.SSH_HOST }}
|
||||||
username: ${{ env.SSH_USER }}
|
username: ${{ env.SSH_USER }}
|
||||||
password: ${{ env.SSH_PASSWORD }}
|
password: ${{ env.SSH_PASSWORD }}
|
||||||
port: ${{ env.SSH_PORT }}
|
port: ${{ env.SSH_PORT }}
|
||||||
debug: true
|
timeout: 300s
|
||||||
|
command_timeout: 600s
|
||||||
script: |
|
script: |
|
||||||
mkdir -p ~/cicd_env_files
|
echo "连接服务器成功,开始部署..."
|
||||||
cd ~/cicd_env_files
|
|
||||||
rm -f ./.env
|
# 停止并删除旧容器
|
||||||
docker cp ${{ vars.JOB_CONTAINER_NAME }}:${{ github.workspace }}/deploy/.env ./.env
|
if docker ps -a | grep -q ppanel-server; then
|
||||||
source ./.env
|
echo "停止旧容器..."
|
||||||
if [ -n "${{ vars.RUNNER_CONTAINER_NAME }}" ]; then
|
docker stop ppanel-server || true
|
||||||
docker cp .env ${{ vars.RUNNER_CONTAINER_NAME }}:/.env
|
docker rm ppanel-server || true
|
||||||
docker exec ${{ vars.RUNNER_CONTAINER_NAME }} /bin/bash -c "source /.env"
|
|
||||||
else
|
|
||||||
echo "RUNNER_CONTAINER_NAME is not set, skipping container operations"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
- name: Setup Go environment with cache
|
# 拉取最新镜像
|
||||||
uses: https://${{ env.GIT_USERNAME }}:${{ env.GIT_PASSWORD }}@${{ vars.DOMAIN_OF_GITEA}}/actions/setup-go@main
|
echo "拉取最新镜像..."
|
||||||
|
docker pull ${{ env.REPO }}:latest
|
||||||
|
|
||||||
|
# 启动新容器
|
||||||
|
echo "启动新容器..."
|
||||||
|
docker run -d \
|
||||||
|
--name ppanel-server \
|
||||||
|
--restart unless-stopped \
|
||||||
|
-p 8080:8080 \
|
||||||
|
${{ env.REPO }}:latest
|
||||||
|
|
||||||
|
# 检查容器状态
|
||||||
|
sleep 5
|
||||||
|
if docker ps | grep -q ppanel-server; then
|
||||||
|
echo "✅ 容器启动成功"
|
||||||
|
else
|
||||||
|
echo "❌ 容器启动失败"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 步骤5: TG通知 (成功)
|
||||||
|
- name: 📱 发送成功通知到Telegram
|
||||||
|
if: success()
|
||||||
|
uses: chapvic/telegram-notify@master
|
||||||
with:
|
with:
|
||||||
go-version: ${{ matrix.go }}
|
bot_token: ${{ env.TG_BOT_TOKEN }}
|
||||||
cache: true
|
chat_id: ${{ env.TG_CHAT_ID }}
|
||||||
cache-dependency-path: go.sum
|
message: |
|
||||||
|
✅ **部署成功!**
|
||||||
|
|
||||||
- name: Prepare GO environment
|
📦 **项目**: ${{ github.repository }}
|
||||||
run: |
|
🌿 **分支**: ${{ github.ref_name }}
|
||||||
go env -w GOPROXY=https://goproxy.cn,direct
|
📝 **提交**: ${{ github.sha }}
|
||||||
go env -w GOPRIVATE="${{ vars.DOMAIN_OF_GITEA}}"
|
👤 **提交者**: ${{ github.actor }}
|
||||||
go env -w GOSUMDB=off
|
🕐 **时间**: ${{ github.event.head_commit.timestamp }}
|
||||||
git config --global url."https://${{ env.GIT_USERNAME }}:${{ env.GIT_PASSWORD }}@${{ vars.DOMAIN_OF_GITEA}}/".insteadOf "https://${{ vars.DOMAIN_OF_GITEA}}/"
|
|
||||||
go clean -modcache
|
🚀 **服务已成功部署到生产环境**
|
||||||
rm -rf go.sum
|
parse_mode: Markdown
|
||||||
|
|
||||||
- name: Build and push docker image
|
# 步骤5: TG通知 (失败)
|
||||||
run: |
|
- name: 📱 发送失败通知到Telegram
|
||||||
source ${{ gitea.workspace }}/deploy/.env
|
if: failure()
|
||||||
go mod tidy
|
uses: chapvic/telegram-notify@master
|
||||||
make build-linux
|
with:
|
||||||
make docker
|
bot_token: ${{ env.TG_BOT_TOKEN }}
|
||||||
make publish-docker
|
chat_id: ${{ env.TG_CHAT_ID }}
|
||||||
make docker-run
|
message: |
|
||||||
|
❌ **部署失败!**
|
||||||
|
|
||||||
|
📦 **项目**: ${{ github.repository }}
|
||||||
|
🌿 **分支**: ${{ github.ref_name }}
|
||||||
|
📝 **提交**: ${{ github.sha }}
|
||||||
|
👤 **提交者**: ${{ github.actor }}
|
||||||
|
🕐 **时间**: ${{ github.event.head_commit.timestamp }}
|
||||||
|
|
||||||
|
⚠️ **请检查构建日志获取详细信息**
|
||||||
|
parse_mode: Markdown
|
||||||
|
|
||||||
31
deploy/.env
31
deploy/.env
@ -1,31 +0,0 @@
|
|||||||
#******** MODIFY THE FOLLOWING VARIABLES TO YOUR OWN SETTINGS ********#
|
|
||||||
# 构建说明:
|
|
||||||
# 1. docker-compose.yaml文件放置目录为:/deploy/docker-compose/project/
|
|
||||||
# 2. 将swagger json文件添加至 api dockerfile的app目录中,用于两个容器之间的文件中转。
|
|
||||||
|
|
||||||
# PROJECT DEFINE
|
|
||||||
export DOMAIN=api.kxsw.us
|
|
||||||
export PROJECT_NAME=ppanel # 容器项目名称
|
|
||||||
export SERVICE_NAME=server # 容器服务名称
|
|
||||||
export API_INNER_PORT=8080
|
|
||||||
export API_EXTERNAL_PORT=8080
|
|
||||||
|
|
||||||
# Container Repository
|
|
||||||
export REGISTRY_URL=registry.kxsw.us # 本地 Docker Registry 地址,请根据实际情况修改
|
|
||||||
export REGISTRY_NAMESPACE=ppanel # 镜像仓库命名空间
|
|
||||||
# Project DockerCompose File
|
|
||||||
export DOCKER_COMPOSE_FILE=deploy/project/docker-compose.yaml
|
|
||||||
|
|
||||||
# DOCKER VARS
|
|
||||||
export DOCKER_PROJECT_NAME=${PROJECT_NAME}-${SERVICE_NAME} # 项目名称,需要保持全局唯一
|
|
||||||
|
|
||||||
export DOCKER_NETWORK_NAME=ppanel-network
|
|
||||||
# API DOCKER DEFINE don't forget modify the service name in docker-compose file
|
|
||||||
export API_PROJECT_BUILD_SUFFIX=api
|
|
||||||
export API_LOG_DIR=/home/logs/${PROJECT_NAME}-${SERVICE_NAME}/${API_PROJECT_BUILD_SUFFIX}
|
|
||||||
export GITEA_RUNNER_NAME=ubuntu-latest #*修改为你自己的gitea-runner容器名称
|
|
||||||
|
|
||||||
#******** DON'T MODIFY THE FOLLOWING VARIABLES ********#
|
|
||||||
#### API ENVS
|
|
||||||
export API_IMAGE_NAME=${REGISTRY_URL}/${REGISTRY_NAMESPACE}/${PROJECT_NAME}-${SERVICE_NAME}-${API_PROJECT_BUILD_SUFFIX}
|
|
||||||
export API_CONTAINER_NAME=${PROJECT_NAME}-${SERVICE_NAME}-${API_PROJECT_BUILD_SUFFIX}
|
|
||||||
@ -1,17 +0,0 @@
|
|||||||
services:
|
|
||||||
# need modify service name to your owner
|
|
||||||
server-api:
|
|
||||||
image: ${API_IMAGE_NAME}
|
|
||||||
container_name: ${API_CONTAINER_NAME}
|
|
||||||
restart: always
|
|
||||||
ports:
|
|
||||||
- ${API_EXTERNAL_PORT}:${API_INNER_PORT}
|
|
||||||
volumes:
|
|
||||||
- ${API_LOG_DIR}:/app/logs
|
|
||||||
environment:
|
|
||||||
- TZ=Asia/Shanghai
|
|
||||||
|
|
||||||
networks:
|
|
||||||
default:
|
|
||||||
name: ${DOCKER_NETWORK_NAME}
|
|
||||||
external: true
|
|
||||||
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Loading…
x
Reference in New Issue
Block a user