adapt-architecture
Acerca de
Esta habilidad proporciona un enfoque estructurado para evolucionar gradualmente la arquitectura del sistema, utilizando patrones como la migración de la higuera estranguladora y las fases de crisálida. Permite una transformación incremental con ejecución en paralelo, transición progresiva y seguridad de reversión. Úsela para migraciones como de monolito a microservicios o reemplazos de subsistemas centrales cuando se requiera una transición gradual y de bajo riesgo.
Instalación rápida
Claude Code
Recomendadonpx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/adapt-architectureCopia y pega este comando en Claude Code para instalar esta habilidad
Documentación
Adapt Architecture
Execute structural metamorphosis — transforming a system's architecture from its current form to a target form while maintaining operational continuity. Uses strangler fig migration, chrysalis phases, and interface preservation to ensure the system never stops functioning during transformation.
When to Use
- Form assessment (see
assess-form) classified the system as READY - A system must evolve its architecture to meet new requirements without downtime
- Migrating from monolith to microservices (or the reverse)
- Replacing a core subsystem while dependent systems continue operating
- Evolving a data model while maintaining backward compatibility
- Any architectural change that must be gradual rather than big-bang
Inputs
- Required: Current form assessment (from
assess-formor equivalent analysis) - Required: Target architecture (what the system should become)
- Required: Operational continuity requirements (what must not break during transformation)
- Optional: Available transformation budget (time, people, compute)
- Optional: Rollback requirements (how far back must we be able to retreat?)
- Optional: Parallel running duration (how long to run old and new simultaneously)
Procedure
Step 1: Design the Transformation Blueprint
Plan the metamorphosis path from current form to target form.
- Map the transformation as a sequence of intermediate forms:
- Current form → Intermediate form 1 → ... → Target form
- Each intermediate form must be operationally viable (can serve traffic, pass tests)
- No intermediate form should be harder to maintain than the current form
- Identify the transformation seams:
- Where can the current form be "cut" to insert the new architecture?
- Natural seams: existing interfaces, module boundaries, data partitions
- Artificial seams: interfaces created specifically to enable the cut (anti-corruption layers)
- Choose the metamorphosis pattern:
- Strangler fig: new system grows around the old, gradually replacing it
- Chrysalis: old system is wrapped in a new shell; internals replaced while shell preserves external interface
- Budding: new system grows alongside the old; traffic gradually shifts (see
scale-colonyfor colony budding) - Metamorphic migration: phased replacement of components in dependency order (leaves first, roots last)
- Design the interface preservation layer:
- External consumers must not experience disruption
- API versioning, backward-compatible contracts, adapter patterns
- The preservation layer is temporary scaffolding — plan its removal
Metamorphosis Patterns:
┌───────────────┬───────────────────────────────────────────────────┐
│ Strangler Fig │ New code intercepts routes one by one; │
│ │ old code handles everything else until replaced │
│ │ ┌──────────┐ │
│ │ │ Old ████ │ → │ Old ██ New ██ │ → │ New ████ │ │
│ │ └──────────┘ │
├───────────────┼───────────────────────────────────────────────────┤
│ Chrysalis │ Wrap old system in new interface; replace │
│ │ internals while external shell stays stable │
│ │ ┌──────────┐ ┌──[new]───┐ ┌──[new]───┐ │
│ │ │ old core │ → │ old core │ → │ new core │ │
│ │ └──────────┘ └──────────┘ └──────────┘ │
├───────────────┼───────────────────────────────────────────────────┤
│ Budding │ New system runs in parallel; traffic shifts │
│ │ ┌──────┐ ┌──────┐ ┌──────┐ ┌──────┐ │
│ │ │ Old │ │ New │ → │ Old │ │ New │ │
│ │ │ 100% │ │ 0% │ │ 0% │ │ 100% │ │
│ │ └──────┘ └──────┘ └──────┘ └──────┘ │
└───────────────┴───────────────────────────────────────────────────┘
Got: A transformation blueprint showing intermediate forms, seams, the chosen metamorphosis pattern, and the interface preservation strategy. Each step is concrete and testable.
If fail: If no clean seam can be found, the system may need preliminary dissolution (see dissolve-form) to create seams before transformation. If the intermediate forms aren't operationally viable, the transformation steps are too large — decompose into smaller increments.
Step 2: Build the Scaffolding
Construct the temporary infrastructure that supports metamorphosis.
- Create the anti-corruption layer:
- A thin translation layer between the old and new systems
- Routes requests to the appropriate system (old or new) based on migration state
- Translates data formats between old and new representations
- This layer is the "cocoon" that protects the transformation
- Set up parallel running infrastructure:
- Both old and new systems must be deployable simultaneously
- Feature flags control which system handles which traffic
- Comparison mechanisms validate that old and new produce equivalent results
- Establish rollback checkpoints:
- At each intermediate form, verify that rollback to the previous form is possible
- Rollback must be faster than the forward transformation step
- Data migration must be reversible (or data must be dual-written during transition)
- Build the validation harness:
- Automated tests that verify operational continuity at each intermediate form
- Performance benchmarks that detect regression
- Data integrity checks that catch migration errors
Got: Scaffolding infrastructure (anti-corruption layer, parallel running, rollback, validation) is in place before any transformation begins. The scaffolding itself is tested and verified.
If fail: If scaffolding is too expensive, simplify: the minimum viable scaffolding is a feature flag and a rollback procedure. Anti-corruption layers and parallel running add safety but are not always necessary for smaller transformations.
Step 3: Execute Progressive Cutover
Migrate functionality from old form to new form incrementally.
- Order components for migration:
- Start with the least-coupled, lowest-risk component (build confidence)
- Progress toward more critical, more coupled components
- Save the most coupled/critical component for last (by which point the team has experience)
- For each component: a. Implement the new version behind the anti-corruption layer b. Run parallel: both old and new process the same inputs c. Compare outputs — they should be equivalent (or the differences should be expected and documented) d. When confident, switch traffic to the new version (feature flag flip) e. Monitor for anomalies (increase monitoring sensitivity post-cutover) f. After a stability period, decommission the old version of this component
- Maintain continuous delivery throughout:
- Each cutover step is a normal deployment, not a special event
- The system is always in a known, tested, operational state
- If a cutover causes issues, roll back to the previous state (which is still operational)
Got: Functionality migrates component by component with validation at each step. The system is always operational. Each cutover builds confidence for the next.
If fail: If parallel running reveals discrepancies, the new implementation has a bug — fix it before cutting over. If a cutover causes performance degradation, the new component may need optimization or the anti-corruption layer is adding too much overhead. If the team loses confidence mid-migration, pause and stabilize — a half-migrated system in a known state is far better than a rushed full migration.
Step 4: Manage the Chrysalis Phase
Navigate the most vulnerable period — when the system is between forms.
- Acknowledge the chrysalis reality:
- During migration, the system is partly old and partly new
- This hybrid state is inherently more complex than either pure state
- Complexity peaks at the midpoint of migration, then decreases
- Chrysalis discipline:
- No new features during the chrysalis phase (transformation only)
- Minimal external changes (freeze non-essential deployments)
- Increased monitoring and on-call coverage
- Daily check-ins on migration progress and system health
- Mid-chrysalis assessment:
- At the halfway point, assess: is the target form still the right goal?
- Has anything changed (market, requirements, team) that affects the target?
- Should the transformation continue, pause, or redirect?
- Protect the chrysalis:
- Keep the rollback path clear at all times
- Document the current hybrid state thoroughly (future debuggers will need it)
- Resist the temptation to "clean up" temporary scaffolding before migration is complete
Got: The chrysalis phase is managed as a deliberate, time-bounded period with increased discipline and monitoring. The team understands that temporary complexity is the cost of safe transformation.
If fail: If the chrysalis phase drags on too long, the hybrid state becomes the new normal — which is worse than either old or new. Set a time limit. If the limit is reached, either accelerate the remaining migration or accept the hybrid state as the "new form" and stabilize it.
Step 5: Complete Metamorphosis and Stabilize
Finish the transformation and remove scaffolding.
- Final cutover:
- Migrate the last component(s) to the new form
- Run full validation suite against the complete new system
- Performance test under production-equivalent load
- Remove scaffolding:
- Decommission the anti-corruption layer (it's no longer needed)
- Remove feature flags related to the migration
- Clean up parallel running infrastructure
- Archive (don't delete) the old system code for reference
- Post-metamorphosis stabilization:
- Run in the new form for 2-4 weeks with enhanced monitoring
- Address any issues that emerge under real-world conditions
- Update documentation to reflect the new architecture
- Retrospective:
- What went well in the transformation?
- What was harder than expected?
- What would we do differently next time?
- Update the team's transformation playbook
Got: The transformation is complete. The system operates in its new form. Scaffolding is removed. Documentation is updated. The team has captured learnings for future transformations.
If fail: If the new form is unstable after cutover, maintain the rollback path and continue stabilization. If stabilization takes more than the planned period, there may be a design issue in the new architecture — consider whether targeted fixes or a partial rollback of the most problematic component is appropriate.
Validation
- Transformation blueprint shows viable intermediate forms
- Scaffolding (anti-corruption layer, rollback, validation harness) is in place before migration starts
- Components migrate in order from lowest to highest risk
- Parallel running validates equivalence at each step
- Chrysalis phase is time-bounded with feature freeze discipline
- All scaffolding is removed after transformation completes
- Post-metamorphosis stabilization period passes without critical issues
- Retrospective captures learnings
Pitfalls
- Big-bang migration: Attempting to transform everything at once. This abandons the safety of incremental cutover and maximizes blast radius. Always migrate incrementally
- Permanent scaffolding: Anti-corruption layers and feature flags that are never removed become technical debt. Plan scaffolding removal as part of the transformation, not as an afterthought
- Chrysalis denial: Pretending the hybrid state is normal leads to feature development on unstable foundations. Acknowledge the chrysalis phase and enforce its discipline
- Target fixation: Becoming so committed to the target architecture that signs of a better alternative are ignored. The mid-chrysalis assessment exists for this reason
- Transformation fatigue: Long migrations exhaust teams. Keep each transformation step small enough to complete in days, not weeks. Celebrate milestones to maintain momentum
Related Skills
assess-form— prerequisite assessment that determines if the system is ready for transformationdissolve-form— for systems too rigid to transform directly; dissolution creates the seams needed hererepair-damage— recovery skill for when transformation introduces damageshift-camouflage— surface adaptation that may suffice without deep architectural changecoordinate-swarm— swarm coordination informs the sequencing of transformation across distributed systemsscale-colony— growth pressure is a common trigger for architectural adaptationimplement-gitops-workflow— GitOps provides the deployment infrastructure for progressive cutoverreview-software-architecture— complementary review skill for evaluating the target architecture
Repositorio GitHub
Habilidades relacionadas
executing-plans
DiseñoUtilice la habilidad executing-plans cuando tenga un plan de implementación completo para ejecutar en lotes controlados con puntos de revisión. Esta habilidad carga y revisa críticamente el plan, luego ejecuta tareas en pequeños lotes (por defecto 3 tareas) mientras reporta el progreso entre cada lote para la revisión del arquitecto. Esto asegura una implementación sistemática con puntos de control de calidad integrados.
requesting-code-review
DiseñoEsta habilidad despacha un subagente revisor de código para analizar los cambios en el código frente a los requisitos antes de proceder. Debe usarse después de completar tareas, implementar funciones principales o antes de fusionar con la rama principal. La revisión ayuda a detectar problemas de forma temprana al comparar la implementación actual con el plan original.
connect-mcp-server
DiseñoEsta habilidad proporciona una guía integral para que los desarrolladores conecten servidores MCP a Claude Code mediante transportes HTTP, stdio o SSE. Cubre la instalación, configuración, autenticación y seguridad para integrar servicios externos como GitHub, Notion y APIs personalizadas. Úsala al configurar integraciones MCP, al configurar herramientas externas o al trabajar con el Protocolo de Contexto del Modelo de Claude.
web-cli-teleport
DiseñoEsta habilidad ayuda a los desarrolladores a elegir entre las interfaces web y CLI de Claude Code mediante el análisis de tareas, y luego permite la teletransportación fluida de sesiones entre estos entornos. Optimiza el flujo de trabajo gestionando el estado y el contexto de la sesión al cambiar entre web, CLI o móvil. Úsala para proyectos complejos que requieren diferentes herramientas en varias etapas.
