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.

9 min
25 Mar, 2022

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.

Available in English

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

Node Congress 2022Node Congress 2022
26 min
It's a Jungle Out There: What's Really Going on Inside Your Node_Modules Folder
Top Content
Do you know what’s really going on in your node_modules folder? Software supply chain attacks have exploded over the past 12 months and they’re only accelerating in 2022 and beyond. We’ll dive into examples of recent supply chain attacks and what concrete steps you can take to protect your team from this emerging threat.
You can check the slides for Feross' talk here.
React Advanced Conference 2021React Advanced Conference 2021
19 min
Automating All the Code & Testing Things with GitHub Actions
Top Content
Code tasks like linting and testing are critical pieces of a developer’s workflow that help keep us sane like preventing syntax or style issues and hardening our core business logic. We’ll talk about how we can use GitHub Actions to automate these tasks and help keep our projects running smoothly.
DevOps.js Conf 2022DevOps.js Conf 2022
33 min
Fine-tuning DevOps for People over Perfection
Top Content
Demand for DevOps has increased in recent years as more organizations adopt cloud native technologies. Complexity has also increased and a "zero to hero" mentality leaves many people chasing perfection and FOMO. This session focusses instead on why maybe we shouldn't adopt a technology practice and how sometimes teams can achieve the same results prioritizing people over ops automation & controls. Let's look at amounts of and fine-tuning everything as code, pull requests, DevSecOps, Monitoring and more to prioritize developer well-being over optimization perfection. It can be a valid decision to deploy less and sleep better. And finally we'll examine how manual practice and discipline can be the key to superb products and experiences.
Node Congress 2022Node Congress 2022
34 min
Out of the Box Node.js Diagnostics
In the early years of Node.js, diagnostics and debugging were considerable pain points. Modern versions of Node have improved considerably in these areas. Features like async stack traces, heap snapshots, and CPU profiling no longer require third party modules or modifications to application source code. This talk explores the various diagnostic features that have recently been built into Node.
You can check the slides for Colin's talk here. 

Workshops on related topic

Node Congress 2023Node Congress 2023
109 min
Node.js Masterclass
Top Content
Workshop
Have you ever struggled with designing and structuring your Node.js applications? Building applications that are well organised, testable and extendable is not always easy. It can often turn out to be a lot more complicated than you expect it to be. In this live event Matteo will show you how he builds Node.js applications from scratch. You’ll learn how he approaches application design, and the philosophies that he applies to create modular, maintainable and effective applications.

Level: intermediate
JSNation 2023JSNation 2023
104 min
Build and Deploy a Backend With Fastify & Platformatic
WorkshopFree
Platformatic allows you to rapidly develop GraphQL and REST APIs with minimal effort. The best part is that it also allows you to unleash the full potential of Node.js and Fastify whenever you need to. You can fully customise a Platformatic application by writing your own additional features and plugins. In the workshop, we’ll cover both our Open Source modules and our Cloud offering:- Platformatic OSS (open-source software) — Tools and libraries for rapidly building robust applications with Node.js (https://oss.platformatic.dev/).- Platformatic Cloud (currently in beta) — Our hosting platform that includes features such as preview apps, built-in metrics and integration with your Git flow (https://platformatic.dev/). 
In this workshop you'll learn how to develop APIs with Fastify and deploy them to the Platformatic Cloud.
Node Congress 2023Node Congress 2023
63 min
0 to Auth in an Hour Using NodeJS SDK
WorkshopFree
Passwordless authentication may seem complex, but it is simple to add it to any app using the right tool.
We will enhance a full-stack JS application (Node.JS backend + React frontend) to authenticate users with OAuth (social login) and One Time Passwords (email), including:- User authentication - Managing user interactions, returning session / refresh JWTs- Session management and validation - Storing the session for subsequent client requests, validating / refreshing sessions
At the end of the workshop, we will also touch on another approach to code authentication using frontend Descope Flows (drag-and-drop workflows), while keeping only session validation in the backend. With this, we will also show how easy it is to enable biometrics and other passwordless authentication methods.
Table of contents- A quick intro to core authentication concepts- Coding- Why passwordless matters
Prerequisites- IDE for your choice- Node 18 or higher
JSNation Live 2021JSNation Live 2021
156 min
Building a Hyper Fast Web Server with Deno
WorkshopFree
Deno 1.9 introduced a new web server API that takes advantage of Hyper, a fast and correct HTTP implementation for Rust. Using this API instead of the std/http implementation increases performance and provides support for HTTP2. In this workshop, learn how to create a web server utilizing Hyper under the hood and boost the performance for your web apps.
React Summit 2023React Summit 2023
88 min
Deploying React Native Apps in the Cloud
WorkshopFree
Deploying React Native apps manually on a local machine can be complex. The differences between Android and iOS require developers to use specific tools and processes for each platform, including hardware requirements for iOS. Manual deployments also make it difficult to manage signing credentials, environment configurations, track releases, and to collaborate as a team.
Appflow is the cloud mobile DevOps platform built by Ionic. Using a service like Appflow to build React Native apps not only provides access to powerful computing resources, it can simplify the deployment process by providing a centralized environment for managing and distributing your app to multiple platforms. This can save time and resources, enable collaboration, as well as improve the overall reliability and scalability of an app.
In this workshop, you’ll deploy a React Native application for delivery to Android and iOS test devices using Appflow. You’ll also learn the steps for publishing to Google Play and Apple App Stores. No previous experience with deploying native applications is required, and you’ll come away with a deeper understanding of the mobile deployment process and best practices for how to use a cloud mobile DevOps platform to ship quickly at scale.