DEV Community

Cover image for Arc42: Cómo Documentar Arquitecturas Cloud Complejas para Garantizar el Éxito
Antonio Jesús Castillo Cotán
Antonio Jesús Castillo Cotán

Posted on

Arc42: Cómo Documentar Arquitecturas Cloud Complejas para Garantizar el Éxito

Arc42 es un marco de documentación diseñado para estructurar y comunicar la arquitectura de software de manera efectiva. A continuación, exploraremos su estructura clave e incorporaremos contenido interactivo y visual para facilitar su comprensión.


¿Cómo funciona Arc42?

Arc42 organiza la documentación en 12 secciones que abarcan desde requisitos iniciales hasta la identificación de riesgos y un glosario técnico. Este enfoque estandarizado mejora la colaboración entre equipos técnicos y no técnicos, ofreciendo una visión integral del sistema.

Para facilitar su adopción, Arc42 ofrece plantillas descargables que puedes encontrar en Download Arc42.

Image description


1. Introduction & Goals

Proporciona un panorama general del sistema, estableciendo los cimientos de la documentación.

  • Requisitos funcionales: Describe las principales funciones que el sistema debe cumplir, como "gestionar inventarios" o "procesar pagos". Esto ayuda a contextualizar las decisiones técnicas.
  • Objetivos de calidad: Define metas específicas como "99.9% de disponibilidad" o "respuesta de menos de 1 segundo para consultas". Estas metas guían el diseño técnico.
  • Stakeholders: Identifica a todas las personas involucradas (usuarios, desarrolladores, gerentes) y sus intereses. Por ejemplo, un gerente busca reportes claros, mientras que un desarrollador necesita herramientas eficaces.

2. Constraints

Documenta las restricciones que limitan el diseño del sistema.

  • Técnicas: Requisitos específicos como "usar PostgreSQL" o "implementar en AWS".
  • Organizativas: Políticas de la empresa, como "solo herramientas aprobadas por TI".
  • Legales: Normativas aplicables, como el cumplimiento de GDPR para proteger datos personales. Estas restricciones ayudan a prevenir problemas futuros y delimitan el alcance del proyecto.

3. Context & Scope

Proporciona una visión de alto nivel del sistema y su interacción con el entorno.

  • Contexto de negocio: Cómo el sistema contribuye a los objetivos de la organización. Por ejemplo, "reducir el tiempo de procesamiento de pedidos en un 20%".
  • Contexto técnico: Relación del sistema con otros sistemas, bases de datos o APIs. Un diagrama de contexto es útil aquí, mostrando cómo los usuarios y sistemas externos interactúan con el sistema.

4. Solution Strategy

Resume las decisiones clave que influyen en la arquitectura.

  • Tecnologías: Por ejemplo, elegir React para frontend por su flexibilidad o Python para backend por su ecosistema.
  • Patrones arquitectónicos: Como usar microservicios para escalabilidad o un monolito para simplicidad inicial.
  • Organización: Describir cómo se divide el trabajo entre los equipos, qué tareas se externalizan y cómo se gestionan dependencias.

5. Building Block View

Divide la arquitectura en niveles de detalle creciente para describir su estructura.

  • Nivel 1 (Contenedores): Elementos principales como "aplicación web", "base de datos" y "API".
  • Nivel 2 (Componentes): Partes internas de los contenedores, como "módulo de autenticación" o "gestor de reportes".
  • Nivel 3 (Código): Clases, funciones y estructuras a nivel de implementación.

Esta sección ayuda a los desarrolladores a entender cómo se conecta cada parte del sistema.


6. Runtime View

Describe cómo interactúan los componentes del sistema durante la ejecución.

  • Ejemplos incluyen:
    • Cómo un usuario inicia sesión y cómo se verifica su autenticación.
    • El flujo de datos en una consulta que pasa desde el frontend, al backend y finalmente a la base de datos.
  • Representación gráfica recomendada: diagramas de secuencia, BPMN, o diagramas de actividad que muestren el flujo paso a paso.

7. Deployment View

Explica cómo y dónde se despliega el sistema.

  • Incluye detalles como servidores, contenedores (Docker), y servicios en la nube.
  • Por ejemplo: "El frontend se ejecuta en S3 y se entrega a través de CloudFront, mientras que el backend está en instancias EC2". Esta vista es crucial para garantizar que los sistemas funcionen correctamente en su entorno operativo.

8. Crosscutting Concepts

Documenta decisiones y conceptos que afectan a todo el sistema:

  • Seguridad: Por ejemplo, "usar OAuth2 para autenticación" o "cifrar datos sensibles".
  • Modelos de dominio: Estructuras clave como "clientes", "pedidos" o "productos".
  • Patrones arquitectónicos: Uso de MVC, CQRS, o estrategias de caché. Esta sección ayuda a mantener la consistencia en todo el sistema.

9. Architectural Decisions

Registra las decisiones arquitectónicas importantes en un formato estructurado (ADRs):

  • Título: Breve descripción, como "Usar PostgreSQL en lugar de MySQL".
  • Contexto: Por qué se necesitaba tomar esta decisión.
  • Decisión: Detalles de lo que se eligió y por qué.
  • Consecuencias: Impactos positivos y negativos, como "mejor rendimiento, pero mayor curva de aprendizaje". Este registro es útil para entender el razonamiento detrás de las decisiones.

10. Quality Requirements

Profundiza en los objetivos de calidad definidos al inicio.

  • Requisitos de calidad: Aspectos generales como rendimiento, escalabilidad, usabilidad, seguridad.
  • Escenarios de calidad: Ejemplos concretos que explican cómo se cumplirán los requisitos. Por ejemplo:
    • Escenario: "El sistema debe procesar 1000 órdenes por minuto con menos de 1% de fallos".

11. Risks & Technical Debt

Identifica y prioriza riesgos, como:

  • Riesgos técnicos: Nuevas tecnologías sin suficiente experiencia en el equipo.
  • Deuda técnica: Decisiones como "postergar optimización de consultas SQL". Se asignan prioridades según su impacto y probabilidad, con planes para mitigarlos.

12. Glossary

Define términos clave usados en el proyecto, asegurando que todos los stakeholders comprendan el lenguaje técnico y del dominio.

  • Por ejemplo, incluir definiciones de "stakeholder", "middleware", o "microservicio".

Conclusión

Estas 12 secciones no solo estructuran la documentación, sino que también ayudan a alinear a los equipos, prevenir errores y garantizar que el sistema cumpla con sus objetivos. Arc42 es una herramienta esencial para cualquier arquitecto de software que busque claridad y precisión en su trabajo.

Top comments (0)