Optimizar flujos de trabajo de desarrollo de Node.js en Kubernetes con Skaffold y Rancher Desktop

Rate this content
Bookmark

En esta charla, aprenderás cómo optimizar tu flujo de trabajo de desarrollo y lanzamiento de Node.js en Kubernetes con Skaffold y Rancher Desktop. El uso conjunto de estas herramientas ayuda a mejorar la experiencia de desarrollo local de K8s, reflejando una experiencia de clúster real, así como el flujo de trabajo de lanzamiento que tendrías para tu clúster remoto. Cubriremos los desafíos del desarrollo local de Kubernetes, cómo ayudan Skaffold y Rancher Desktop, demostraciones de lanzamientos locales a un clúster y cómo utilizar la misma configuración para lanzamientos en clústeres remotos.

FAQ

Rancher Desktop es una aplicación de escritorio basada en Electron que simplifica la gestión de clústeres de Kubernetes. Está disponible para Windows, Linux y Mac, y permite a los usuarios gestionar fácilmente su cluster, incluyendo actualizaciones y configuraciones de tiempo de ejecución de contenedores, con una interfaz de usuario intuitiva.

Scaffold automatiza y abstrae los procesos de construcción e implementación de imágenes de contenedor, mejorando el ciclo de desarrollo iterativo. Permite a los desarrolladores centrarse en la codificación mientras maneja automáticamente las compilaciones y despliegues, detectando cambios locales y desencadenando un pipeline de implementación.

La combinación de Rancher Desktop y Scaffold permite a los desarrolladores enfocarse en optimizar sus aplicaciones mientras interactúan fácilmente con Kubernetes y manejan configuraciones de DevOps de manera automática. Esto ayuda a integrar prácticas de DevOps sin sacrificar las prioridades de desarrollo.

Usando el archivo scaffold.yaml, los desarrolladores pueden configurar la construcción, prueba e implementación de sus aplicaciones. Este archivo permite especificar detalles como el archivo Docker utilizado, cómo se construyen las imágenes, y cómo se prueban y despliegan los recursos de Kubernetes.

Rancher Desktop permite a los usuarios elegir entre diferentes runtimes de contenedores como ContainerD o DockerD, actualizar la versión de Kubernetes, y ajustar recursos de hardware como memoria y CPU del clúster, todo accesible a través de una interfaz de usuario simplificada.

Scaffold mejora el desarrollo local al detectar automáticamente los cambios en el código y recompilar e implementar la aplicación. Esto permite a los desarrolladores probar rápidamente cambios y asegurarse de que la aplicación funcione correctamente antes de su despliegue final en el clúster.

Lukonde Mwila
Lukonde Mwila
9 min
25 Mar, 2022

Comments

Sign in or register to post your comment.

Video Summary and Transcription

Lucan de Muela discute cómo optimizar los flujos de trabajo de desarrollo de Node.js en Kubernetes utilizando Skaffold y Rancher Desktop. Destaca la experiencia del desarrollador, la simplificación de la gestión de clústeres con Rancher Desktop y la optimización del flujo de trabajo de compilación/lanzamiento con Skaffold. También menciona la capacidad de actualizar las versiones de Kubernetes y elegir un tiempo de ejecución de contenedor, así como la opción de restablecer el clúster para un entorno de desarrollo seguro.

1. Optimización de flujos de trabajo de Node.js en Kubernetes

Short description:

Hola, soy Lucan de Muela, un Principal Evangelista Técnico en SUSE. En esta charla relámpago, te mostraré cómo optimizar tus flujos de trabajo de desarrollo de Node.js en Kubernetes con Scaffold y Rancher Desktop. Consideraremos la experiencia del desarrollador, cómo Rancher Desktop simplifica la gestión de clústeres, la optimización de flujos de trabajo de compilación y lanzamiento con Scaffold, y una demostración. Kubernetes resuelve problemas reales, y Rancher Desktop y Scaffold pueden complementar las prioridades principales de los desarrolladores al incorporar prácticas de DevOps. Rancher Desktop es una interfaz de usuario intuitiva que simplifica la gestión de clústeres, y Skaffold automatiza el proceso de construcción e implementación de imágenes de contenedor. Echemos un vistazo rápido a cómo funcionan.

Hola, soy Lucan de Muela, o puedes llamarme Luke. Voy a hablarles sobre cómo optimizar sus flujos de trabajo de desarrollo de Node.js en Kubernetes con Scaffold y Rancher Desktop. Soy un Principal Evangelista Técnico en SUSE, así que no dudes en contactarme en varias plataformas de redes sociales, ya sea Twitter o LinkedIn, siguiéndome en GitHub o suscribiéndote a mi canal de YouTube.

