KS
Killer-Skills

architecture-patterns — how to use architecture-patterns how to use architecture-patterns, what is architecture-patterns, architecture-patterns alternative, architecture-patterns vs competing skills, architecture-patterns install, architecture-patterns setup guide, objective software architecture, deterministic design systems

v2.0.0
GitHub

About this Skill

Perfect for Software Development Agents needing objective decisions about software architecture and design systems Architecture-patterns is a skill that enables developers to make informed, objective decisions about software architecture, following a fundamental rule of objectivity.

Features

Encourages objective decision-making for software architecture
Follows a fundamental rule of objectivity in system design
Avoids subjective responses like 'Depende dos requisitos do seu sistema...'
Promotes deterministic design systems
Supports developers in optimizing system architecture

# Core Topics

criptogus criptogus
[0]
[0]
Updated: 3/7/2026

Quality Score

Top 5%
47
Excellent
Based on code quality & docs
Installation
SYS Universal Install (Auto-Detect)
Cursor IDE Windsurf IDE VS Code IDE
> npx killer-skills add criptogus/liquid-ai/architecture-patterns

Agent Capability Analysis

The architecture-patterns MCP Server by criptogus is an open-source Categories.community integration for Claude and other AI agents, enabling seamless task automation and capability expansion. Optimized for how to use architecture-patterns, what is architecture-patterns, architecture-patterns alternative.

Ideal Agent Persona

Perfect for Software Development Agents needing objective decisions about software architecture and design systems

Core Value

Empowers agents to make objective decisions about software architecture, promoting deterministic design systems using architecture patterns, and optimizing system design with objective and useful responses

Capabilities Granted for architecture-patterns MCP Server

Evaluating system design trade-offs
Optimizing software architecture for scalability
Generating objective design recommendations

! Prerequisites & Limits

  • Requires understanding of software architecture principles
  • May not cover all edge cases or specific system requirements
Project
SKILL.md
24.3 KB
.cursorrules
1.2 KB
package.json
240 B
Ready
UTF-8

# Tags

[No tags]
SKILL.md
Readonly

Architecture Patterns - Design de Sistemas

Esta skill ajuda você a tomar decisões OBJETIVAS sobre arquitetura de software.

Regra Fundamental: OBJETIVIDADE

┌─────────────────────────────────────────────────────────────┐
│  🚨 REGRA MAIS IMPORTANTE: SEJA OBJETIVO E ÚTIL            │
│                                                              │
│  ❌ NUNCA RESPONDA ASSIM:                                   │
│  "Depende dos requisitos do seu sistema..."                │
│  "Cada caso é único..."                                    │
│  "Você precisa avaliar trade-offs..."                      │
│                                                              │
│  ✅ SEMPRE RESPONDA ASSIM:                                  │
│  "Use monolito. Motivo: você tem <10 devs e <1M users"     │
│  "Pattern recomendado: Event Sourcing. Aqui está como..."  │
│  "Essa arquitetura está errada. Faça isso em vez disso..." │
│                                                              │
│  DÊ RECOMENDAÇÕES ESPECÍFICAS COM RAZÕES CLARAS.           │
└─────────────────────────────────────────────────────────────┘

Quando Usar Esta Skill

  • Decisões de arquitetura de sistema
  • Escolha entre monolito vs microservices
  • Design de APIs e comunicação entre serviços
  • Escalabilidade e performance
  • Organização de código e camadas

Monolito vs Microservices

Quando Usar Monolito

┌─────────────────────────────────────────────────────────────┐
│  USE MONOLITO QUANDO:                                        │
│                                                              │
│  ✅ Time < 10 desenvolvedores                                │
│  ✅ Produto ainda está descobrindo product-market fit       │
│  ✅ Domínio do negócio ainda está mudando                   │
│  ✅ Você precisa de velocidade de desenvolvimento           │
│  ✅ Não tem expertise em sistemas distribuídos              │
│                                                              │
│  EXEMPLOS DE EMPRESAS QUE COMEÇARAM COM MONOLITO:           │
│  → Shopify (Ruby monolito até bilhões em GMV)              │
│  → Basecamp (ainda é monolito)                             │
│  → GitHub (monolito por anos)                              │
│  → Airbnb (começou monolito)                               │
│                                                              │
│  "If you can't build a well-structured monolith,            │
│   what makes you think microservices are the answer?"       │
└─────────────────────────────────────────────────────────────┘

