El Estado del Núcleo de Node.js

This ad is not shown to multipass and full ticket holders
React Summit US
React Summit US 2025
November 18 - 21, 2025
New York, US & Online
The biggest React conference in the US
Learn More
In partnership with Focus Reactive
Upcoming event
React Summit US 2025
React Summit US 2025
November 18 - 21, 2025. New York, US & Online
Learn more
Bookmark
Rate this content

Node.js, como plataforma, está en constante cambio y evolución. El núcleo de Node es una mezcla de características de nuestra propia comunidad, así como de dependencias como V8 y libuv. Esta charla cubrirá los últimos desarrollos en el núcleo de Node.

This talk has been presented at Node Congress 2023, check out the latest edition of this JavaScript Conference.

FAQ

El programa de soporte a largo plazo (LTS) de Node.js fue creado para equilibrar las necesidades de desarrolladores y usuarios empresariales, lanzando nuevas versiones principales dos veces al año. Las versiones con números pares pasan a LTS activo durante un año y luego a mantenimiento por 18 meses, mientras que las versiones con números impares tienen un periodo de mantenimiento abreviado.

Las próximas versiones principales de Node.js se lanzarán en abril y octubre de cada año. En abril se lanzan versiones con números pares y en octubre versiones con números impares. Por ejemplo, la versión 20 se lanzará en abril y la versión 21 en octubre.

Se recomienda utilizar una versión LTS de Node.js para producción, como la versión 18 (Hydrogen), que es actualmente una LTS activa y pasará a mantenimiento en octubre de este año. Las versiones LTS ofrecen estabilidad y soporte extendido, ideal para entornos de producción.

El ecosistema de Node.js, representado por npm, es el más grande con más de 2 millones de paquetes, superando a otros registros de paquetes populares. Aunque no todos los paquetes son de alta calidad, el tamaño del ecosistema refleja la salud y la actividad comunitaria alrededor de Node.js.

Node 14, llamado Firmium, llegará al final de su vida útil a finales de abril, mientras que Node 16, conocido como Gallium, solo será compatible hasta septiembre de 2023 debido al fin de soporte de la versión de OpenSSL que incluye.

Node.js ha integrado varias nuevas características como reinos sombreados, métodos findLast y findLastIndex en arrays, mejoras en la API de internacionalización, y un ejecutor de pruebas incorporado. Además, se ha mejorado la compatibilidad con la plataforma web agregando APIs como Fetch, Web Streams y Web Crypto.

Colin Ihrig
Colin Ihrig
24 min
18 Apr, 2023

Comments

Sign in or register to post your comment.
Video Summary and Transcription
La charla de hoy discutió el estado del núcleo de Node.js, con descargas crecientes y más de 2 millones de paquetes en npm. Node.js tiene un programa LTS, con Node 14 actualmente en modo de mantenimiento. Se recomendó apuntar a Node 18, ya que Node 16 y su versión de OpenSSL pronto llegarán al final de su vida útil. Node 18, conocido como Hydrogen, es estable y tiene nuevas características. La charla también cubrió pruebas de CLI, módulos principales, nuevas características y mejoras próximas.
Available in English: The State of Node.js Core

1. Node.js Core State and LTS

Short description:

Hoy voy a hablar sobre el estado del núcleo de Node.js. El número de descargas desde nodejs.org sigue aumentando. npm es el único gestor de paquetes con más de 2 millones de paquetes. Node tiene un programa de soporte a largo plazo conocido como LTS. Lanzamos nuevas versiones en abril y octubre. Node 14 está actualmente en modo de mantenimiento.

