TL;DR
Was: GitHubs eingebaute CI/CD- und Automatisierungsplattform.
Warum: Native GitHub-Integration, kostenlos für öffentliche Repos, Marktplatz mit Actions, Matrix-Builds.
Quick Start
Erstellen Sie .github/workflows/ci.yml:
name: CI
on:
push:
branches: [main]
pull_request:
branches: [main]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: actions/setup-node@v4
with:
node-version: '20'
- run: npm ci
- run: npm test
Pushen Sie, um den Workflow auszulösen.
Cheatsheet
| Trigger | Syntax |
|---|---|
| Push | on: push |
| Pull Request | on: pull_request |
| Zeitplan | on: schedule: - cron: '0 0 * * *' |
| Manuell | on: workflow_dispatch |
| Anderer Workflow | on: workflow_call |
Gotchas
Matrix builds
jobs:
test:
runs-on: ubuntu-latest
strategy:
matrix:
node: [18, 20, 22]
os: [ubuntu-latest, windows-latest]
steps:
- uses: actions/setup-node@v4
with:
node-version: ${{ matrix.node }}
Secrets and environment variables
jobs:
deploy:
runs-on: ubuntu-latest
env:
NODE_ENV: production
steps:
- run: echo ${{ secrets.API_KEY }}
- run: echo $NODE_ENV
Caching dependencies
- uses: actions/cache@v4
with:
path: ~/.npm
key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
Conditional steps
- name: Deploy
if: github.ref == 'refs/heads/main'
run: ./deploy.sh
Artifacts
- uses: actions/upload-artifact@v4
with:
name: build
path: dist/
Next Steps
- GitHub Actions Dokumentation - Offizielle Docs
- Actions Marktplatz - Vorgefertigte Actions
- Workflow Syntax - Referenz
- GitHub Actions Patterns - Beispiele