Quando Usar Microservices

┌─────────────────────────────────────────────────────────────┐
│  USE MICROSERVICES QUANDO:                                   │
│                                                              │
│  ✅ Time > 50 desenvolvedores                                │
│  ✅ Domínios claramente separados e estáveis                │
│  ✅ Diferentes partes precisam escalar independentemente     │
│  ✅ Times autônomos com ownership claro                     │
│  ✅ Você tem DevOps/Platform team dedicado                  │
│                                                              │
│  CUSTOS DOS MICROSERVICES (que ninguém conta):              │
│  → Latência de rede entre serviços                         │
│  → Complexidade de debugging distribuído                   │
│  → Consistência eventual (transactions distribuídas)       │
│  → Infraestrutura: K8s, service mesh, observability        │
│  → Overhead operacional: deploy, monitoring de N serviços  │
│                                                              │
│  "Don't do microservices unless you have the team          │
│   and infrastructure to support them."                      │
└─────────────────────────────────────────────────────────────┘

Decisão Rápida

FLOWCHART DE DECISÃO:

Quantos devs você tem?
│
├─ < 10 devs → MONOLITO (ponto final)
│
├─ 10-50 devs → MODULAR MONOLITH
│   │
│   └─ Monolito bem estruturado com módulos separados
│      que PODEM virar serviços se necessário
│
└─ > 50 devs → CONSIDERE microservices
    │
    ├─ Tem Platform Team? → Talvez microservices
    │
    └─ Não tem → Modular monolith

Padrões de Arquitetura

Clean Architecture / Hexagonal

┌─────────────────────────────────────────────────────────────┐
│  CLEAN ARCHITECTURE (Uncle Bob)                              │
│                                                              │
│  ┌───────────────────────────────────────┐                  │
│  │           FRAMEWORKS & DRIVERS        │ ← Web, DB, UI   │
│  │  ┌───────────────────────────────┐   │                  │
│  │  │      INTERFACE ADAPTERS       │   │ ← Controllers    │
│  │  │  ┌───────────────────────┐   │   │                  │
│  │  │  │     USE CASES         │   │   │ ← Business rules │
│  │  │  │  ┌───────────────┐   │   │   │                  │
│  │  │  │  │   ENTITIES    │   │   │   │ ← Domain objects │
│  │  │  │  └───────────────┘   │   │   │                  │
│  │  │  └───────────────────────┘   │   │                  │
│  │  └───────────────────────────────┘   │                  │
│  └───────────────────────────────────────┘                  │
│                                                              │
│  REGRA: Dependências apontam para DENTRO                    │
│  → Entities não conhecem Use Cases                         │
│  → Use Cases não conhecem Controllers                      │
│  → Controllers não conhecem Frameworks específicos         │
│                                                              │
├─────────────────────────────────────────────────────────────┤
│  QUANDO USAR:                                                │
│  ✅ Aplicações com lógica de negócio complexa               │
│  ✅ Quando você quer trocar de framework/DB facilmente      │
│  ✅ Projetos de longa duração (> 2 anos)                    │
│                                                              │
│  QUANDO NÃO USAR:                                            │
│  ❌ CRUDs simples                                            │
│  ❌ MVPs e protótipos                                        │
│  ❌ Time inexperiente (curva de aprendizado)                │
└─────────────────────────────────────────────────────────────┘

CQRS (Command Query Responsibility Segregation)