Hola a todos, gracias por venir a mi charla. Hoy voy a hablar sobre el estado del núcleo de Node.js. Para empezar, quiero mostrar algunas métricas de descarga. Estas métricas son de los últimos dos años aproximadamente y se puede ver que el número de descargas desde nodejs.org sigue aumentando, con la excepción de dos grandes caídas de tráfico relacionadas con las vacaciones de Navidad y cosas así, pero sí, Node sigue en aumento. A continuación, quiero hablar sobre el ecosistema, así que esta es una gráfica de modulecounts.com que compara el tamaño del ecosistema de npm con otros registros de paquetes populares para cosas como Rust, Java y Ruby, entre otros. Esto no representa necesariamente el núcleo de Node, sino el ecosistema más grande. npm es el único gestor de paquetes en esta gráfica que tiene más de 2 millones de paquetes. JavaScript es, con mucho, el ecosistema más grande del mundo, y esto viene con algunas advertencias, ya que npm también aloja cosas que no son solo módulos de Node.js, así que hay otras cosas allí. No todos los módulos son de gran calidad, pero hay algunos paquetes realmente buenos. También hay otros que probablemente no se usan mucho o no deberían usarse mucho, pero en general, creo que esto representa bastante bien la salud del ecosistema.

A continuación, quiero hablar sobre el programa de soporte a largo plazo de Node, también conocido como LTS. En 2015, Node creó un plan de LTS para equilibrar a los individuos y desarrolladores que desean incluir la mayor cantidad de características posible con los usuarios empresariales, que valoran la estabilidad a lo largo de los años, no solo días o semanas. Creamos este plan donde dos veces al año, en abril y octubre, lanzamos una nueva versión principal del proyecto. Puedes ver aquí en la gráfica en la parte superior, la barra inestable etiquetada como Main. Ahí es donde se realiza todo el desarrollo activo del proyecto. Parches, nuevas características, cambios rompedores, todo se incluye en la rama principal. Luego mantenemos varias ramas de lanzamiento a las que seleccionamos confirmaciones cada vez que hacemos un lanzamiento. Ahora mismo tenemos las versiones 14, 16, 18, 19 y 20 de Node como ramas de lanzamiento activas o próximas. Este año en abril, lanzaremos la versión 20, y luego en octubre lanzaremos la versión 21. Así que hacemos lanzamientos con números impares en octubre y lanzamientos con números pares en abril. La última versión principal se convierte en lo que llamamos la línea de lanzamiento actual durante seis meses. Ahora mismo, la versión 19 de Node es la versión actual, y después de ese período de seis meses, si es una versión con número impar, pasará a un período de mantenimiento abreviado donde recibirá cosas como correcciones de seguridad, pero es más bien un período de gracia para que las personas migren, mientras que las versiones con números pares pasan a lo que llamamos LTS activo durante un año, y en LTS activo, aún obtienes todo, excepto los cambios rompedores que se incluyen en la línea de lanzamiento actual, pero los mantenemos en la línea de lanzamiento actual durante unas semanas para asegurarnos de que sean estables y no haya grandes regresiones, y luego los retrocedemos. Obtienes los mismos cambios, pero a un ritmo más lento y con una mayor garantía de estabilidad. Después de esos 12 meses, las versiones con números pares pasan al modo de mantenimiento durante 18 meses, esto es para dar tiempo suficiente a las grandes empresas y demás para migrar a la próxima línea de lanzamiento que van a utilizar. Así que esta es una descripción general de todas las líneas de lanzamiento en este momento.

A continuación, quiero profundizar en cada línea de lanzamiento individualmente y ver qué está sucediendo allí. Node 14 está actualmente en modo de mantenimiento. Se le asigna el nombre en código Firmium, así que todas las versiones LTS se les asigna un elemento de la tabla periódica, en este caso Firmium. Creo que comenzamos con Argon y Node 4, Boron y Node 6, y así sucesivamente. Algunas letras no tienen elementos de la tabla periódica, en ese caso simplemente inventamos algunos.

2. Node.js Core Versions and Recommendations

Short description:

