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 (Apis Manager, 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 plama en los correspondientes descriptores Dockerfile sobre el Gitlab del proyecto así como en la publicación en un registro de las imagenes 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.
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 respresenta 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 manerializando 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 tambien 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 despledada la aplicación en el entorno kubernetes seleccionado:
Video
Todo el proceso se puede apreciar en el siguiente video, donde tambien se muestra en vivio como se despliega la aplicación sobre el entorno kubernetes gestionado mediante Rancher: