github-workflow.yml
GitHub Actions Workflow (Multi-Stage CI/CD)
1. Basic Multi-Stage GitHub Actions Workflow
name: CI/CD Pipeline
on:
push:
branches:
- main
pull_request:
branches:
- main
jobs:
build:
runs-on: ubuntu-latest
steps:
- name: Checkout Code
uses: actions/checkout@v4
- name: Set up Node.js
uses: actions/setup-node@v4
with:
node-version: 18
- name: Install Dependencies
run: npm install
- name: Run Linter
run: npm run lint
- name: Run Tests
run: npm test
docker-build:
runs-on: ubuntu-latest
needs: build
steps:
- name: Checkout Code
uses: actions/checkout@v4
- name: Log in to Docker Hub
uses: docker/login-action@v3
with:
username: ${{ secrets.DOCKER_USERNAME }}
password: ${{ secrets.DOCKER_PASSWORD }}
- name: Build and Push Docker Image
run: |
docker build -t mydockerhub/myapp:latest .
docker push mydockerhub/myapp:latest
deploy:
runs-on: ubuntu-latest
needs: docker-build
environment: production
if: github.ref == 'refs/heads/main'
steps:
- name: Checkout Code
uses: actions/checkout@v4
- name: Deploy Application
run: ./deploy.sh2. Breakdown of Workflow Sections
2.1 on (Triggers)
on (Triggers)2.2 Jobs & Dependencies
Job
Purpose
Dependency
2.3 runs-on
runs-on2.4 Docker Authentication
2.5 Conditional Deployment
3. Optimized Multi-Stage GitHub Actions Workflow
4. GitHub Actions Best Practices
5. Scenario-Based Interview Questions
Q1: How do you prevent a deployment on pull requests?
Q2: How can you cache dependencies in GitHub Actions?
Q3: How do you securely store API keys in GitHub Actions?
Q4: How do you ensure that only the main branch can deploy to production?
main branch can deploy to production?6. Summary
Topic
Key Takeaways
Last updated