Volviendo a Node 14, llegará al final de su vida útil a finales de abril. Recomiendo apuntar a Node 18 si es posible. Node 16 es conocido con el nombre en código gallium. La versión de OpenSSL que se incluye con Node 16 también llegará al final de su vida útil. Si estás migrando desde Node 14, no vayas a la versión 16. Si estás utilizando la versión 16, comienza a apuntar a Node 18. Node 18 se conoce con el nombre en código Hydrogen. Actualmente es una LTS activa y pasará a mantenimiento en octubre de este año. Node 18 es muy estable y tiene muchas características que no están en Node 14 y 16. Node 19 no tiene un nombre en código de elemento de la tabla periódica porque nunca será LTS. Fue lanzado originalmente en octubre de 2022. No entrará en LTS activa y no recomiendo usarlo en producción.

Eso es solo un dato curioso. Volviendo a Node 14, llegará al final de su vida útil a finales de abril, por lo que probablemente puedes esperar 1 o tal vez 2 lanzamientos más entre ahora y entonces, pero si estás utilizando Node 14, realmente necesitas comenzar a migrar ahora.

Recomiendo apuntar a Node 18 si es posible, y la razón de eso es que Node 16 también llegará al final de su vida útil este año. Node 16 es conocido con el nombre en código gallium. Debería haber llegado al final de su vida útil en abril de 2024, pero solo será compatible hasta septiembre de 2023. Hay una diferencia de 7 meses, pero hay una buena razón para ello. La versión de OpenSSL que se incluye con Node 16 también llegará al final de su vida útil, por lo que como proyecto, tuvimos que equilibrar si queríamos seguir admitiendo Node 16 solo porque sí, o dejarlo desaparecer en lugar de pedir a las personas que ejecuten lo que podría ser una versión posiblemente insegura de OpenSSL cuando llegue al final de su vida útil.

He vinculado la publicación oficial del blog en la parte inferior de la diapositiva aquí, si deseas más detalles. Pero en general, solo recomendaría que si estás migrando desde Node 14, no vayas a la versión 16. Si actualmente estás en la versión 16, comienza a apuntar a Node 18.

A continuación, quiero hablar brevemente sobre Node 18. Node 18 se conoce con el nombre en código Hydrogen. Actualmente es una LTS activa y pasará a mantenimiento en octubre de este año. Una vez que esté en mantenimiento, se admitirá con parches de seguridad y cosas así hasta abril de 2025. Node 18 es muy estable en este momento y en realidad tiene muchas características que no están en Node 14 y 16. Personalmente, esto es lo que recomendaría utilizar en producción. Esto es lo que estoy usando en producción en el trabajo. Como dije, es muy estable y definitivamente es lo que debes apuntar ahora.

Siempre habrá personas que quieran utilizar las últimas y mejores cosas en producción. En este momento, eso sería Node 19. Node 19 no tiene un nombre en código de elemento de la tabla periódica porque nunca será LTS. Fue lanzado originalmente en octubre de 2022. Seguirá siendo la línea de lanzamiento actual hasta abril de 2023. En ese momento, tendrá algunos meses de soporte de mantenimiento y llegará al final de su vida útil en junio de 2023. Como mencioné, no entrará en LTS activa. No recomiendo usarlo en producción. En el pasado, tuvimos muchos casos en los que la línea de lanzamiento actual tenía regresiones que no se incluían en LTS. Eso ya no es tanto el caso. Las versiones con números impares parecen ser cada vez más estables, lo cual es bueno. Pero aún así no lo recomendaría para producción.

3. Node.js Versiones de Lanzamiento y Recomendaciones LTS

Short description:

Hay un cambio notable en esta línea de lanzamiento. Se eliminaron las sondas de diagnóstico dTRACE, SystemTap y ETW. Node 14 está pasando a modo de mantenimiento, mientras que Node 16 sigue en aumento. Node 18 está ganando terreno lentamente, mientras que Node 19 no ha tenido mucho éxito. Se recomienda ejecutar una versión LTS en producción y considerar la facilidad de actualizaciones y la necesidad de nuevas características. A continuación, hablaré sobre las nuevas características en Node a través del proyecto V8.