Ahora, esta es una charla relámpago, pero aún tengo algunos consejos valiosos que puedes llevar contigo en poco tiempo. Para empezar, vamos a considerar la experiencia del desarrollador al construir tus aplicaciones Node.js para Kubernetes. Luego, veremos cómo Rancher Desktop simplifica el ciclo de vida de gestión de clústeres, seguido de la optimización de flujos de trabajo de compilación y lanzamiento con Scaffold, y finalmente lo demostraremos. Esta es usualmente la parte favorita de todos.

Ahora, si eres un desarrollador y tienes experiencia trabajando en aplicaciones nativas de la nube, es posible que hayas sido reacio a ver esta sesión, porque quieres centrarte en el desarrollo de tu aplicación. Kubernetes se ve predominantemente como un mundo separado que no debería interferir con lo que deberías priorizar. Personalmente, estoy de acuerdo con eso. Sin embargo, hay un pequeño problema porque Kubernetes resuelve problemas reales. Y es posible que tu equipo esté lidiando con esos problemas, por lo que Kubernetes podría ser una solución que se encuentra dentro del panorama más amplio de tu arquitectura. Así que debes formar parte del viaje de todos modos.

Y aquí es donde las cosas se complican aún más porque hay diferentes ideas sobre quién debería ser dueño de qué. Mi objetivo es demostrar cómo Rancher Desktop y Scaffold pueden complementar las prioridades principales de los desarrolladores y aún incorporar prácticas de DevOps como flujos de trabajo de lanzamiento para implementaciones de aplicaciones en tu clúster de Kubernetes. Un ejemplo de esto sería ir más allá de NodeMod. Me encanta usar NodeMod cuando construyo mis aplicaciones Node.js porque reconstruye rápidamente los cambios y puedo verlos reflejados. Pero ¿qué pasaría si pudieras lograr eso con un pipeline de CI/CD completo en tu máquina local con todas las complejidades abstraídas pero aún configurables para un contexto local y para implementaciones remotas? Echaremos un vistazo a eso en breve.

La primera herramienta en esta solución es Rancher Desktop. RD es una aplicación de escritorio disponible en Windows, Linux y Mac. Es una aplicación basada en Electron que envuelve una serie de componentes bajo el capó con una máquina virtual que ejecuta K3S y ContainerD o DockerD, dependiendo de tu elección de configuración. Al final, tienes una interfaz de usuario intuitiva que simplifica el proceso de gestión de clústeres, y puedes actualizar o restablecer tu clúster con solo unos pocos clics.

La segunda herramienta en esta solución, o golpe uno-dos en mi mente, es Skaffold. El objetivo de Skaffold es simplificar el flujo de trabajo de desarrollo de Kubernetes automatizando y abstrayendo el proceso de construcción e implementación de imágenes de contenedor. El ciclo de desarrollo iterativo de codificación, construcción y prueba de tus aplicaciones es algo que puede mejorarse con Skaffold, porque tomará tus cambios locales y desencadenará un pipeline de implementación cada vez que los detecte. Esto es especialmente útil para depurar tus aplicaciones antes de que terminen en el clúster final objetivo. Por lo tanto, el uso de RD y Skaffold permite a los desarrolladores centrarse en la optimización de la aplicación porque te brindan la combinación de un clúster fácil de interactuar y gestionar, y un proceso de flujo de trabajo configurable que está automatizado y abstrae los detalles de DevOps. Echemos un vistazo rápido a esto en acción. Como puedes ver, tengo Rancher Desktop abierto y en ejecución, y actualmente estoy en la sección de configuración de Kubernetes. Aquí, muchas de las cosas principales que ocurren en torno a la gestión y optimización de tu clúster de Kubernetes se consolidarían en esta sección en particular.

2. Actualización de la versión de Kubernetes y reinicio del clúster

Short description:

Puedes actualizar fácilmente tu versión de Kubernetes y elegir un tiempo de ejecución de contenedor. Puedes modificar la máquina virtual y reiniciar el clúster. También hay un botón de reinicio para reinicios completos, lo que proporciona un entorno seguro para el desarrollo local del clúster.

