II.
StackProfile JSON
Structured · livestack-profile:event-sourcing-cqrs
Event Sourcing / CQRS Stack (TypeScript, NestJS, PostgreSQL, Redis, Docker) json
Inspect the normalized record payload exactly as the atlas UI reads it.
{
"id": "stack-profile:event-sourcing-cqrs",
"_kind": "StackProfile",
"_file": "domain/stack-profiles/deep-stacks-3.yaml",
"_cluster": "domain",
"attributes": {
"displayName": "Event Sourcing / CQRS Stack (TypeScript, NestJS, PostgreSQL, Redis, Docker)",
"description": "An event-sourced architecture implementing Command Query Responsibility\nSegregation (CQRS) where every state change is captured as an immutable\nevent in an append-only event store backed by PostgreSQL. NestJS\nprovides the application framework with its CQRS module for command\nhandlers, event handlers, and sagas. Redis powers the read-side\nprojections for fast query performance and caches materialized views.\nNATS or RabbitMQ distributes events to downstream consumers for\nbuilding additional read models or triggering side effects. Docker\norchestrates the multi-service deployment. This pattern excels for\ndomains with complex business rules, audit requirements, and temporal\nqueries (what was the state at time T?). The tradeoff is significant\ncognitive overhead — developers must reason about eventual consistency,\nevent schema evolution, and projection rebuilds.\n",
"composes": [
"language:typescript",
"framework:nestjs",
"library:prisma",
"library:ioredis",
"tool:nats",
"tool:docker"
]
},
"outgoingEdges": [
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "language:typescript",
"kind": "composed_of"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "framework:nestjs",
"kind": "composed_of"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "library:prisma",
"kind": "composed_of"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "library:ioredis",
"kind": "composed_of"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "tool:nats",
"kind": "composed_of"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "tool:docker",
"kind": "composed_of"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "library:zod",
"kind": "composed_of"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "tool:docker-compose",
"kind": "composed_of"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "role:backend-engineer",
"kind": "used_by_role"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "role:architect",
"kind": "used_by_role"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "role:tech-lead",
"kind": "used_by_role"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "workflow:event-driven-architecture-review",
"kind": "follows_workflow"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "workflow:schema-migration",
"kind": "follows_workflow"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "domain:software-engineering",
"kind": "applies_to"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "domain:backend",
"kind": "applies_to"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "skill-area:event-sourcing",
"kind": "requires_skill_area"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "skill-area:cqrs",
"kind": "requires_skill_area"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "skill-area:event-driven-architecture",
"kind": "requires_skill_area"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "skill-area:domain-driven-design",
"kind": "requires_skill_area"
},
{
"from": "stack-profile:event-sourcing-cqrs",
"to": "skill-area:backend-data-persistence",
"kind": "requires_skill_area"
}
],
"incomingEdges": []
}