┌─────────────────────────────────────────────────────────────┐
│  CQRS: SEPARE LEITURAS DE ESCRITAS                           │
│                                                              │
│  MODELO TRADICIONAL:                                         │
│  [Client] ←→ [API] ←→ [Service] ←→ [Database]              │
│                                                              │
│  MODELO CQRS:                                                │
│                                                              │
│  [Client] ─── Commands ──→ [Write Model] ─→ [Write DB]     │
│     │                           │                           │
│     │                           ▼ (eventos)                 │
│     │                      [Event Bus]                      │
│     │                           │                           │
│     │                           ▼                           │
│     └─── Queries ────→ [Read Model] ←─ [Read DB]           │
│                                                              │
├─────────────────────────────────────────────────────────────┤
│  QUANDO USAR:                                                │
│  ✅ Leituras >> Escritas (90% reads, 10% writes)            │
│  ✅ Requisitos de leitura diferentes de escrita             │
│  ✅ Performance de leitura é crítica                        │
│  ✅ Múltiplas views do mesmo dado                           │
│                                                              │
│  QUANDO NÃO USAR:                                            │
│  ❌ CRUD simples                                             │
│  ❌ Consistência forte necessária                           │
│  ❌ Time pequeno sem experiência                            │
│                                                              │
│  EXEMPLO PRÁTICO:                                            │
│  E-commerce: Catálogo de produtos                          │
│  → Escrita: Admin atualiza produto (raro)                  │
│  → Leitura: Milhões de pageviews (frequente)               │
│  → Read model pode ser denormalizado, cacheado, etc.       │
└─────────────────────────────────────────────────────────────┘

Event Sourcing

┌─────────────────────────────────────────────────────────────┐
│  EVENT SOURCING: ARMAZENE EVENTOS, NÃO ESTADO               │
│                                                              │
│  TRADICIONAL:                                                │
│  User { name: "João", email: "joao@email.com" }            │
│  (só o estado atual)                                        │
│                                                              │
│  EVENT SOURCING:                                             │
│  1. UserCreated { name: "João", email: "j@email.com" }     │
│  2. EmailChanged { email: "joao@email.com" }               │
│  3. NameChanged { name: "João Silva" }                     │
│  → Estado atual = replay de todos os eventos               │
│                                                              │
├─────────────────────────────────────────────────────────────┤
│  VANTAGENS:                                                  │
│  ✅ Audit log completo (quem, quando, o quê)                │
│  ✅ Pode reconstruir estado em qualquer ponto no tempo     │
│  ✅ Debug fácil (replay eventos para reproduzir bug)        │
│  ✅ Integração natural com CQRS                             │
│                                                              │
│  DESVANTAGENS:                                               │
│  ❌ Complexidade muito maior                                 │
│  ❌ Storage cresce infinitamente                            │
│  ❌ Queries são mais complexas                              │
│  ❌ Evolução de schema de eventos é difícil                │
│                                                              │
├─────────────────────────────────────────────────────────────┤
│  QUANDO USAR:                                                │
│  ✅ Auditoria é requisito legal (financeiro, saúde)         │
│  ✅ Precisa de "time travel" (undo/redo)                    │
│  ✅ Domínio naturalmente baseado em eventos                 │
│                                                              │
│  QUANDO NÃO USAR (maioria dos casos):                       │
│  ❌ Você não tem requisito de auditoria                     │
│  ❌ CRUD é suficiente                                       │
│  ❌ Time não tem experiência com ES                         │
│                                                              │
│  "Event Sourcing is a very powerful pattern, but it's       │
│   also very complex. Don't use it unless you need it."      │
└─────────────────────────────────────────────────────────────┘

Comunicação Entre Serviços

Síncrona vs Assíncrona

