Seleccione sus preferencias de cookies

Usamos cookies esenciales y herramientas similares que son necesarias para proporcionar nuestro sitio y nuestros servicios. Usamos cookies de rendimiento para recopilar estadísticas anónimas para que podamos entender cómo los clientes usan nuestro sitio y hacer mejoras. Las cookies esenciales no se pueden desactivar, pero puede hacer clic en “Personalizar” o “Rechazar” para rechazar las cookies de rendimiento.

Si está de acuerdo, AWS y los terceros aprobados también utilizarán cookies para proporcionar características útiles del sitio, recordar sus preferencias y mostrar contenido relevante, incluida publicidad relevante. Para aceptar o rechazar todas las cookies no esenciales, haga clic en “Aceptar” o “Rechazar”. Para elegir opciones más detalladas, haga clic en “Personalizar”.

Patrón de higo estrangulador - AWS Guía prescriptiva

Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.

Las traducciones son generadas a través de traducción automática. En caso de conflicto entre la traducción y la version original de inglés, prevalecerá la version en inglés.

Patrón de higo estrangulador

Los patrones de diseño discutidos hasta ahora en esta guía se aplican a las aplicaciones en descomposición para proyectos totalmente nuevos. ¿Qué pasa con los proyectos abandonados que implican aplicaciones grandes y monolíticas? Será difícil aplicarles los patrones de diseño anteriores, ya que dividirlos en trozos más pequeños mientras se utilizan activamente es una tarea ardua.

El patrón de higo estrangulador es un patrón de diseño popular que fue introducido por Martin Fowler, quien se inspiró en un determinado tipo de higo que se siembra él solo en las ramas superiores de los árboles. El árbol existente se convierte inicialmente en una estructura de soporte para la nueva higuera. Luego, el higo envía sus raíces al suelo, envolviendo gradualmente el árbol original y dejando solo el higo nuevo en su lugar, que se sostiene por sí mismo.

Este patrón se suele utilizar para transformar gradualmente una aplicación monolítica en microservicios mediante la sustitución de una funcionalidad concreta por un servicio nuevo. El objetivo es que las versiones heredadas y las nuevas y modernizadas coexistan. El nuevo sistema inicialmente es compatible con el sistema existente y lo complementa. Este soporte da tiempo al nuevo sistema para crecer y, potencialmente, reemplazar por completo el sistema anterior.

El proceso de transición de una aplicación monolítica a un microservicio mediante la implementación del patrón de higo estrangulador consta de tres pasos: transformar, coexistir y eliminar:

  • Transformar: identifique y cree componentes modernizados portándolos o reescribiéndolos en paralelo con la aplicación heredada.

  • Coexistir: conserve la aplicación monolítica para su reversión. Intercepte las llamadas externas al sistema incorporando un proxy HTTP (por ejemplo, Amazon API Gateway) en el perímetro de su monolito y redirija el tráfico a la versión modernizada. Esto le ayuda a implementar la funcionalidad de forma incremental.

  • Eliminar: retire la funcionalidad anterior del monolito a medida que el tráfico se redirige del monolito heredado al servicio modernizado.

AWS Migration Hub Refactor Spaces es el punto de partida para la refactorización gradual de las aplicaciones y convertirlas en microservicios en AWS. Refactor Spaces proporciona una aplicación que modela el patrón del higo estrangulador para una refactorización incremental. Una aplicación de Refactor Spaces orquesta políticas AWS Identity and Access Management de API Gateway, Network Load Balancer y basadas en recursos (IAM) para que pueda añadir nuevos servicios de forma transparente a un punto de conexión HTTP externo.

En la siguiente tabla se explican las ventajas y desventajas de usar el patrón de higo estrangulador.

Ventajas Desventajas
  • Permite migrar sin problemas de un servicio a uno o más servicios de reemplazo.

  • Mantiene los servicios antiguos en funcionamiento a la vez que los refactoriza a versiones actualizadas.

  • Ofrece la posibilidad de añadir nuevos servicios y funcionalidades a la vez que refactoriza los servicios más antiguos.

  • El patrón se puede utilizar para el control de versiones de las API.

  • El patrón se puede usar para interacciones heredadas para soluciones que no se actualizan o no se actualizarán.

  • No es adecuado para sistemas pequeños donde la complejidad es baja y el tamaño es pequeño.

  • No se puede utilizar en sistemas en los que las solicitudes al sistema de fondo no se puedan interceptar ni enrutar.

  • La capa proxy o de fachada puede convertirse en un único punto de fallo o en un obstáculo para el rendimiento si no se diseña correctamente.

  • Requiere un plan de reversión para cada servicio refactorizado a fin de volver a la antigua forma de hacer las cosas de forma rápida y segura en caso de que algo vaya mal.

La siguiente ilustración muestra cómo se puede dividir un monolito en microservicios aplicando el patrón del higo estrangulador a la arquitectura de una aplicación. Ambos sistemas funcionan en paralelo, pero empezará a trasladar la funcionalidad fuera de la base de código monolítica y a mejorarla con nuevas capacidades. Estas nuevas capacidades le brindan la oportunidad de diseñar los microservicios de la manera que mejor se adapte a sus necesidades. Seguirá eliminando las capacidades del monolito hasta que todas sean reemplazadas por microservicios. En ese momento podrá eliminar la aplicación monolítica. El punto clave a tener en cuenta aquí es que tanto el monolito como los microservicios convivirán durante un período de tiempo.

Descomposición de monolitos en microservicios utilizando el patrón de higo estrangulador
PrivacidadTérminos del sitioPreferencias de cookies
© 2025, Amazon Web Services, Inc o sus afiliados. Todos los derechos reservados.