docs(devops): update all documentation for DockerSpec compliance
- Replace all docker-compose.yml/docker-compose.monitoring.yml references with compose.yaml/compose.monitoring.yaml (modern Compose Spec naming) - Replace all `docker-compose` CLI commands with `docker compose` (plugin syntax) - Update Dockerfile stage descriptions: node:18-alpine → node:20.11-bookworm-slim, built-in node user → explicit nodeapp:1001 non-root user - Update image version references: postgres:14-alpine → postgres:14.12-alpine3.19, redis:7-alpine → redis:7.2-alpine3.19 - Externalize postgres credentials: hardcoded values → POSTGRES_USER/PASSWORD/DB env vars - Externalize Grafana admin password: hardcoded 'agentidp' → GF_ADMIN_PASSWORD env var - Add Docker Compose Variables section to environment-variables.md (POSTGRES_*, GF_ADMIN_PASSWORD) - Update local-development.md Step 3: cp .env.example .env, document POSTGRES_* purpose - Update quick-start.md: cp .env.example .env, use awk/sed for JWT key injection - Update 07-dev-setup.md: remove 'no .env.example' claim, reference cp .env.example - Update docker-compose.yml key file description in 04-codebase-structure.md - Update monitoring overlay launch commands across all docs (compose.yaml + compose.monitoring.yaml) - Update volume names to kebab-case: postgres_data → postgres-data, redis_data → redis-data - Fix compliance encryption-runbook: docker-compose restart agentidp → docker compose restart app All docs now consistent with compose.yaml in repo root. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -152,7 +152,10 @@ grep -E "^(DATABASE_URL|REDIS_URL|JWT_PRIVATE_KEY|JWT_PUBLIC_KEY|BILLING_ENABLED
|
||||
Expected output (values abbreviated):
|
||||
|
||||
```
|
||||
DATABASE_URL=postgresql://agentidp:password@localhost:5432/agentidp
|
||||
POSTGRES_USER=sentryagent
|
||||
POSTGRES_PASSWORD=sentryagent
|
||||
POSTGRES_DB=sentryagent_idp
|
||||
DATABASE_URL=postgresql://sentryagent:sentryagent@localhost:5432/sentryagent_idp
|
||||
REDIS_URL=redis://localhost:6379
|
||||
JWT_PRIVATE_KEY="-----BEGIN RSA PRIVATE KEY-----\n...
|
||||
JWT_PUBLIC_KEY="-----BEGIN PUBLIC KEY-----\n...
|
||||
@@ -185,10 +188,10 @@ docker compose ps
|
||||
Expected output — all three services must show `healthy`:
|
||||
|
||||
```
|
||||
NAME IMAGE STATUS
|
||||
sentryagent-idp-app-1 sentryagent-idp-app running (healthy)
|
||||
sentryagent-idp-postgres-1 postgres:14-alpine running (healthy)
|
||||
sentryagent-idp-redis-1 redis:7-alpine running (healthy)
|
||||
NAME IMAGE STATUS
|
||||
sentryagent-idp-app-1 sentryagent-idp-app running (healthy)
|
||||
sentryagent-idp-postgres-1 postgres:14.12-alpine3.19 running (healthy)
|
||||
sentryagent-idp-redis-1 redis:7.2-alpine3.19 running (healthy)
|
||||
```
|
||||
|
||||
If any service shows `starting` or `unhealthy`, wait 15 seconds and run `docker compose ps`
|
||||
@@ -787,7 +790,7 @@ Common causes:
|
||||
|
||||
| Service | Cause | Fix |
|
||||
|---------|-------|-----|
|
||||
| `postgres` | Wrong database credentials | Verify `DATABASE_URL` in `.env` matches `docker-compose.yml` credentials |
|
||||
| `postgres` | Wrong database credentials | Verify `POSTGRES_USER`, `POSTGRES_PASSWORD`, `POSTGRES_DB` in `.env` match values in `compose.yaml` |
|
||||
| `redis` | Port conflict | Check `lsof -ti:6379` and kill occupying process |
|
||||
| `app` | Missing env var | Check `docker compose logs app` for `Failed to start server` message |
|
||||
|
||||
@@ -825,7 +828,7 @@ Cause: A previous partial migration run left the database in an inconsistent sta
|
||||
Fix: Check which migrations have been applied:
|
||||
|
||||
```bash
|
||||
docker compose exec postgres psql -U agentidp -d agentidp \
|
||||
docker compose exec postgres psql -U sentryagent -d sentryagent_idp \
|
||||
-c "SELECT name FROM schema_migrations ORDER BY name;"
|
||||
```
|
||||
|
||||
|
||||
Reference in New Issue
Block a user