┌─────────────────────────────────────────────────────────────┐
│  COMUNICAÇÃO SÍNCRONA (REST, gRPC)                          │
│                                                              │
│  [Service A] ──request──→ [Service B]                      │
│       ↑                        │                            │
│       └────── response ────────┘                            │
│                                                              │
│  A espera B responder                                       │
│                                                              │
│  USE QUANDO:                                                 │
│  ✅ Você PRECISA da resposta imediatamente                  │
│  ✅ Operações simples e rápidas (<100ms)                    │
│  ✅ User-facing requests                                    │
│                                                              │
├─────────────────────────────────────────────────────────────┤
│  COMUNICAÇÃO ASSÍNCRONA (Message Queue, Events)             │
│                                                              │
│  [Service A] ──event──→ [Queue] ──event──→ [Service B]     │
│       │                                                     │
│       └─ continua sem esperar                               │
│                                                              │
│  A NÃO espera B                                             │
│                                                              │
│  USE QUANDO:                                                 │
│  ✅ Operação pode demorar (processamento batch)             │
│  ✅ Não precisa de resposta imediata                        │
│  ✅ Desacoplamento é importante                             │
│  ✅ Retry automático é necessário                           │
│                                                              │
├─────────────────────────────────────────────────────────────┤
│  RECOMENDAÇÃO:                                               │
│                                                              │
│  User request → SÍNCRONO (REST/gRPC)                       │
│  Background jobs → ASSÍNCRONO (Queue)                       │
│  Entre microservices → ASSÍNCRONO quando possível          │
└─────────────────────────────────────────────────────────────┘

Message Queues

QUAL USAR:

┌────────────────┬─────────────────────────────────────────┐
│ TECNOLOGIA     │ QUANDO USAR                             │
├────────────────┼─────────────────────────────────────────┤
│ RabbitMQ       │ Workload tradicional, routing complexo  │
│                │ Bom para: Tasks, RPC assíncrono         │
├────────────────┼─────────────────────────────────────────┤
│ Apache Kafka   │ High throughput, event streaming        │
│                │ Bom para: Logs, analytics, event store  │
├────────────────┼─────────────────────────────────────────┤
│ AWS SQS        │ Serverless, managed, simples            │
│                │ Bom para: Tarefas simples em AWS        │
├────────────────┼─────────────────────────────────────────┤
│ Redis Streams  │ Já usa Redis, precisa de speed          │
│                │ Bom para: Cache + queue em um           │
├────────────────┼─────────────────────────────────────────┤
│ BullMQ (Node)  │ App Node.js, já tem Redis               │
│                │ Bom para: Background jobs em Node       │
└────────────────┴─────────────────────────────────────────┘

REGRA SIMPLES:
→ Task queue simples? → BullMQ/SQS
→ Event streaming? → Kafka
→ Routing complexo? → RabbitMQ
→ Não sabe? → Comece com SQS/BullMQ

Database Design

Escolha de Banco de Dados

┌────────────────┬─────────────────────────────────────────┐
│ TIPO           │ QUANDO USAR                             │
├────────────────┼─────────────────────────────────────────┤
│ PostgreSQL     │ DEFAULT. Relacional, full-featured.     │
│                │ Use para: 90% dos casos                 │
├────────────────┼─────────────────────────────────────────┤
│ MongoDB        │ Documentos JSON, schema flexível        │
│                │ Use para: Conteúdo, catálogos           │
├────────────────┼─────────────────────────────────────────┤
│ Redis          │ Cache, sessões, filas                   │
│                │ Use para: Performance, dados efêmeros   │
├────────────────┼─────────────────────────────────────────┤
│ Elasticsearch  │ Full-text search, analytics             │
│                │ Use para: Busca, logs                   │
├────────────────┼─────────────────────────────────────────┤
│ ClickHouse     │ Analytics, time-series                  │
│                │ Use para: Dashboards, métricas          │
└────────────────┴─────────────────────────────────────────┘

REGRA: Se você não sabe, use PostgreSQL.
PostgreSQL pode fazer:
→ Relacional (óbvio)
→ JSON (JSONB)
→ Full-text search (basic)
→ Time-series (com extensões)
→ Vector search (pgvector)

"PostgreSQL is the everything database."

Exemplo de Resposta OBJETIVA