Hay un cambio notable en esta línea de lanzamiento. Se eliminaron las sondas de diagnóstico dTRACE, SystemTap y ETW. La razón de esto es simplemente que Node es un proyecto de código abierto dirigido principalmente por voluntarios. Nadie se ofreció como voluntario o se hizo cargo de mantener esos fragmentos de código. Se estaban convirtiendo en una carga de mantenimiento y se eliminaron. Hay un problema abierto invitando a cualquier persona que se sienta fuertemente acerca de estas cosas a que venga y las apoye nuevamente, pero por ahora, no están en la base de código.

Similar al gráfico que mostré al principio, este es un desglose de las descargas por diferentes líneas de lanzamiento de Node en los últimos dos años. La barra azul, que comienza en el extremo izquierdo y luego disminuye a medida que pasa el tiempo, es Node 14. Ese es el comportamiento esperado y lo que queremos ver. Las descargas aumentaron y luego pasó a modo de mantenimiento y comenzaron a disminuir. De manera similar, Node 16, que es la barra naranja, todavía está en proceso de aumentar y avanzar hacia la derecha. Espero que las personas, y parece que la tendencia ya está comenzando en este gráfico, comiencen a migrar de la versión 16 a Node 18. Node 15 y 17 no se muestran en este gráfico porque ya habían alcanzado el final de su vida útil cuando se compiló este gráfico. Luego, puedes ver la línea amarilla de Node 18 comenzando a ganar impulso un poco más de la mitad del gráfico y está aumentando lentamente. Como dije, si volvemos a hacer este gráfico en unos meses, imagino que Node 18 será considerablemente más alto, con suerte más que Node 16. Y luego, la pequeña parte verde en el extremo derecho es Node 19. Puedes ver que llegó al mundo más tarde que todas las demás líneas de lanzamiento. No ha tenido tanto éxito y espero que también veamos que comienza a desaparecer.

Entonces, si quieres elegir qué versión ejecutar en producción, ya he insinuado esto, pero definitivamente deberías ejecutar una versión LTS en producción, especialmente si Node es crítico para la misión, si estás ganando dinero con Node.js en producción, entonces quieres ser lo más estable posible. También debes preguntarte si puedes actualizar fácil y frecuentemente. Estar en la vanguardia implica que puede haber problemas. Si insistes en ejecutar Node 19 en producción, asegúrate de poder actualizar fácilmente porque las cosas se mueven mucho más rápido allí. Y luego, realmente debes preguntarte si realmente necesitas todas las características más nuevas. Algunas personas realmente las necesitan, pero muchas veces la respuesta es no. No necesitas estrictamente las cosas más nuevas y puedes esperar unos meses. Estas son solo recomendaciones. Puedes hacer lo que quieras, pero así es como recomendaría proceder.

A continuación, quiero hablar sobre algunas de las nuevas características que han llegado a Node a través del proyecto V8. La forma en que funcionan las cosas es que cuando hay una nueva característica de JavaScript, TC39 crea una especificación para ella. Los implementadores de navegadores o motores de JavaScript como V8 realmente desarrollarán las nuevas características y una vez que Node.js se actualice a una versión de V8 que incluya esas características, las recibiremos automáticamente.

4. Nuevas características y mejoras de Node.js

Short description:

Una de las cosas que agregamos en Node es habilitar los reinos sombreados, que permiten ejecutar código en su propio reino. También tenemos nuevos métodos de matriz, adiciones y mejoras en la API, mejoras de rendimiento relacionadas con los campos y métodos de clase, integración de promesas de JavaScript para WebAssembly y compatibilidad con las API de la plataforma web. Node 18 también incluye un ejecutor de pruebas incorporado.

Una de las cosas que tuvimos que agregar en Node es habilitar los reinos sombreados. Los reinos sombreados son la solución oficial del lenguaje para cosas como el módulo VM de Node, para poder ejecutar código en su propio reino, enviar entradas y obtener salidas. Es similar a VM, pero un poco más seguro que Eval, pero como aún está detrás de una bandera experimental en V8, tuvimos que agregar una bandera experimental en Node para desbloquear esas características.

