Deno es un runtime para JavaScript y TypeScript basado en el motor V8 y escrito en Rust. Fue creado por Ryan Dahl, creador original de Node.js, y se enfoca en seguridad y productividad.[4] Fue anunciado por Dahl en el 2018 durante su charla “10 cosas de las que me arrepiento de Node.js”.[5] Deno toma la función de ambos runtime y gestor de paquetes dentro de un solo ejecutable, en vez de requerir un programa de gestión de paquetes separado.[6][7]
Deno | ||
---|---|---|
![]() | ||
Información general | ||
Tipo de programa | software libre | |
Autor | Ryan Dahl | |
Desarrollador | Varios | |
Lanzamiento inicial | 13 de mayo de 2018 | |
Licencia | MIT license[1][2] | |
Información técnica | ||
Programado en | ||
Versiones | ||
Última versión estable | 2.2.521 de marzo de 2025 | |
Enlaces | ||
Sitio web oficial
Blog
Repositorio de código
| ||
Deno fue anunciado en JSConf UE 2018 por Ryan Dahl en su charla "10 cosas de las que me arrepiento de Node.js".[5] En su charla, Ryan mencionó sus remordimientos sobre las decisiones de diseño iniciales con Node.js, enfocándose en sus decisiones de no utilizar promesas en el diseño de API, usando del sistema de construcción anticuado GYP, node_modules y package.json.
Finalmente presentó el prototipo de Deno, buscando hacer las llamadas a sistema a través del paso de mensajes con herramientas de serialización tales como Protocol Buffers, y proporcionar banderas de línea de comando para control de acceso.
Deno fue inicialmente escrito en Go, utilizando Protocol Buffers para serialización entre los lados privilegiado (Go, con acceso de llamada del sistema) y no-privilegiado (V8).[8] Aun así, Go fue pronto reemplazado con Rust debido a preocupaciones por double runtime y la recolección de basura.[9] Usa Tokio en vez de libuv como la plataforma conducida por eventos (event drive) asíncrona, y se adopta FlatBuffers para una serialización y deserialización "Zero Copy" más rápida. Más tarde, en agosto de 2019, FlatBuffers era finalmente sacado después de haberse publicado benchmarks en abril de 2019 que medían una sobrecarga significativa de la serialización.[10][11][12][13]
Una librería estándar, modelada al estilo de la librería estándar de Go, fue creada en noviembre de 2018 para proporcionar una extensa cantidad de utilidades y herramientas, parcialmente solucionando el problema de Node.js de la explosión del árbol de dependencias.[14]
Deno 1.0 oficial fue liberado el 13 de mayo de 2020.[15]
Deno busca ser un entorno de scripting productivo y seguro para el programador moderno.[6] Similar a Node.js, Deno enfatiza en arquitectura manejada por eventos, proveyendo un conjunto de utilidades de entrada/salida asíncronas(no bloqueantes), además de sus versiones síncronas(bloquenates). Deno puede ser usado para crear servidores web, llevar a cabo computación científica, etc.
Tanto Deno como Node.js son runtimes basados en el motor V8 de Google, el mismo motor utilizado en Google Chrome. Ambos tienen event loops, proporcionan interfaces de líneas de comando para ejecutar scripts, además de una amplia gama de utilidades de sistema.
Deno principalmente se diferencia de Node.js en los siguientes aspectos:[6]
La siguiente ejecuta un script básico de Deno sin ningún permiso de lectura/escritura/red (modo sandbox):
deno run main.ts
Banderas explícitas son requeridas para activar permisos:
deno run --allow-read --allow-net main.ts
Para inspeccionar el árbol de dependencia del script, use el subcomando info
:
deno info main.ts
Un programa Hola-mundo básico en Deno se parece es algo así a (como en Node.js):
console.log("Hello world");
Deno proporciona un espacio de nombre global para la mayoría de las APIs de Deno que no están disponibles en el navegador. Un programa Cat de Unix podría ser implementado como sigue:
/* cat.ts */
/* Las APIs de Deno están expuestas a través del namespace `Deno`. */
const { readFile, args } = Deno;
// await de alto nivel es soportado
for (const file of args) { // Itera por cada elemento de los argumentos
const bytes = await readFile(file); // Abre el archivo correspondiente para lectura (en un Uint8Array)
const plainText = new TextDecoder().decode(bytes) // Usa la API TextDecoder del navegador para decodificar los bytes
console.log(plainText) // Muestra en la consola el texto decodificado
}
La función Deno.copy
de arriba trabaja de manera similar como io.Copy
de Go, donde stdout
(Salida estándar) es el destino Writer
y file es la fuente Reader
. Para correr este programa, necesitamos proporcionar el permiso de lectura del sistema de archivos:
deno run --allow-read cat.ts myfile
El siguiente script de Deno implementa un servidor de HTTP básico:
// Importa `serve` desde la librería estandar remota de Deno, usando URL.
import { serve } from "https://deno.land/std@v0.195.0/http/server.ts";
// La función `serve` retorna un iterador asíncrono, invocando un flujo de llamadas
for await (const req of serve({ port: 8000 })) {
req.respond({ body: "Hello World\n" });
}
Cuando se ejecuta este programa, Deno automáticamente descarga y cachea las librerías remotas y compila el código. De forma similar, podemos correr un script de librería estándar (como un servidor de archivo) directamente sin explícitamente descargarlo, proporcionando la URL como archivo de entrada ( -A
activa todos los permisos):
$ deno run -A https://deno.land/std/http/file_server.ts
Download https://deno.land/std/http/file_server.ts
Compile https://deno.land/std/http/file_server.ts
...
HTTP server listening on http://0.0.0.0:4500/