76 lines
2.8 KiB
YAML
76 lines
2.8 KiB
YAML
name: Deploy to Test
|
|
on:
|
|
push:
|
|
branches: [dev]
|
|
|
|
jobs:
|
|
deploy:
|
|
runs-on: ubuntu-22.04
|
|
timeout-minutes: 20 # 延长超时时间[1](@ref)
|
|
|
|
steps:
|
|
- name: Checkout code
|
|
uses: actions/checkout@v4
|
|
with:
|
|
# 指定分支、标签或提交哈希
|
|
ref: dev
|
|
# 拉取深度(节省时间与带宽)
|
|
fetch-depth: 0 # 0 表示拉取完整的历史
|
|
|
|
- name: Replace Debian APT sources
|
|
run: |
|
|
tee /etc/apt/sources.list <<EOF
|
|
# 清华大学 Debian 11 Bullseye 镜像
|
|
deb https://mirrors.tuna.tsinghua.edu.cn/debian/ bullseye main contrib non-free
|
|
deb https://mirrors.tuna.tsinghua.edu.cn/debian/ bullseye-updates main contrib non-free
|
|
deb https://mirrors.tuna.tsinghua.edu.cn/debian/ bullseye-backports main contrib non-free
|
|
deb https://mirrors.tuna.tsinghua.edu.cn/debian-security bullseye-security main contrib non-free
|
|
EOF
|
|
|
|
- name: Install SSH tools
|
|
run: |
|
|
apt-get update && apt-get install -y openssh-client rsync
|
|
|
|
- name: Configure SSH
|
|
env:
|
|
SSH_PRIVATE_KEY: ${{ secrets.COMMON_USER_RSA }}
|
|
run: |
|
|
SSH_DIR="/root/.ssh"
|
|
mkdir -p $SSH_DIR
|
|
echo "$SSH_PRIVATE_KEY" > $SSH_DIR/id_rsa
|
|
whoami
|
|
echo "$SSH_PRIVATE_KEY"
|
|
chmod 700 $SSH_DIR
|
|
chmod 600 $SSH_DIR/id_rsa
|
|
ssh-keyscan 192.168.110.108 >> $SSH_DIR/known_hosts
|
|
|
|
- name: Sync code
|
|
run: |
|
|
rsync -avz --delete --exclude=".env" \
|
|
-e "ssh -o StrictHostKeyChecking=no -i /root/.ssh/id_rsa" \
|
|
--rsync-path="mkdir -p /home/common-user/demo/test_runner && rsync" \
|
|
./ common-user@192.168.110.108:/home/common-user/demo/test_runner
|
|
|
|
- name: Deploy containers
|
|
run: |
|
|
ssh -i /root/.ssh/id_rsa common-user@192.168.110.108 /bin/bash << 'EOF'
|
|
COMPOSE_PROJECT="test_runner"
|
|
echo "DEBUG - COMPOSE_PROJECT=${COMPOSE_PROJECT}" # 确认变量值
|
|
cd /home/common-user/demo/test_runner
|
|
|
|
# 使用docker-compose插件模式
|
|
/usr/bin/docker compose -p "${COMPOSE_PROJECT}" down --volumes || true
|
|
/usr/bin/docker compose -p "${COMPOSE_PROJECT}" up -d --build
|
|
|
|
# 等待 PHP 容器健康状态
|
|
while [ $(docker inspect --format "{{.State.Health.Status}}" ${COMPOSE_PROJECT}-php-1) != "healthy" ]; do
|
|
echo "等待 PHP 容器就绪..."
|
|
sleep 5
|
|
done
|
|
|
|
docker exec "${COMPOSE_PROJECT}-php-1" composer install --no-dev --optimize-autoloader
|
|
docker exec "${COMPOSE_PROJECT}-php-1" php artisan key:generate
|
|
docker exec "${COMPOSE_PROJECT}-php-1" php artisan config:cache
|
|
docker exec "${COMPOSE_PROJECT}-nginx-1" nginx -s reload
|
|
EOF
|