También tenemos un par de nuevos métodos en las matrices. find last y find last index son similares a find y find index, pero comienzan desde el final de la matriz en lugar del principio. Se han realizado varias adiciones y mejoras en la API. Si estás utilizando las API de internacionalización, se ha mejorado la localización y se han agregado el formato de número y los valores admitidos en el método. También ha habido algunas mejoras de rendimiento relacionadas con los campos y métodos de clase. Por lo general, cuando se agregan nuevas características a V8, no están completamente optimizadas. Entonces, los campos y métodos de clase llegaron a V8, tuvimos acceso a ellos en Node, pero evitamos usarlos porque eran más lentos que las alternativas que utilizaban símbolos y otras cosas. Pero el rendimiento ha mejorado y ahora podemos recomendar completamente su uso en tu código.

Y luego, algo importante que ha llegado recientemente es la integración de promesas de JavaScript. Esto se dirige específicamente a las personas que utilizan WebAssembly. La forma en que generalmente funcionaba era que llamabas desde tu código JavaScript a WebAssembly y WebAssembly realizaba alguna operación sincrónica. Si necesitaba alguna funcionalidad personalizada, podías llamar de vuelta a JavaScript. Pero no había una forma real de tener una integración asíncrona entre JavaScript y WebAssembly. Con tantas de las nuevas API de JavaScript basadas en promesas o simplemente asíncronas en general, había una especie de desconexión. Esto es realmente una gran mejora en la calidad de vida para las personas que utilizan WebAssembly y Node.

A continuación, quiero destacar algunas de las API que hemos obtenido basadas en la compatibilidad con la plataforma web. Node intenta admitir, cuando tiene sentido, muchas de las mismas API que se pueden obtener en un navegador. Una de las más importantes que las personas han estado esperando durante años es Fetch. El proyecto finalmente logró hacer que Fetch sucediera. Junto con Fetch, también se agregaron muchas otras API como Request, Response y FormData. Tenemos Web Streams, que son la respuesta del navegador a las transmisiones de Node.js. Actualmente, no están altamente optimizados en Node, pero están mejorando poco a poco. Tenemos Web Crypto, Structured Clone, que es muy útil para poder copiar objetos. No voy a enumerar todas las cosas diferentes aquí, pero constantemente estamos tratando de mejorar nuestra compatibilidad con la plataforma web.

Otra característica importante que se implementó en Node 18 es un ejecutor de pruebas incorporado. Hay algunas formas de usar el ejecutor de pruebas. Existe el módulo de pruebas node:test dentro de Core que puedes requerir.

5. Node.js CLI Runner y Módulos Core

Short description:

Hay un ejecutor de línea de comandos (CLI) para pruebas en Node.js. Admite subpruebas, saltar pruebas, especificar solo pruebas, ganchos del ciclo de vida y simulación. Tiene cobertura de código incorporada y permite reportes personalizados. El reporte predeterminado es TAP, pero puedes usar SPEC para un formato más legible para humanos. Los módulos principales solo con prefijo 'node-' permiten identificar fácilmente los módulos principales.

También hay un ejecutor de línea de comandos (CLI), que se habilita con guión, guión, prueba. Y si estás utilizando una versión anterior de Node que, ya sabes, no se ha adaptado a esto, como por ejemplo, actualmente Node 14 no tiene soporte para ello.

Algunas personas amables tomaron el código de Core, lo pusieron en un paquete en npm, y puedes instalarlo desde allí y obtener casi todas las mismas funcionalidades. Por lo tanto, admite muchas de las cosas que esperarías que un ejecutor de pruebas, soporte de pruebas, admita de forma predeterminada.

Por lo tanto, tiene subpruebas. Puede saltar pruebas. Puedes especificar solo pruebas, por lo que solo quieres ejecutar un subconjunto de tu conjunto de pruebas. Ganchos del ciclo de vida, como antes, antes de cada uno, después y después de cada uno, y cosas así. Y también admite simulación de forma predeterminada.

Actualmente no admite la simulación de módulos completos. Debido a algunas limitaciones en los módulos ES. Pero puedes simular funciones, métodos y cosas así. Tiene cobertura de código incorporada de forma predeterminada, que puedes habilitar con la bandera --experimental-test-coverage del CLI. Y ahora también puedes generar tus propios reportes personalizados.

