Demostrador Center - Migración a Cloud

Se trata de un demostrador en el que se realiza la migración a Cloud sobre Kubernetes, de una aplicación legacy desplegada de forma tradicional.

Para ello:

Creamos un proyecto en el Center

En este paso, se crea el proyecto y se le asigna su configuración, incluyendo:

  • Información administrativa y usuarios asociados al proyecto

  • Configuración DevOps (Gitlab, Jenkins, …).

 

  • Entornos Kubernetes donde se desplegará la solución en cloud.

Realizamos el Assessment de la aplicación legacy

Una vez creado el proyecto, el siguiente paso es identificar los elementos que componen la aplicación legacy a migrar a cloud. Para ello se realiza un Assessment, esto es, la identificación de todos los elementos lógicos de la aplicación y su configuración de despliegue en un entorno tipo.

Para ello mediante un formulario (aunque en el futuro tenemos pensadas alternativas mas automáticas) se identifican:

  • Frontales Web de la aplicación.

  • Módulos de Backend (Servidores JEE, Microservicios Spring Boot, …)

  • Bases de datos.

  • Procesos batch.

  • Middleware de integración (API Managers, ESBs, Brokers de mensajeria, …)

  • Balanceadores.

Alternativamente al formulario y de manera bidireccional, esta información se plasma en un Diagrama de Assessment editable, organizado por capas:

 

Contenerizamos la aplicación

Finalizado el Assessment, el siguiente paso hacia el cloud, es convertir los elementos lógicos identificados en la aplicación en contenedores desplegables como cargas de trabajo Kubernetes.

Para ello, por cada elemento identificado se crea un contenedor sobre un diagrama editable:

El resultado de la contenerización se plasma en los correspondientes descriptores Dockerfile sobre el GitLab del proyecto, así como en la publicación en un registro de las imágenes de los diferentes contenedores:

 

Aplantillamos la aplicación con Helm

Con la contenerización finalizada, y las relaciones entre componentes lógicos definidas en el assessment, el Center ya dispone de una imagen para inferir una propuesta de despliegue sobre Kubernetes.

En el siguiente paso, esta información es utilizada para generar de forma automática un Diagrama Helm, esto es, una representación gráfica de todos los descriptores Helm de la aplicación. Para ello se crea de forma automática:

  • Un Namespace para la aplicación.

  • Un Deployment y un Service por cada contenedor.

  • Un Config-map con la configuración de cada Base de datos contenerizada.

  • Un Secret con las credenciales de cada Base de datos contenerizada.

  • Un PV y un PVC por cada Base de datos, para proporcionar almacenamiento persistente.

  • Un PV y un PVC general para el resto de Deployments que no sean Base de datos.

  • Un Ingress con reglas de balanceo hacia los Service que tuvieran reglas de balanceo en en Assessment.

 

Como en el resto de elementos generados por el Center, este diagrama es editable para que el arquitecto refine o modifique cualquier elemento.

Un diagrama Helm representa una abstracción gráfica de un Chart Helm, de manera que un arquitecto sin conocimientos muy profundos de Helm pueda construir sus Charts. Pero un diagrama Helm se termina materializando en un Chart Helm, con los descriptores YAML y la configuración externalizada en un fichero values.yaml. Estos chart pueden descargarse o versionarse en el GitLab del proyecto:

Despliegamos en Kubernetes

Un Diagrama Helm también pude instalarse en Kubernetes sobre uno de los entornos del proyecto. Para ello, seleccionando el diagrama podemos elegir “Desplegar Chart Helm”.

Al haberse externalizado la configuración, se pueden sobrescribir determinadas variables para el entorno:

La instalación finaliza mostrando el log de Helm:

 

quedando desplegada la aplicación en el entorno Kubernetes seleccionado:

Vídeo

Todo el proceso se puede apreciar en el siguiente video, donde también se muestra cómo se despliega la aplicación sobre el entorno Kubernetes gestionado mediante Rancher: