docfast/DEPLOYMENT.md
openclawd 7d3525fe57 Add CI/CD deployment pipeline with Forgejo Actions
- Add .forgejo/workflows/deploy.yml for automated deployment
- Include rollback mechanism with image tagging
- Add health check verification (http://127.0.0.1:3100/health)
- Create manual rollback script for emergency use
- Add deployment documentation and setup instructions
- Supports auto-rollback on deployment failure
2026-02-15 11:02:43 +00:00

2.1 KiB

DocFast CI/CD Deployment

This repository uses Forgejo Actions for automated deployment to production.

Setup Instructions

1. Repository Secrets

Go to repository settings → Actions → Secrets and add these secrets:

  • SERVER_HOST: 167.235.156.214
  • SERVER_USER: root
  • SSH_PRIVATE_KEY: The private SSH key content from /home/openclaw/.ssh/docfast

2. How Deployment Works

Trigger: Push to main branch Process:

  1. SSH to production server
  2. Pull latest code from git
  3. Tag current Docker image for rollback
  4. Build new Docker image
  5. Stop current services
  6. Start new services
  7. Health check at http://127.0.0.1:3100/health
  8. Rollback automatically if health check fails

3. Rollback Procedure

Automatic Rollback:

  • Happens automatically if deployment fails health checks
  • Reverts to the previously tagged image

Manual Rollback:

# On the production server
cd /root/docfast
./scripts/rollback.sh

Emergency Rollback via SSH:

ssh root@167.235.156.214
cd /root/docfast
docker compose down
docker tag docfast-docfast:rollback-YYYYMMDD-HHMMSS docfast-docfast:latest
docker compose up -d

4. Monitoring

  • Health Check: curl http://127.0.0.1:3100/health
  • Service Status: docker compose ps
  • Logs: docker compose logs -f

5. File Structure

.forgejo/workflows/deploy.yml  # Main deployment workflow
scripts/rollback.sh           # Manual rollback script  
scripts/setup-secrets.sh      # Helper for setting up secrets
DEPLOYMENT.md                 # This documentation

6. Testing the Pipeline

  1. Make a small change (e.g., bump version comment)
  2. Commit and push to main branch
  3. Check Actions tab in Forgejo to see deployment progress
  4. Verify service is running with curl http://127.0.0.1:3100/health

Troubleshooting

  • SSH Issues: Ensure SSH key is properly added to secrets
  • Docker Build Issues: Check server has enough disk space and memory
  • Health Check Fails: Check if service is binding to correct port (3100)
  • Permission Issues: Ensure user has Docker privileges on server