Por lo tanto, hay algunos que están integrados en Node. De forma predeterminada, será TAP, que significa Protocolo de Prueba de Cualquier Cosa, que es un formato para expresar resultados de pruebas, que se utiliza, entre otros ecosistemas, no solo en Node.js. Y eso se enviará a través de la salida estándar, pero puedes personalizarlo. Puedes usar SPEC, que es un formato más legible para humanos. TAP, el formato pequeño donde solo se muestran puntos con X. No sé cómo se llama eso. Y luego puedes usar la bandera de destino del reporte de prueba, donde puedes decir dónde quieres que se envíen tus resultados. Por defecto, es la salida estándar, pero puedes usar la salida de error estándar y otras cosas.

Esto es solo una imagen rápida de cómo se ve una prueba. Admitimos pruebas sincrónicas, pruebas asincrónicas, devoluciones de llamada, etc. A la izquierda, aquí está lo que obtendrías si ejecutases la prueba anterior y generases la salida TAP. A la derecha está lo que obtienes con el reporte SPEC. Si quieres colores y cosas que sean un poco más amigables para los humanos, puedes usar eso.

Del TestRunner también surgió otra nueva característica llamada módulos principales solo con prefijo 'node-'. La diferencia aquí, si miras en la parte superior, estamos importando node:test y node:assert. Cada módulo principal se puede importar usando el prefijo 'node:', y eso es bueno porque permite que las herramientas y las personas que leen el código lo sepan.

6. Módulos Core de Node.js y Nuevas Características

Short description:

Puedes importar módulos core sin el prefijo 'node'. Hay un modo de observación similar a nodemon. util.parse.args es una API simple para analizar indicadores de línea de comandos. El soporte para aplicaciones ejecutables individuales permite distribuir binarios de Node.js. Se ha implementado un sistema de permisos para restringir el acceso al sistema de archivos y a los procesos secundarios. Otros cambios destacados incluyen el soporte de 'happy eyeball' y ayudantes de streams.

justo al principio cuando algo es un módulo core. En la parte inferior, también puedes importar el módulo assert y todos los demás módulos coremodules sin el prefijo 'node', pero con TestRunner, y probablemente con todos los futuros módulos coremodules, eso no es el caso. Node-test te dará el módulo core, just-test intentará cargar desde el código de usuario, así que módulos node y cosas así. Es una distinción importante a tener en cuenta, especialmente a medida que potencialmente habrá más módulos coremodules que sigan este patrón. Ahora también tenemos un modo de observación, por lo que es muy similar a nodemon. Si has usado ese indicador de línea de comandos --watch, observará todos tus archivos importados, y cuando alguno de ellos cambie, reiniciará Node. Está integrado con TestRunner, por lo que puedes ejecutar tus pruebas, hacer algunos cambios y luego volverá a ejecutar tus pruebas por ti. Y puedes personalizarlo con el indicador --watch-path para especificar qué archivos realmente quieres observar, aunque esto está limitado a macOS y Windows. También está util.parse.args. Esta es una API simple para analizar indicadores de línea de comandos y devolverlos en una estructura de datos. Esto se estabilizará en node 20, por lo que es algo con lo que debes estar familiarizado. Una cosa menos en la que tienes que depender de NPM. Recientemente, hemos agregado soporte para aplicaciones ejecutables individuales. Esto te permite inyectar tu código de aplicación en un binario de Node.js, y luego puedes distribuir ese binario en sistemas que no tienen Node o NPM instalado. Actualmente, solo se admite un archivo común JS, pero puedes, ya sabes, usar un bundler o algo así para crear ese archivo común JS y luego empaquetar toda tu aplicación de esa manera. El proyecto Node tiene un módulo auxiliar para esto llamado postject, que está disponible en NPM. Fue amablemente donado por la gente de Postman Labs. Hay herramientas similares disponibles, pero el proyecto no prueba oficialmente ninguna de ellas. También hemos agregado recientemente un sistema de permisos. Para habilitarlo, se usa el indicador --experimental-permission. Una vez habilitado, restringe el acceso al sistema de archivos, a los procesos secundarios y a los marcadores, y luego hay varios indicadores a continuación que puedes usar para desbloquear todo o partes de esas cosas. Se admiten comodines, por lo que puedes decir allow FS read star, y eso te permitirá leer cualquier cosa del sistema de archivos. También puedes usar la API programática dentro de tu código. Por ejemplo, process.permission.has, puedes verificar si tienes un permiso específico, y luego puedes, ya sabes, denegar cosas adicionales en tiempo de ejecución. No hay forma de volver a permitirlas. Tiene sentido porque no querrías permitir que las personas se otorguen más permisos, pero siempre puedes verificar qué permisos tienes actualmente, y puede ser un poco más granular. Aquí puedes ver que hemos deshabilitado los derechos del sistema de archivos para un directorio específico. Aún tenemos acceso general al sistema de archivos, pero no a ese directorio específico es lo que este ejemplo está transmitiendo. También ha habido otros cambios destacados recientemente. Soporte de 'happy eyeball', que te permitirá hacer resolución DNS con IPv4 y v6 al mismo tiempo. Ayudantes de streams para convertir entre streams de Node y streams web y cosas así.