Como puedes ver, puedo actualizar fácilmente mi versión de Kubernetes usando este menú desplegable aquí. Y esto obviamente dependerá de la versión específica en la que tú o tu equipo hayan acordado utilizar. Además de eso, si deseas elegir un tiempo de ejecución de contenedor específico entre ContainerD y DockerD, eso es algo que puedes alternar aquí. Y luego tienes diferentes situaciones cuando se trata de tus aplicaciones. Puede que algunas sean intensivas en memoria, otras en cómputo, pero quieres tener la oportunidad de modificar la máquina virtual con la que estás trabajando. Y puedes hacerlo aquí actualizando la memoria y la CPU específicas, y eso simplemente reiniciará tu clúster. Y también, si necesitas hacer un reinicio completo para eliminar todas las cargas de trabajo y la configuración que hayas establecido, por cualquier motivo, simplemente puedes hacer clic en el botón de reinicio aquí. Y eso es genial, especialmente cuando se trata del desarrollo local del clúster porque tienes la seguridad de que el impacto no afectará a otras personas o equipos. Pero aún así, quieres tener una forma sencilla de reiniciar y comenzar de nuevo. Ahora he cambiado a la aplicación, y lo que estás viendo es mi archivo de configuración de Scaffold, que es el archivo scaffold.yaml, y este archivo se utiliza básicamente para configurar cómo se va a construir e implementar tu aplicación en el clúster relevante. Si observas los campos de nivel superior, la versión de la API, el tipo y los metadatos son tres campos de nivel superior familiares cuando se trabaja con tus archivos de manifiesto de Kubernetes. Además de eso, tenemos construir, probar e implementar, y cada uno de ellos, el nombre implica con qué se ocupan realmente. Entonces, la construcción contiene las configuraciones de construcción, en este caso, los artefactos, y estoy construyendo una imagen de Docker, y especifico el archivo Docker específico que se está utilizando, como puedes ver aquí, así como el nombre de la imagen para que Scaffold sepa dónde enviar esta imagen en particular en términos del repositorio relevante. Y en la fase de pruebas, porque quiero intentar replicar lo que esencialmente haría en un pipeline de CI CD de producción o en la vida real, puedo importar esencialmente esas mismas características aquí, y este mismo archivo de configuración se puede utilizar local y remotamente, y así puedo incluir mi fase de prueba como puedes ver aquí, y estoy ejecutando npm run test con la misma imagen que estoy usando para mi fase de construcción. Y finalmente, en la sección de implementación, estoy usando kubectl o kubectl para implementar mis recursos de Kubernetes específicos, y especifico que estos recursos están definidos en el archivo manifest.yaml. Entonces, si voy al archivo manifest.yaml, verás aquí que tengo mi recurso de implementación y mi recurso de servicio. Ahora, si voy al archivo app.js, verás aquí que esta es una aplicación muy básica y solo tengo una única ruta llamada test, y la respuesta que debería obtener cuando acceda a ese punto final será ¿esperabas algo menos? Y también tengo una única prueba, y esa prueba se asegurará de que cada vez que consulte ese punto final en particular, debería obtener la respuesta relevante. Debería darme un estado de respuesta 200, y debería ser una respuesta de cadena, y debería tener exactamente ese mismo texto. Así que lo que voy a hacer ahora es ir a la terminal. Voy a ejecutar scaffold dev, y eso debería construir mi aplicación y ponerla en funcionamiento. Genial, como puedes ver, mi aplicación se ha construido y también ha pasado por la fase de prueba. Y como puedes ver aquí, la aplicación ahora se está ejecutando y está escuchando el tráfico en el puerto 8080. Así que si voy al navegador, y puedes ver, ya lo he probado anteriormente, pero estoy obteniendo la respuesta relevante. Ahora, lo genial de cómo Scaffold complementa el ciclo de desarrollo interno es que si volviera a mi aplicación y hiciera un cambio aquí que quisiera probar, simplemente agregaré, ¿esperabas algo menos este año? Actualizar eso, pero muy importante, también vamos a necesitar actualizar nuestras pruebas. Scaffold detectará esos cambios y procederá a volver a implementar la aplicación. Genial. Así que vemos que nuestra implementación se ha estabilizado, y si vengo aquí y simplemente actualizo eso, entonces obtengo la respuesta correcta. Esto hace que las cosas sean mucho más fluidas cuando se trata del desarrollo local de Kubernetes. Para tus desarrolladores que no necesitan saber demasiado sobre Kubernetes, esto les facilita mucho las cosas. Espero que te haya resultado útil.

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

