Add CI/CD workflows for development and production deployments
Some checks failed
Deploy Development / deploy (push) Failing after 29s
Some checks failed
Deploy Development / deploy (push) Failing after 29s
- Created `deploy-dev.yml` for automated deployment to the development server on push to the `dev` branch. - Created `deploy.yml` for automated deployment to the production server on push to the `main` or `master` branches. - Added deployment instructions in `DEPLOYMENT-PORTAINER.md` for using Portainer and Traefik. - Documented Gitea Actions deployment process in `DEPLOYMENT.md`. - Configured Traefik SSL settings in `TRAEFIK-SSL-CONFIG.md` for both development and production environments. - Implemented a deployment script `deploy.sh` for manual deployments. - Added Docker Compose configurations for development (`docker-compose.portainer.dev.yml`) and production (`docker-compose.portainer.yml`) environments. - Updated main `docker-compose.yml` to support Traefik integration and environment variable configurations.
This commit is contained in:
46
.gitea/workflows/build-push.yml
Normal file
46
.gitea/workflows/build-push.yml
Normal file
@@ -0,0 +1,46 @@
|
||||
name: Build and Push Docker Image
|
||||
|
||||
on:
|
||||
push:
|
||||
tags:
|
||||
- 'v*'
|
||||
workflow_dispatch:
|
||||
|
||||
jobs:
|
||||
build-and-push:
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- name: Checkout code
|
||||
uses: actions/checkout@v3
|
||||
|
||||
- name: Set up Docker Buildx
|
||||
uses: docker/setup-buildx-action@v2
|
||||
|
||||
- name: Login to Docker Registry
|
||||
uses: docker/login-action@v2
|
||||
with:
|
||||
registry: ${{ secrets.DOCKER_REGISTRY_URL }}
|
||||
username: ${{ secrets.DOCKER_USERNAME }}
|
||||
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||
|
||||
- name: Extract metadata
|
||||
id: meta
|
||||
uses: docker/metadata-action@v4
|
||||
with:
|
||||
images: ${{ secrets.DOCKER_REGISTRY_URL }}/merchbay_admin
|
||||
tags: |
|
||||
type=semver,pattern={{version}}
|
||||
type=semver,pattern={{major}}.{{minor}}
|
||||
type=semver,pattern={{major}}
|
||||
type=raw,value=latest
|
||||
|
||||
- name: Build and push
|
||||
uses: docker/build-push-action@v4
|
||||
with:
|
||||
context: .
|
||||
push: true
|
||||
tags: ${{ steps.meta.outputs.tags }}
|
||||
labels: ${{ steps.meta.outputs.labels }}
|
||||
cache-from: type=registry,ref=${{ secrets.DOCKER_REGISTRY_URL }}/merchbay_admin:buildcache
|
||||
cache-to: type=registry,ref=${{ secrets.DOCKER_REGISTRY_URL }}/merchbay_admin:buildcache,mode=max
|
||||
111
.gitea/workflows/deploy-dev.yml
Normal file
111
.gitea/workflows/deploy-dev.yml
Normal file
@@ -0,0 +1,111 @@
|
||||
name: Deploy Development
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- dev
|
||||
workflow_dispatch:
|
||||
|
||||
jobs:
|
||||
deploy:
|
||||
runs-on: ubuntu-latest
|
||||
|
||||
steps:
|
||||
- name: Checkout code
|
||||
uses: actions/checkout@v3
|
||||
|
||||
- name: Set up Docker Buildx
|
||||
uses: docker/setup-buildx-action@v2
|
||||
|
||||
- name: Build Docker Image
|
||||
run: |
|
||||
docker build -t merchbay_admin:dev .
|
||||
|
||||
- name: Save Docker Image
|
||||
run: |
|
||||
docker save merchbay_admin:dev | gzip > merchbay_admin_dev.tar.gz
|
||||
|
||||
- name: Deploy to Development Server via SSH
|
||||
uses: appleboy/scp-action@master
|
||||
with:
|
||||
host: ${{ secrets.DEPLOY_HOST }}
|
||||
username: ${{ secrets.DEPLOY_USER }}
|
||||
key: ${{ secrets.DEPLOY_SSH_KEY }}
|
||||
port: ${{ secrets.DEPLOY_PORT || 22 }}
|
||||
source: "merchbay_admin_dev.tar.gz,docker-compose.yml"
|
||||
target: "/tmp/merchbay_admin_dev_deploy"
|
||||
|
||||
- name: Execute Development Deployment Script
|
||||
uses: appleboy/ssh-action@master
|
||||
with:
|
||||
host: ${{ secrets.DEPLOY_HOST }}
|
||||
username: ${{ secrets.DEPLOY_USER }}
|
||||
key: ${{ secrets.DEPLOY_SSH_KEY }}
|
||||
port: ${{ secrets.DEPLOY_PORT || 22 }}
|
||||
script: |
|
||||
# Set deployment directory for dev
|
||||
DEPLOY_DIR="/var/www/merchbay_admin_dev"
|
||||
|
||||
# Create deployment directory if it doesn't exist
|
||||
mkdir -p $DEPLOY_DIR
|
||||
|
||||
# Load the Docker image
|
||||
cd /tmp/merchbay_admin_dev_deploy
|
||||
docker load < merchbay_admin_dev.tar.gz
|
||||
|
||||
# Copy docker-compose.yml to deployment directory
|
||||
cp docker-compose.yml $DEPLOY_DIR/
|
||||
|
||||
# Navigate to deployment directory
|
||||
cd $DEPLOY_DIR
|
||||
|
||||
# Update environment file for dev
|
||||
cat > .env << EOF
|
||||
APP_ENV=staging
|
||||
APP_DEBUG=false
|
||||
APP_URL=https://dev.merchbay.app
|
||||
DB_HOST=${{ secrets.DEV_DB_HOST }}
|
||||
DB_PORT=${{ secrets.DEV_DB_PORT || 3306 }}
|
||||
DB_DATABASE=${{ secrets.DEV_DB_DATABASE }}
|
||||
DB_USERNAME=${{ secrets.DEV_DB_USERNAME }}
|
||||
DB_PASSWORD=${{ secrets.DEV_DB_PASSWORD }}
|
||||
DOMAIN=dev.merchbay.app
|
||||
EOF
|
||||
|
||||
# Stop existing container
|
||||
docker compose down || true
|
||||
|
||||
# Remove old image
|
||||
docker image prune -f
|
||||
|
||||
# Ensure Traefik network exists
|
||||
docker network inspect traefik-public >/dev/null 2>&1 || docker network create traefik-public
|
||||
|
||||
# Update docker-compose for dev
|
||||
export DOMAIN=dev.merchbay.app
|
||||
export APP_URL=https://dev.merchbay.app
|
||||
|
||||
# Start the application
|
||||
docker compose up -d
|
||||
|
||||
# Wait for container to be ready
|
||||
sleep 10
|
||||
|
||||
# Run migrations
|
||||
docker compose exec -T app php artisan migrate --force
|
||||
|
||||
# Clear and cache configuration
|
||||
docker compose exec -T app php artisan config:cache
|
||||
docker compose exec -T app php artisan route:cache
|
||||
docker compose exec -T app php artisan view:cache
|
||||
|
||||
# Cleanup
|
||||
rm -rf /tmp/merchbay_admin_dev_deploy
|
||||
|
||||
echo "Development deployment completed successfully!"
|
||||
echo "Application available at: https://dev.merchbay.app"
|
||||
|
||||
- name: Health Check
|
||||
run: |
|
||||
sleep 10
|
||||
curl -f https://dev.merchbay.app || exit 1
|
||||
122
.gitea/workflows/deploy.yml
Normal file
122
.gitea/workflows/deploy.yml
Normal file
@@ -0,0 +1,122 @@
|
||||
name: Deploy Production
|
||||
|
||||
on:
|
||||
push:
|
||||
branches:
|
||||
- main
|
||||
- master
|
||||
workflow_dispatch:
|
||||
|
||||
jobs:
|
||||
deploy:
|
||||
runs-on: ubuntu-latest
|
||||
# If using self-hosted runner, change to:
|
||||
# runs-on: self-hosted
|
||||
|
||||
steps:
|
||||
- name: Checkout code
|
||||
uses: actions/checkout@v3
|
||||
|
||||
- name: Set up Docker Buildx
|
||||
uses: docker/setup-buildx-action@v2
|
||||
|
||||
- name: Login to Docker Registry (Optional)
|
||||
if: ${{ secrets.DOCKER_REGISTRY_URL != '' }}
|
||||
uses: docker/login-action@v2
|
||||
with:
|
||||
registry: ${{ secrets.DOCKER_REGISTRY_URL }}
|
||||
username: ${{ secrets.DOCKER_USERNAME }}
|
||||
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||
|
||||
- name: Build Docker Image
|
||||
run: |
|
||||
docker build -t merchbay_admin:latest .
|
||||
|
||||
- name: Save Docker Image
|
||||
run: |
|
||||
docker save merchbay_admin:latest | gzip > merchbay_admin.tar.gz
|
||||
|
||||
- name: Deploy to Server via SSH
|
||||
uses: appleboy/scp-action@master
|
||||
with:
|
||||
host: ${{ secrets.DEPLOY_HOST }}
|
||||
username: ${{ secrets.DEPLOY_USER }}
|
||||
key: ${{ secrets.DEPLOY_SSH_KEY }}
|
||||
port: ${{ secrets.DEPLOY_PORT || 22 }}
|
||||
source: "merchbay_admin.tar.gz,docker-compose.yml"
|
||||
target: "/tmp/merchbay_admin_deploy"
|
||||
|
||||
- name: Execute Production Deployment Script
|
||||
uses: appleboy/ssh-action@master
|
||||
with:
|
||||
host: ${{ secrets.PROD_DEPLOY_HOST }}
|
||||
username: ${{ secrets.PROD_DEPLOY_USER }}
|
||||
key: ${{ secrets.PROD_DEPLOY_SSH_KEY }}
|
||||
port: ${{ secrets.PROD_DEPLOY_PORT || 22 }}
|
||||
script: |
|
||||
# Set deployment directory for production
|
||||
DEPLOY_DIR="/var/www/merchbay_admin"
|
||||
|
||||
# Create deployment directory if it doesn't exist
|
||||
mkdir -p $DEPLOY_DIR
|
||||
|
||||
# Load the Docker image
|
||||
cd /tmp/merchbay_admin_deploy
|
||||
docker load < merchbay_admin.tar.gz
|
||||
|
||||
# Copy docker-compose.yml to deployment directory
|
||||
cp docker-compose.yml $DEPLOY_DIR/
|
||||
|
||||
# Navigate to deployment directory
|
||||
cd $DEPLOY_DIR
|
||||
|
||||
# Update environment file for production
|
||||
cat > .env << EOF
|
||||
APP_ENV=production
|
||||
APP_DEBUG=false
|
||||
APP_URL=https://merchbay.app
|
||||
DB_HOST=${{ secrets.PROD_DB_HOST }}
|
||||
DB_PORT=${{ secrets.PROD_DB_PORT || 3306 }}
|
||||
DB_DATABASE=${{ secrets.PROD_DB_DATABASE }}
|
||||
DB_USERNAME=${{ secrets.PROD_DB_USERNAME }}
|
||||
DB_PASSWORD=${{ secrets.PROD_DB_PASSWORD }}
|
||||
DOMAIN=merchbay.app
|
||||
EOF
|
||||
|
||||
# Stop existing container (disconnect from Traefik network gracefully)
|
||||
docker compose down || true
|
||||
|
||||
# Remove old image (optional, keeps only latest)
|
||||
docker image prune -f
|
||||
|
||||
# Ensure Traefik network exists
|
||||
docker network inspect traefik-public >/dev/null 2>&1 || docker network create traefik-public
|
||||
|
||||
# Update docker-compose for production
|
||||
export DOMAIN=merchbay.app
|
||||
export APP_URL=https://merchbay.app
|
||||
|
||||
# Start the application (will auto-connect to Traefik with paid SSL)
|
||||
docker compose up -d
|
||||
|
||||
# Wait for container to be ready
|
||||
sleep 10
|
||||
|
||||
# Run migrations
|
||||
docker compose exec -T app php artisan migrate --force
|
||||
|
||||
# Clear and cache configuration
|
||||
docker compose exec -T app php artisan config:cache
|
||||
docker compose exec -T app php artisan route:cache
|
||||
docker compose exec -T app php artisan view:cache
|
||||
|
||||
# Cleanup
|
||||
rm -rf /tmp/merchbay_admin_deploy
|
||||
|
||||
echo "Production deployment completed successfully!"
|
||||
echo "Application available at: https://merchbay.app"
|
||||
|
||||
- name: Health Check
|
||||
run: |
|
||||
sleep 10
|
||||
curl -f https://merchbay.app || exit 1
|
||||
Reference in New Issue
Block a user