7. Pruebas de Snapshot y Enlaces Importantes

Short description:

Teníamos pruebas de snapshot, pero se eliminaron debido a la insatisfacción con la implementación. Las próximas características incluyen la interfaz de función extranjera, una mejor integración con TypeScript, soporte de proxy para fetch y mejoras en los módulos core. Se proporcionan enlaces importantes para informes de errores, preguntas de soporte, calendario de lanzamientos y vulnerabilidades de seguridad. Únete a la comunidad de OpenJS Foundation en Slack para discusiones sobre el proyecto. Se hace una mención a Platformatic, una empresa que simplifica la creación de API con Node.js.

No voy a mencionar todos ellos, nuevamente por falta de tiempo, pero vale la pena señalar que teníamos pruebas de snapshot, el assert.snapshot, pero la gente no estaba realmente satisfecha con la implementación, así que lo hemos eliminado y esperamos revisarlo para refinarlo un poco más.

Algunas características potenciales próximas, recientemente se abrió una solicitud de extranjero interfaz de función o FFI para el core. Actualmente, las personas están trabajando en soluciones para una mejor integración con TypeScript, agregando soporte de proxy a fetch y con suerte prometiendo más mejoras en los módulos core, solo quedan unos pocos en este momento. Nuevamente, todas estas son cosas futuras que pueden o no suceder, así que creo que probablemente sucederán, pero no quiero hacer promesas que no pueda cumplir. Y por último, quería mencionar algunos de los enlaces importantes relacionados con el proyecto, por lo que si tienes un informe de error o una solicitud de función, ve a nodejs slash node en GitHub. Si tienes una pregunta de soporte, puedes crear una discusión o ir a nodejs slash help. Si estás interesado en el calendario de lanzamientos, algunas de las cosas que mencioné anteriormente en esta charla, nodejs slash release tiene todos los detalles. Si tienes una vulnerabilidad de seguridad que encontraste, por favor repórtala en HackerOne con el enlace aquí, no la informes en el rastreador de problemas público. Y finalmente, nodejs está activo en la comunidad de OpenJS Foundation en Slack, por lo que hay un enlace aquí donde puedes unirte a Slack. Nodejs y nodejs slash core son los canales principales donde se discute el proyecto. Y eso es todo de mi parte. Solo quería hacer una mención a la empresa para la que estoy trabajando actualmente, Platformatic, que ayuda a simplificar la creación de API con Node.js mucho más fácil para las API REST, GraphQL, Metrix, todas las cosas que son un poco indiferenciadas, estamos tratando de hacerlas más simples para todos. Y eso es todo lo que tengo. Gracias nuevamente por venir a mi charla.

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

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.
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.
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.
Diagnostics de Node.js listos para usar
Node Congress 2022Node Congress 2022
34 min
Diagnostics de Node.js listos para usar
This talk covers various techniques for getting diagnostics information out of Node.js, including debugging with environment variables, handling warnings and deprecations, tracing uncaught exceptions and process exit, using the v8 inspector and dev tools, and generating diagnostic reports. The speaker also mentions areas for improvement in Node.js diagnostics and provides resources for learning and contributing. Additionally, the responsibilities of the Technical Steering Committee in the TS community are discussed.
Compatibilidad con Node.js en Deno
Node Congress 2022Node Congress 2022
34 min
Compatibilidad con Node.js en Deno
Deno aims to provide Node.js compatibility to make migration smoother and easier. While Deno can run apps and libraries offered for Node.js, not all are supported yet. There are trade-offs to consider, such as incompatible APIs and a less ideal developer experience. Deno is working on improving compatibility and the transition process. Efforts include porting Node.js modules, exploring a superset approach, and transparent package installation from npm.
El Estado de Node.js 2025
JSNation 2025JSNation 2025
30 min
El Estado de Node.js 2025
The speaker covers a wide range of topics related to Node.js, including its resilience, popularity, and significance in the tech ecosystem. They discuss Node.js version support, organization activity, development updates, enhancements, and security updates. Node.js relies heavily on volunteers for governance and contribution. The speaker introduces an application server for Node.js enabling PHP integration. Insights are shared on Node.js downloads, infrastructure challenges, software maintenance, and the importance of update schedules for security.

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
Construir y Desplegar un Backend Con Fastify & Platformatic
JSNation 2023JSNation 2023
104 min
Construir y Desplegar un Backend Con Fastify & Platformatic
Top Content
WorkshopFree
Matteo Collina
Matteo Collina
Platformatic te permite desarrollar rápidamente GraphQL y REST APIs con un esfuerzo mínimo. La mejor parte es que también te permite desatar todo el potencial de Node.js y Fastify siempre que lo necesites. Puedes personalizar completamente una aplicación de Platformatic escribiendo tus propias características y plugins adicionales. En la masterclass, cubriremos tanto nuestros módulos de Open Source 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 esta masterclass aprenderás cómo desarrollar APIs con Fastify y desplegarlas en la Platformatic Cloud.
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
Workshop
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.
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
GraphQL: De Cero a Héroe en 3 horas
React Summit 2022React Summit 2022
164 min
GraphQL: De Cero a Héroe en 3 horas
Workshop
Pawel Sawicki
Pawel Sawicki
Cómo construir una aplicación GraphQL fullstack (Postgres + NestJs + React) en el menor tiempo posible.
Todos los comienzos son difíciles. Incluso más difícil que elegir la tecnología es desarrollar una arquitectura adecuada. Especialmente cuando se trata de GraphQL.
En este masterclass, obtendrás una variedad de mejores prácticas que normalmente tendrías que trabajar en varios proyectos, todo en solo tres horas.
Siempre has querido participar en un hackathon para poner algo en funcionamiento en el menor tiempo posible, entonces participa activamente en este masterclass y únete a los procesos de pensamiento del instructor.
Dominando Node.js Test Runner
TestJS Summit 2023TestJS Summit 2023
78 min
Dominando Node.js Test Runner
Workshop
Marco Ippolito
Marco Ippolito
Node.js test runner es moderno, rápido y no requiere bibliotecas adicionales, pero entenderlo y usarlo bien puede ser complicado. Aprenderás a utilizar Node.js test runner a su máximo potencial. Te mostraremos cómo se compara con otras herramientas, cómo configurarlo y cómo ejecutar tus pruebas de manera efectiva. Durante la masterclass, haremos ejercicios para ayudarte a sentirte cómodo con el filtrado, el uso de afirmaciones nativas, la ejecución de pruebas en paralelo, el uso de CLI y más. También hablaremos sobre trabajar con TypeScript, hacer informes personalizados y la cobertura de código.