Bun, Deno y muchos otros tiempos de ejecución de JavaScript han sido elogiados, pero ¿sabes por qué? ¿Es tan fácil crear un tiempo de ejecución desde cero?
He estado investigando el secreto detrás del poder de Node.js y por qué hay tantos nuevos tiempos de ejecución de JavaScript surgiendo. Desglosando cada componente clave utilizado en Node.js, he llegado a conclusiones interesantes que muchas personas solían decir, pero en la práctica funciona de manera un poco diferente.
En esta charla, los asistentes aprenderán los conceptos utilizados para crear un nuevo tiempo de ejecución de JavaScript. Pasarán por un ejemplo de cómo hacer un tiempo de ejecución de JavaScript siguiendo lo que está detrás de escena en el proyecto Node.js utilizando C++. Aprenderán la relación entre V8 de Chrome y Libuv y qué hace que un tiempo de ejecución de JavaScript sea mejor que otros.
Esta charla cubrirá los siguientes temas:
- ¿Qué es un motor de JavaScript - V8
- ¿Por qué Node.js utiliza Libuv
- Cómo crear un tiempo de ejecución de JS desde cero
Bun, Deno, Node.js? Recreando un tiempo de ejecución de JavaScript desde cero - Comprende la magia detrás de Node.js
Video Summary and Transcription
La charla explora la magia detrás de Node.js y profundiza en sus componentes, incluyendo V8, libuv y el puente C++. Se discute el flujo de trabajo y el proceso de ejecución, el uso de NodeMod y la comprensión de las funciones de la consola. La charla también cubre las funciones y programación de Node.js, la introducción de tiempos de ejecución y la colaboración entre los tiempos de ejecución de JavaScript. Concluye con ideas sobre la producción de contenido, la elección de Node.js y la inspiración detrás de él.
1. Introducción a Node.js y mi investigación
Hoy, les hablaré sobre algunos experimentos, algunas ciencias locas que he estado haciendo usando JavaScript y muchas cosas más. Comencé a investigar sobre Node.js y encontré información contradictoria. Así que decidí crear un tutorial basado en mi propia investigación. Vamos a entender la magia detrás de Node.js y explorar el repositorio de Node.js.
Hoy, les hablaré sobre algunos experimentos, algunas ciencias locas que he estado haciendo usando JavaScript y muchas cosas más, y espero que les guste mucho este contenido porque fue un verdadero esfuerzo crear todo esto. Para comenzar, todo lo que les mostraré hoy ya está en línea, así que después de la charla les mostraré algunos enlaces para que puedan ir allí, pero por favor, si pueden, tomen una foto de esta charla, mencionen el evento, mencionenme porque esto nos ayuda mucho con el trabajo que hemos estado haciendo. Muy bien. Estoy muy emocionado, voy a hablar sobre Node.js y el creador de NodeJS está aquí, el bun, y así sucesivamente. Así que es bastante asombroso. Bueno, en primer lugar, he estado haciendo muchos otros experimentos. Estaba tratando de volver a implementar Node.js, re-implementando WebSockets, re-implementando la cobertura de código, así que he estado haciendo muchas preguntas específicas, así que estoy muy curioso, y todos estos tutoriales están allí para que también los encuentren. Bueno, todo este experimento comenzó cuando comencé a preguntarme, bueno, ¿realmente sé qué es Node.js? Así que comencé a investigar y descubrí que algunos artículos decían que V8 hace una cosa, Libuv hace otra, JavaScript tiene otro papel, y a veces un artículo era controvertido con otro, así que pensé, hmm, tal vez debería aprender más, tal vez debería entender mejor. Así que realmente no sé qué está sucediendo detrás de escena, cómo está funcionando realmente. Así que comencé a investigar un poco y descubrí que no hay contenido sobre esto. Nadie ha recreado todo esto, compilando todas las bibliotecas, pero comencé a investigar en el sitio web de Node.js, y esos enlaces me ayudaron mucho a aprender cómo funciona el bucle de eventos, cómo funciona el módulo de concurrencia en Node.js, pero aún así, quería más. Así que por eso creé este tutorial. Este es un tutorial completo paso a paso, en el que se basa esta charla, así que esta charla va a ser muchos aspectos destacados, porque no puedo mostrar todo práctico aquí. Así que pueden probarlo más tarde. Solo un aviso antes de continuar, voy a decirles, todo lo que hay aquí es parte de mi investigación, ¿de acuerdo? No soy un desarrollador de C++. Es posible que vean muchas malas prácticas allí, pero es algo que disfruté haciendo. Además, esto es parte de mi propia investigación. Como les dije, no hay contenido en Internet. Así que comencé a preguntar a algunos amigos, a mirar el código fuente y a hacer algunas suposiciones. Y solo un aviso, los autores de los JS Runtimers, son increíbles. Comencé a valorarlos más a medida que vi lo complejo que es detrás pueden usar JavaScript allí. Muy bien, vamos a la parte divertida, ¿verdad? Así que vamos a entender la magia detrás de Node.js. Todo esto, lo hice como un Gitpod. Hice todo el entorno para ustedes allí mismo. Son binarios y muchas cosas que pueden comenzar a usar de inmediato. Para comenzar, pensé, ¿qué pasa si voy al repositorio de Node.js y trato de encontrar cómo Ryan Doll estaba haciendo esto? Así que descubrí muchos archivos. Y descubrí como, oh, tal vez debería intentar reproducir esto, pero si ven, fue hace 14 años. Como muchas herramientas, ni siquiera funciona más. Pero aún así, ¿alguien ha visto este sitio web antes?
2. Introducción a los Componentes de Node.js
Esta fue la primera versión lanzada de Node.js. Es la V001. Y puedes ver que en ese entonces no había console.log. Era puts. Muy bien. Traté de dividir los componentes principales para que puedas entender el papel de cada uno. Vamos a hablar sobre V8, libuv y el impresionante puente C++. Voy a intentar implementar una nueva función en el lado de V8. Echemos un vistazo a nuestro código JS y creemos una función de impresión en C++. Detrás de escena, V8 es como el evolucionador. Una función setTimeout es algo asíncrono, depende del entorno. Por eso Node.js es tan bueno, porque es extensible. La mayoría de los entornos de ejecución de JS siguen la misma idea. Voy a intentar hacer algunos experimentos usando nuestro código JavaScript. Aquí está todo el proyecto en C++.
Primero, vamos a hablar sobre V8. V8 es la gramática, son los tipos de datos de JavaScript, es cómo se interpreta JavaScript, lo que significa una clase, una variable, un tipo de datos, todo está en V8. También tenemos libuv. Libuv es la parte asíncrona de la que hemos estado hablando mucho. Pero solo piensa en ello como un while true que busca nuevos eventos y, si los hay, si hay eventos pendientes, los despacha todos y puedes comenzar a recibir más datos y así sucesivamente. Y aquí, para mí, está la parte asombrosa. El puente C++. Así que cuando intentes encontrar, te darás cuenta de que Node.js es casi todo en C++. Voy a intentar algo mágico contigo, intentando implementar una nueva función en el lado de V8. Así que echemos un vistazo a nuestro código JS. Cuando comienzas a usar V8 desde cero, nuestro contexto, nuestro disco global está vacío. Entonces no hay nada allí que podamos usar, pero voy a intentar implementar la función de impresión. Print no existe en JavaScript, ¿de acuerdo? Entonces, si quiero poder ejecutar esta función desde el lado de JavaScript, esto debe estar en V8. Así que usando el puente C++, voy a crear una función de impresión en C++, y luego la voy a vincular al contexto. Verás, diría que cada vez que vea esta cadena, voy a llamar a esta función de C++. Detrás de escena, V8 es como el evolucionador, ¿verdad? Está evaluando todo lo que quieres. Bien, vamos a intentar hacer algo más difícil. Una función setTimeout es algo asíncrono, depende del entorno, así que podemos usar uvstart, que son funciones de libuv. Hacemos exactamente lo mismo, mapeamos esta cadena a esta función de C++ y luego ya está disponible en V8. Te digo, esta fue la parte para mí como, oh dios mío, por eso esto es tan bueno, porque es extensible, ¿verdad? La mayoría de los entornos de ejecución de JS siguen la misma idea, extienden el entorno de ejecución de JavaScript y hacen muchas cosas geniales. Así que aquí mismo, voy a intentar hacer algunos experimentos usando nuestro código JavaScript. Aquí puedo
3. Flujo de Trabajo y Ejecución
En esta parte, exploraremos el flujo de trabajo del proyecto. Comenzamos leyendo el archivo Index.js como una cadena y luego lo compilamos en instancias de C++. A continuación, examinamos la ejecución real y la espera de eventos. Este proceso implica evaluar el código y programar eventos.
4. Using NodeMod and Understanding Console
Si vas al código fuente, verás que se lee el archivo desde C++. Para hacer este proyecto, pasé un mes tratando de crear una estructura para poder reutilizarla. Pensé, ¿qué tal si simplemente uso NodeMod para esperar cualquier cambio y luego actualizar nuestra aplicación? En primer lugar, ¿qué sucede si intentamos llamar a console.log? Todo lo que depende del entorno es parte de algo más. Echemos un vistazo a la impresión. Es agradable ver algo tan complejo y aún así usar algo que, para mí, era realmente primitivo.
5. Node.js Functions and Scheduling
Cada función en Node.js se instancia utilizando el mismo enfoque. JavaScript tiene algunas excepciones, como el tiempo que depende del entorno. Las plantillas de cadenas, los mapas, los operadores de propagación y las promesas están integrados en V8. Las promesas son envoltorios para devoluciones de llamada que ayudan a los desarrolladores a escribir un código mejor. setTimeout e setInterval implican programar funciones para su ejecución futura, con variables y referencias en su lugar. Se crea el temporizador de libuv para ejecutar la función y el resultado se envía de vuelta a JavaScript. Las promesas en JavaScript no son operaciones LibuV o asíncronas. El código UV ejecuta eventos y espera nuevos. Las promesas se pueden usar con async/await, ya que forman parte del lenguaje V8. La primera versión de Node.js expuso temporizadores y se ejecutó desde un archivo JavaScript, siguiendo la especificación ECMAScript.
6. Introduction to Runtimes and Research
Es por eso que tenemos módulos ECMAScript para reemplazar como el Common JS o el Required JS y facilitar nuestras vidas y también las vidas de los autores de otros runtimes. Bueno, ahora tenemos muchos otros nuevos runtimes que vienen, ¿verdad? La primera pregunta que tuve fue, ¿es fácil crear un runtime? ¿Por qué necesitamos un runtime ahora? Node ha estado allí durante casi 10 años. Así que comencé a investigar, a revisar su código y tenía algunas suposiciones. Primero, DNO. Si vas al código fuente de DNO, verás un código muy similar al que tenemos en el lado de C++ escrito en Rust. Está tomando una cadena, compilándola y ejecutándola. ¿De acuerdo? La misma idea. Exactamente la misma idea en C++. Y luego puedes ver que está inyectando DNO core, que extiende V8 e inyecta más código. Exactamente la misma idea interesante. ¿Qué pasa con Bunn? Bueno, Bunn es más una idea de ciencia matemática porque utiliza JavaScript core en lugar de V8, que no tiene documentación. No sé cómo lo ha escrito, y está escrito en Zig. Pero al mirar todo el código, verás el mismo enfoque. Está extendiendo las vinculaciones naturales del runtime de JavaScript y ejecutando muchas cosas.
7. JavaScript Runtimes and Collaboration
Lo que hace que un tiempo de ejecución de JavaScript sea mejor que otros es cómo manejan la complejidad de los módulos y la comunicación entre procesos. Bunn afirma ser más rápido debido a mejores algoritmos. La experiencia del desarrollador también juega un papel importante, con Dino ofreciendo características como pruebas nativas y TypeScript. Sin embargo, no es una competencia entre Dino, Bunn y Node.js. Están colaborando y compartiendo ideas para beneficiar a los desarrolladores. Si quieres aprender más e implementar tu propio FS, hay un tutorial en video y un libro electrónico disponibles en el sitio web del ponente.
QnA
Closing Remarks and Q&A
Antes de terminar esta charla, tomemos una selfie y hagamos algo de ruido. Gracias por tenerme aquí. Estaré en el escenario con Ryan Dow para más discusiones. Ahora, respondamos una pregunta sobre por qué el proyecto de demostración se llama Capybara. Quería mostrar que Brasil es más que solo samba. Una de las cosas que más me gusta de mi trabajo es el poder de la comunidad y la curiosidad. He tenido conversaciones con personas de Google y V8, y ahora estoy planeando recrear React Native. Es una tarea desafiante, pero divertida. Hablando de desafíos, encontrar el coraje para hacer esto viene de mi amor por la historia. Incluso las mentes más grandes enfrentan problemas similares. Así que acepto el desafío.
Explorando Experimentos Personales e Historias de YouTube
Diría que porque no había contenido en Internet. ¿Has considerado escribir tu propio bucle de eventos para un tiempo de ejecución de juguete como este en lugar de libuv? Bueno, nunca. En realidad, libuv fue escrito para Node.js, ¿verdad? ¿Cuál es la recreación de la que estás más orgulloso? Es difícil de decir. Estaba intentando usar aprendizaje automático en el navegador utilizando las APIs de TensorFlow. ¿Alguna financiación o descubrimientos de Node.js, brepro, arqueología? Oh, no tengo idea. ¿Habrá algún video sobre cómo crear tu propia imagen de Node-Docker como Alpine, etc., por favor? ¿Cuánto dinero ganas en YouTube? No estás escuchando, ¿verdad? No. Permíteme contar una historia. YouTube es horrible.
Bueno, nunca. En realidad, libuv fue escrito para Node.js, ¿verdad? Antes era, creo, libio que solo funcionaba en sistemas operativos Linux y Mac, y libuv vino a ayudar en el sistema Mac. Pero estaba mirando las APIs del sistema operativo, Dios mío, esto no es legible para los humanos, ¿verdad? No sé si hay algún desarrollador de C++ aquí. Realmente valoro mucho tu trabajo, porque es bastante difícil. Sí, parece. ¿Cuál es la recreación de la que estás más orgulloso? Es difícil de decir. Diría que siempre intento enseñar algo que no estoy 100% seguro de saber, para desafiarme mucho. Lo último fue, diría, estaba intentando usar aprendizaje automático en el navegador utilizando las APIs de TensorFlow. Y pensé, ¿qué tal si puedo usar la cámara web para hacer clic en los elementos como lo hacía la realidad virtual, ¿verdad? Así que la API era increíble haciendo esto, así que tuve que mapearlo todo. Pero el navegador no te permite simular un hover. Así que fue un desafío encontrar el CSS del elemento para poder hacer clic, pero fue muy divertido. Y solo por curiosidad, después de dos semanas, Zuckenberg publicó, como, chicos, oh, Zuckenberg te está robando. Vamos, dale un aumento, hombre. ¿Qué? Lo siento. ¿Alguna financiación o descubrimientos de Node.js, brepro, arqueología? Oh, no tengo idea, pero tal vez lo del Atlántico, ¿verdad? No sé si es así. No tengo idea. Sí. No sé si se puede llamar arqueología, pero está ahí, ¿verdad?, las ramas y todas esas cosas, cosas antiguas. ¿Habrá algún video sobre cómo crear tu propia imagen de Node-Docker como Alpine, etc., por favor? Bueno. Quiero decir, no lo sé, hay tantos buenos ahora mismo instalando todos los paquetes. No estoy seguro si agregaría más valor creando esto, pero no estoy seguro. Wow. ¿Cuánto dinero ganas en YouTube? No estás escuchando, ¿verdad? No. Permíteme contar una historia. YouTube es horrible. Así que tienes gente para
Producción de Contenido y Runtimes
Al final, estoy pagando por hacer estas cosas porque produzco mucho contenido. No tenía idea de que console.log no es Javascript. Señor da so es una jerga en portugués para referirse a un nivel alto. El mejor runtime para microservicios depende de la experiencia del desarrollador y la preferencia del equipo. El prefijo WTF en el código GSA probablemente sea una plantilla utilizada en C++ para enlazar bibliotecas y referirse a funciones en tiempo de ejecución.
De acuerdo, esta es una charla increíble. En tu opinión, ¿cuál es uno de los mejores runtimes para microservicios en este momento? Oh, quieres ponerme en aprietos, ¿verdad? Oh, dios mío, es difícil de decir, ¿verdad? Diría que no, no lo sé, es difícil porque he visto cómo BAN está evolucionando mucho y cómo Node.js es tan maduro, cómo Dino, ha sido bueno. Diría que lo mejor es lo que mejora tu experiencia porque en términos de rendimiento, hemos visto algunas pruebas de referencia que muestran, oh, esto es más rápido, pero el 90% de las aplicaciones son aplicaciones CRUD, ¿verdad? Así que es difícil sentir toda esta mejora y en mi opinión, lo mejor es la mejor experiencia de desarrollo y lo que más le gusta a tu equipo. Diría que es más una opinión personal que para los runtimes. Pero esa es mi opinión, ¿verdad? Tengo más experiencia con Node que con otros runtimes también. La gente puede pensar de manera diferente, ¿verdad? Definitivamente. Tenemos una pregunta más. ¿Qué significa el prefijo WTF en el código GSA que vimos? Por ejemplo, incluye WTF/slash/model.h. Bueno, diría que WTF es un texto muy específico, ¿verdad? Voy a pensar que es una plantilla. Entonces, en C++, usamos include para enlazar las bibliotecas y decir, oh, voy a llamar a esta función, por ejemplo, la compilación de V8. Cuando uso V8 compile, tengo que incluir los encabezados. Entonces, cuando está en tiempo de ejecución, se va a referir al binario, ¿verdad? Si miras todo el pod de puerta que construí, V8 tiene dos gigabytes. Así que esto es algo de lo que estaba hablando con Anna, cómo dos gigabytes se convierten en 200 gigabytes al final de Node.js. Esto es realmente interesante. Estaba como, oh dios mío,
Choosing Node.js and Inspiration
Elegí Node.js porque me sentía limitado como desarrollador de .NET y quería liberarme de estar atado a herramientas específicas. Con Node.js, pude aprender el funcionamiento interno y tener la capacidad de solucionar o comprender cualquier problema que surja. ¡Gracias por la charla informativa y atractiva!
Comments