Elevando Monorepos con los Espacios de Trabajo de npm
DevOps.js Conf 2022DevOps.js Conf 2022
33 min
Elevando Monorepos con los Espacios de Trabajo de npm
Top Content
Aprenda más sobre cómo aprovechar las características predeterminadas de los espacios de trabajo de npm para ayudarlo a administrar su proyecto monorepo, mientras también explora algunas de las nuevas características de npm cli.
Es una jungla ahí fuera: ¿Qué está pasando realmente dentro de tu carpeta Node_Modules?
Node Congress 2022Node Congress 2022
26 min
Es una jungla ahí fuera: ¿Qué está pasando realmente dentro de tu carpeta Node_Modules?
Top Content
¿Sabes qué está pasando realmente en tu carpeta node_modules? Los ataques a la cadena de suministro de software han explotado en los últimos 12 meses y solo están acelerándose en 2022 y más allá. Profundizaremos en ejemplos de recientes ataques a la cadena de suministro y qué pasos concretos puedes tomar para proteger a tu equipo de esta amenaza emergente.
Puedes consultar las diapositivas de la charla de Feross aquí.
Automatizando Todo el Código y las Pruebas con GitHub Actions
React Advanced Conference 2021React Advanced Conference 2021
19 min
Automatizando Todo el Código y las Pruebas con GitHub Actions
Top Content
Las tareas de código como linting y pruebas son partes críticas del flujo de trabajo de un desarrollador que nos ayudan a mantenernos cuerdos, como prevenir problemas de sintaxis o estilo y fortalecer nuestra lógica de negocio central. Hablaremos de cómo podemos usar GitHub Actions para automatizar estas tareas y ayudar a mantener nuestros proyectos funcionando sin problemas.
Ajustando DevOps para las Personas sobre la Perfección
DevOps.js Conf 2022DevOps.js Conf 2022
33 min
Ajustando DevOps para las Personas sobre la Perfección
Top Content
La demanda de DevOps ha aumentado en los últimos años a medida que más organizaciones adoptan tecnologías nativas de la nube. La complejidad también ha aumentado y una mentalidad de "cero a héroe" deja a muchas personas persiguiendo la perfección y FOMO. Esta sesión se centra en cambio en por qué tal vez no deberíamos adoptar una práctica tecnológica y cómo a veces los equipos pueden lograr los mismos resultados priorizando a las personas sobre la automatización y controles de operaciones. Veamos las cantidades y el ajuste fino de todo como código, solicitudes de extracción, DevSecOps, Monitoreo y más para priorizar el bienestar del desarrollador sobre la perfección de la optimización. Puede ser una decisión válida desplegar menos y dormir mejor. Y finalmente examinaremos cómo la práctica manual y la disciplina pueden ser la clave para productos y experiencias superiores.
Hacia una Biblioteca Estándar para Runtimes de JavaScript
Node Congress 2022Node Congress 2022
34 min
Hacia una Biblioteca Estándar para Runtimes de JavaScript
Top Content
Puedes revisar las diapositivas de la charla de James aquí.
ESM Loaders: Mejorando la carga de módulos en Node.js
JSNation 2023JSNation 2023
22 min
ESM Loaders: Mejorando la carga de módulos en Node.js
El soporte nativo de ESM para Node.js fue una oportunidad para el proyecto de Node.js de lanzar soporte oficial para mejorar la experiencia de carga de módulos, permitiendo casos de uso como la transpilación sobre la marcha, la sustitución de módulos, el soporte para cargar módulos desde HTTP y la monitorización.
Aunque CommonJS tiene soporte para todo esto, nunca fue oficialmente compatible y se hacía mediante hackeo del código de ejecución de Node.js. ESM ha solucionado todo esto. Analizaremos la arquitectura de la carga de ESM en Node.js y discutiremos la API del cargador que lo admite. También veremos características avanzadas como la concatenación de cargadores y la ejecución fuera de hilo.

Workshops on related topic

Masterclass de Node.js
Node Congress 2023Node Congress 2023
109 min
Masterclass de Node.js
Top Content
Workshop
Matteo Collina
Matteo Collina
¿Alguna vez has tenido dificultades para diseñar y estructurar tus aplicaciones Node.js? Construir aplicaciones que estén bien organizadas, sean probables y extensibles no siempre es fácil. A menudo puede resultar ser mucho más complicado de lo que esperas. En este evento en vivo, Matteo te mostrará cómo construye aplicaciones Node.js desde cero. Aprenderás cómo aborda el diseño de aplicaciones y las filosofías que aplica para crear aplicaciones modulares, mantenibles y efectivas.

