Phase Plans (5 files): - 04-RESEARCH.md: Domain research on Docker limits, healthchecks, EC2 parallels - 04-VALIDATION.md: Success criteria and validation strategy - 04-01-PLAN.md: Test infrastructure (RED phase) - 04-02-PLAN.md: Diátxis documentation - 04-03-PLAN.md: Infrastructure implementation (GREEN phase) Test Scripts (6 files, 1300+ lines): - 01-resource-limits-test.sh: Validate INF-03 compliance - 02-healthcheck-test.sh: Validate healthcheck configuration - 03-enforcement-test.sh: Verify resource limits with docker stats - 04-verify-infrastructure.sh: Infrastructure verification - 99-final-verification.sh: End-to-end student verification - run-all-tests.sh: Test orchestration with fail-fast - quick-test.sh: Fast validation (<30s) Documentation (11 files, 2500+ lines): Tutorials (3): - 01-set-resource-limits.md: EC2 instance types, Docker limits syntax - 02-implement-healthchecks.md: ELB health check parallels - 03-dependencies-with-health.md: depends_on with service_healthy How-to Guides (4): - check-resource-usage.md: docker stats monitoring - test-limits-enforcement.md: Stress testing CPU/memory - custom-healthcheck.md: HTTP, TCP, database healthchecks - instance-type-mapping.md: Docker limits → EC2 mapping Reference (3): - compose-resources-syntax.md: Complete deploy.resources reference - healthcheck-syntax.md: All healthcheck parameters - ec2-instance-mapping.md: Instance type mapping table Explanation (1): - compute-ec2-parallels.md: Container=EC2, Limits=Instance Type, Healthcheck=ELB Infrastructure: - docker-compose.yml: 5 services (web, app, worker, db, stress-test) All services: INF-03 compliant (cpus + memory limits) All services: healthcheck configured EC2 parallels: t2.nano, t2.micro, t2.small, t2.medium, m5.large - Dockerfile: Alpine 3.19 + stress tools + non-root user Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
141 lines
2.7 KiB
YAML
141 lines
2.7 KiB
YAML
# Lab 03: Compute & EC2 - Docker Compose Configuration
|
|
# Simula diverse EC2 instance types usando resource limits Docker
|
|
|
|
version: "3.8"
|
|
|
|
services:
|
|
# Web Server - simula t2.micro (1 vCPU, 1 GB RAM)
|
|
web:
|
|
image: nginx:alpine
|
|
container_name: lab03-web
|
|
hostname: web
|
|
|
|
deploy:
|
|
resources:
|
|
limits:
|
|
cpus: '1'
|
|
memory: 1G
|
|
|
|
healthcheck:
|
|
test: ["CMD", "wget", "--quiet", "--tries=1", "--spider", "http://localhost/"]
|
|
interval: 10s
|
|
timeout: 5s
|
|
retries: 3
|
|
start_period: 5s
|
|
|
|
ports:
|
|
- "127.0.0.1:8080:80"
|
|
|
|
depends_on:
|
|
app:
|
|
condition: service_healthy
|
|
|
|
restart: unless-stopped
|
|
|
|
# Application Server - simula t2.small (1 vCPU, 2 GB RAM)
|
|
app:
|
|
image: nginx:alpine
|
|
container_name: lab03-app
|
|
hostname: app
|
|
|
|
deploy:
|
|
resources:
|
|
limits:
|
|
cpus: '1'
|
|
memory: 2G
|
|
|
|
healthcheck:
|
|
test: ["CMD", "wget", "--quiet", "--tries=1", "--spider", "http://localhost/"]
|
|
interval: 10s
|
|
timeout: 5s
|
|
retries: 3
|
|
start_period: 5s
|
|
|
|
ports:
|
|
- "127.0.0.1:8081:80"
|
|
|
|
depends_on:
|
|
db:
|
|
condition: service_healthy
|
|
|
|
restart: unless-stopped
|
|
|
|
# Worker - simula t2.medium (2 vCPU, 4 GB RAM)
|
|
worker:
|
|
image: alpine:3.19
|
|
container_name: lab03-worker
|
|
hostname: worker
|
|
|
|
command: ["sh", "-c", "sleep 3600"]
|
|
|
|
deploy:
|
|
resources:
|
|
limits:
|
|
cpus: '2'
|
|
memory: 4G
|
|
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "exit 0"]
|
|
interval: 30s
|
|
timeout: 5s
|
|
retries: 3
|
|
|
|
restart: unless-stopped
|
|
|
|
# Database - simula t2.medium (2 vCPU, 4 GB RAM)
|
|
db:
|
|
image: postgres:16-alpine
|
|
container_name: lab03-db
|
|
hostname: db
|
|
|
|
environment:
|
|
POSTGRES_DB: lab03_db
|
|
POSTGRES_USER: lab03_user
|
|
POSTGRES_PASSWORD: lab03_password
|
|
POSTGRES_INITDB_ARGS: "-E UTF8"
|
|
|
|
deploy:
|
|
resources:
|
|
limits:
|
|
cpus: '2'
|
|
memory: 4G
|
|
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "pg_isready -U lab03_user -d lab03_db || exit 1"]
|
|
interval: 10s
|
|
timeout: 5s
|
|
retries: 5
|
|
start_period: 10s
|
|
|
|
volumes:
|
|
- db-data:/var/lib/postgresql/data
|
|
|
|
restart: unless-stopped
|
|
|
|
# Stress Test Container - per verifica enforcement
|
|
stress-test:
|
|
image: alpine:3.19
|
|
container_name: lab03-stress
|
|
hostname: stress-test
|
|
|
|
command: ["sh", "-c", "sleep 3600"]
|
|
|
|
deploy:
|
|
resources:
|
|
limits:
|
|
cpus: '0.5'
|
|
memory: 512M
|
|
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "exit 0"]
|
|
interval: 5s
|
|
timeout: 3s
|
|
retries: 3
|
|
|
|
restart: unless-stopped
|
|
|
|
# Persistent Volumes
|
|
volumes:
|
|
db-data:
|
|
driver: local
|