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.

This talk has been presented at DevOps.js Conf 2022, check out the latest edition of this JavaScript Conference.

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
NPM workspaces help manage multiple nested packages within a single top-level package, improving since the release of NPM CLI 7.0. You can easily add dependencies to workspaces and handle duplications. Running scripts and orchestration in a monorepo is made easier with NPM workspaces. The npm pkg command is useful for setting and retrieving keys and values from package.json files. NPM workspaces offer benefits compared to Lerna and future plans include better workspace linking and adding missing features.
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
The talk discusses the importance of supply chain security in the open source ecosystem, highlighting the risks of relying on open source code without proper code review. It explores the trend of supply chain attacks and the need for a new approach to detect and block malicious dependencies. The talk also introduces Socket, a tool that assesses the security of packages and provides automation and analysis to protect against malware and supply chain attacks. It emphasizes the need to prioritize security in software development and offers insights into potential solutions such as realms and Deno's command line flags.
Automatizando Todo el Código y las Pruebas con GitHub Actions
React Advanced 2021React Advanced 2021
19 min
Automatizando Todo el Código y las Pruebas con GitHub Actions
Top Content
We will learn how to automate code and testing with GitHub Actions, including linting, formatting, testing, and deployments. Automating deployments with scripts and Git hooks can help avoid mistakes. Popular CI-CD frameworks like Jenkins offer powerful orchestration but can be challenging to work with. GitHub Actions are flexible and approachable, allowing for environment setup, testing, deployment, and custom actions. A custom AppleTools Eyes GitHub action simplifies visual testing. Other examples include automating content reminders for sharing old content and tutorials.
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
DevOps is a journey that varies for each company, and remote work makes transformation challenging. Pull requests can be frustrating and slow, but success stories like Mateo Colia's company show the benefits of deploying every day. Challenges with tools and vulnerabilities require careful consideration and prioritization. Investing in documentation and people is important for efficient workflows and team growth. Trust is more important than excessive control when deploying to production.
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
There is a need for a standard library of APIs for JavaScript runtimes, as there are currently multiple ways to perform fundamental tasks like base64 encoding. JavaScript runtimes have historically lacked a standard library, causing friction and difficulty for developers. The idea of a small core has both benefits and drawbacks, with some runtimes abusing it to limit innovation. There is a misalignment between Node and web browsers in terms of functionality and API standards. The proposal is to involve browser developers in conversations about API standardization and to create a common standard library for JavaScript runtimes.
Cargadores ESM: Mejorando la carga de módulos en Node.js
JSNation 2023JSNation 2023
22 min
Cargadores ESM: Mejorando la carga de módulos en Node.js
Top Content
ESM Loaders enhance module loading in Node.js by resolving URLs and reading files from the disk. Module loaders can override modules and change how they are found. Enhancing the loading phase involves loading directly from HTTP and loading TypeScript code without building it. The loader in the module URL handles URL resolution and uses fetch to fetch the source code. Loaders can be chained together to load from different sources, transform source code, and resolve URLs differently. The future of module loading enhancements is promising and simple to use.

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.
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.
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