Nivel: intermedio
Construye y Despliega un Backend con Fastify y Platformatic
JSNation 2023JSNation 2023
104 min
Construye y Despliega un Backend con Fastify y Platformatic
WorkshopFree
Matteo Collina
Matteo Collina
Platformatic te permite desarrollar rápidamente APIs GraphQL y REST con un esfuerzo mínimo. La mejor parte es que también te permite aprovechar todo el potencial de Node.js y Fastify cuando lo necesites. Puedes personalizar completamente una aplicación de Platformatic escribiendo tus propias características y complementos adicionales. En el masterclass, cubriremos tanto nuestros módulos de código abierto como nuestra oferta en la nube:- Platformatic OSS (open-source software) — Herramientas y bibliotecas para construir rápidamente aplicaciones robustas con Node.js (https://oss.platformatic.dev/).- Platformatic Cloud (actualmente en beta) — Nuestra plataforma de alojamiento que incluye características como aplicaciones de vista previa, métricas integradas e integración con tu flujo de Git (https://platformatic.dev/).
En este masterclass aprenderás cómo desarrollar APIs con Fastify y desplegarlas en la nube de Platformatic.
0 a Auth en una Hora Usando NodeJS SDK
Node Congress 2023Node Congress 2023
63 min
0 a Auth en una Hora Usando NodeJS SDK
WorkshopFree
Asaf Shen
Asaf Shen
La autenticación sin contraseña puede parecer compleja, pero es fácil de agregar a cualquier aplicación utilizando la herramienta adecuada.
Mejoraremos una aplicación JS de pila completa (backend de Node.JS + frontend de React) para autenticar usuarios con OAuth (inicio de sesión social) y contraseñas de un solo uso (correo electrónico), incluyendo:- Autenticación de usuario - Administrar interacciones de usuario, devolver JWT de sesión / actualización- Gestión y validación de sesiones - Almacenar la sesión para solicitudes de cliente posteriores, validar / actualizar sesiones
Al final del masterclass, también tocaremos otro enfoque para la autenticación de código utilizando Flujos Descope en el frontend (flujos de arrastrar y soltar), manteniendo solo la validación de sesión en el backend. Con esto, también mostraremos lo fácil que es habilitar la biometría y otros métodos de autenticación sin contraseña.
Tabla de contenidos- Una breve introducción a los conceptos básicos de autenticación- Codificación- Por qué importa la autenticación sin contraseña
Requisitos previos- IDE de tu elección- Node 18 o superior
Construyendo un Servidor Web Hiper Rápido con Deno
JSNation Live 2021JSNation Live 2021
156 min
Construyendo un Servidor Web Hiper Rápido con Deno
WorkshopFree
Matt Landers
Will Johnston
2 authors
Deno 1.9 introdujo una nueva API de servidor web que aprovecha Hyper, una implementación rápida y correcta de HTTP para Rust. El uso de esta API en lugar de la implementación std/http aumenta el rendimiento y proporciona soporte para HTTP2. En este masterclass, aprende cómo crear un servidor web utilizando Hyper en el fondo y mejorar el rendimiento de tus aplicaciones web.
Despliegue de aplicaciones React Native en la nube
React Summit 2023React Summit 2023
88 min
Despliegue de aplicaciones React Native en la nube
WorkshopFree
Cecelia Martinez
Cecelia Martinez
Desplegar aplicaciones React Native manualmente en una máquina local puede ser complejo. Las diferencias entre Android e iOS requieren que los desarrolladores utilicen herramientas y procesos específicos para cada plataforma, incluidos los requisitos de hardware para iOS. Los despliegues manuales también dificultan la gestión de las credenciales de firma, las configuraciones de entorno, el seguimiento de las versiones y la colaboración en equipo.
Appflow es la plataforma de DevOps móvil en la nube creada por Ionic. Utilizar un servicio como Appflow para construir aplicaciones React Native no solo proporciona acceso a potentes recursos informáticos, sino que también simplifica el proceso de despliegue al proporcionar un entorno centralizado para gestionar y distribuir tu aplicación en múltiples plataformas. Esto puede ahorrar tiempo y recursos, permitir la colaboración, así como mejorar la confiabilidad y escalabilidad general de una aplicación.
En este masterclass, desplegarás una aplicación React Native para su entrega en dispositivos de prueba Android e iOS utilizando Appflow. También aprenderás los pasos para publicar en Google Play y Apple App Stores. No se requiere experiencia previa en el despliegue de aplicaciones nativas, y obtendrás una comprensión más profunda del proceso de despliegue móvil y las mejores prácticas para utilizar una plataforma de DevOps móvil en la nube para enviar rápidamente a gran escala.