Usuário: "Estou começando uma startup, devo usar microservices?"

Resposta:

NÃO. Use monolito.

RAZÕES:

1. VOCÊ NÃO TEM OS PROBLEMAS QUE MICROSERVICES RESOLVEM
   Microservices resolvem:
   → Times grandes (50+ devs) que não conseguem trabalhar junto
   → Partes do sistema que precisam escalar diferentemente
   → Deploys independentes por diferentes times

   Você tem:
   → Time pequeno (1-10 pessoas)
   → Domínio ainda em descoberta
   → Necessidade de velocidade, não escala

2. CUSTO VS BENEFÍCIO
   Microservices adicionam:
   → Latência de rede entre serviços
   → Complexidade de debugging
   → Infraestrutura (K8s, service mesh, etc.)
   → Overhead operacional

   Para uma startup, isso é MORTAL. Você vai gastar
   tempo resolvendo problemas de infra em vez de
   problemas de negócio.

3. O QUE FAZER EM VEZ DISSO:

   a) MONOLITO MODULAR
      → Separe código em módulos/packages
      → Defina interfaces claras entre módulos
      → Isso facilita extrair serviço DEPOIS se precisar

   b) ESTRUTURA SUGERIDA:
      /src
        /modules
          /users
            - controller.ts
            - service.ts
            - repository.ts
          /orders
            - controller.ts
            - service.ts
            - repository.ts
          /payments
            ...
        /shared
          - database.ts
          - auth.ts

   c) TECNOLOGIA:
      → Node.js + Express/Fastify ou
      → Python + FastAPI ou
      → Go + Chi
      → PostgreSQL
      → Redis para cache/sessions
      → Tudo em uma máquina ou container

4. QUANDO MIGRAR PARA MICROSERVICES:
   → Você tem 50+ devs
   → Deploys estão atrasando porque times se bloqueiam
   → Parte específica precisa escalar 10x mais que resto
   → Você tem time de plataforma dedicado

   Até lá: MONOLITO.

"If you can't build a well-structured monolith,
 what makes you think microservices are the answer?"

Regras Imutáveis

1. SEJA OBJETIVO — dê recomendações específicas
2. Monolito primeiro, sempre (até 50 devs)
3. PostgreSQL é o default
4. Simplicidade > elegância arquitetural
5. Não adicione complexidade sem razão clara
6. "You ain't gonna need it" (YAGNI)
7. Escolha boring technology
8. Arquitetura evolui com o time e produto
9. Modular monolith é melhor que microservices ruins
10. Se não sabe explicar por que precisa, não precisa

Esta skill ativa AUTOMATICAMENTE quando:

  • Decisões de arquitetura de sistema
  • Monolito vs microservices
  • Design de APIs e comunicação
  • Escolha de banco de dados
  • Escalabilidade e performance

Related Skills

Looking for an alternative to architecture-patterns or building a Categories.community AI Agent? Explore these related open-source MCP Servers.

View All

widget-generator

Logo of f
f

widget-generator is an open-source AI agent skill for creating widget plugins that are injected into prompt feeds on prompts.chat. It supports two rendering modes: standard prompt widgets using default PromptCard styling and custom render widgets built as full React components.

149.6k
0
Design

chat-sdk

Logo of lobehub
lobehub

chat-sdk is a unified TypeScript SDK for building chat bots across multiple platforms, providing a single interface for deploying bot logic.

73.0k
0
Communication

zustand

Logo of lobehub
lobehub

The ultimate space for work and life — to find, build, and collaborate with agent teammates that grow with you. We are taking agent harness to the next level — enabling multi-agent collaboration, effortless agent team design, and introducing agents as the unit of work interaction.

72.8k
0
Communication

data-fetching

Logo of lobehub
lobehub

The ultimate space for work and life — to find, build, and collaborate with agent teammates that grow with you. We are taking agent harness to the next level — enabling multi-agent collaboration, effortless agent team design, and introducing agents as the unit of work interaction.

72.8k
0
Communication