DEV Community

Cover image for Bun : Le Serveur HTTP en Action
Beπ ✨
Beπ ✨

Posted on • Updated on • Originally published at benoitpetit.dev

Bun : Le Serveur HTTP en Action

Substack Newsletter

Suite à l’article sur mon enthousiasme concernant bun.js, j'ai voulu en faire un autre au sujet du serveur HTTP intégré de Bun.js.

Il offre une solution intégrée, robuste et performante pour la gestion des requêtes HTTP. Dans cet article, embarquons pour un voyage à la découverte des fonctionnalités géniales de ce serveur HTTP, qui en font un choix de prédilection pour le déploiement d'applications web. 🌐

1. Gestion des Routes et des Middlewares 😎 :

Le serveur HTTP de Bun simplifie la gestion des routes en permettant une définition claire et concise des points d'entrée de votre application. Les middlewares peuvent être intégrés de manière transparente pour traiter les requêtes avant d'atteindre la logique de l'application, offrant ainsi une flexibilité maximale dans la conception de votre architecture.

import { App } from 'bun';

const app = new App();

// la on dit a bun d'utiliser un middleware
app.use((req, res, next) => {
  // Middleware log
  console.log(`Received request at ${req.path}`);
  next();
});

app.get('/hello', (req, res) => {
  // ici c'est la logique de l'application
  res.send('Hello, world!');
});

// ca c'est pour lancer le serveur
app.start(3000);

Enter fullscreen mode Exit fullscreen mode

Plus d'informations : https://bun.sh/docs/api/http#bun-serve

2. Prise en charge des WebSockets 🌐 :

Bun va au-delà de la simple gestion des requêtes HTTP en incluant une prise en charge native des WebSockets. Cette fonctionnalité permet des communications bidirectionnelles en temps réel entre le serveur et le client, ouvrant ainsi un univers d'opportunités pour le développement d'applications interactives.

import { Bun } from 'bun';

// Crée un serveur en utilisant la méthode statique 'serve' de la classe Bun
const server = Bun.serve<{ authToken: string }>({
    // Définit une fonction de rappel pour les requêtes HTTP
    fetch(req, server) {
        // Tente de mettre à niveau la requête en WebSocket
        const success = server.upgrade(req);
        if (success) {
            return undefined;
        }
        // traiter les requêtes HTTP normalement
        return new Response("Hello world!");
    },
    // Définit des fonctions de rappel pour les connexions WebSocket
    websocket: {
        // ca c'est appeller l'orsque un message est reçu
        async message(ws, message) {
            console.log(`Received ${message}`);
            // Renvoie un message au client
            ws.send(`You said: ${message}`);
        },
    },
});

console.log(`Listening on ${server.hostname}:${server.port}`);
Enter fullscreen mode Exit fullscreen mode

Plus d'informations ici : https://bun.sh/docs/api/websockets

3. Streaming de Fichiers ⚡️ :

BunFile est un objet de flux qui peut être utilisé pour envoyer des fichiers en streaming. Il est optimisé pour les performances, car il utilise l'appel système sendfile(2) lorsque cela est possible, permettant des transferts de fichiers sans copie dans le noyau, le moyen le plus rapide d'envoyer des fichiers.

Bun.serve({
  // Définit une fonction de rappel pour les requêtes HTTP
  fetch(req) {
    // Renvoie un fichier en streaming avec une promesse
    return new Response(Bun.file("./hello.txt"));
  },
});
Enter fullscreen mode Exit fullscreen mode

Plus d'information ici : https://bun.sh/docs/api/http#streaming-files

4. Sécurité et Performance 🔐💨 :

Bun assure la sécurité et la performance de votre application web en utilisant les dernières technologies disponibles. Le serveur HTTP de Bun supporte le protocole HTTPS, le chiffrement TLS, la compression gzip, le cache HTTP et bien plus encore. Bun optimise également l'utilisation des ressources du système en utilisant un modèle asynchrone basé sur les coroutines, permettant de gérer un grand nombre de requêtes simultanées sans compromettre la réactivité.

Plus d'information : https://bun.sh/docs/api/http#tls

Je ne pourrais pas tout vous montrer dans cet article, mais vous pouvez retrouver la documentation complète ici 😉 : https://bun.sh/docs/api/http

En gros :

Le serveur HTTP de Bun offre un ensemble complet de fonctionnalités pour le développement d'applications web, de la gestion des routes à la prise en charge native des WebSockets. Sa simplicité d'utilisation, couplée à sa puissance, en fait un choix idéal pour les développeurs cherchant à créer des applications web performantes et évolutives. Explorez la documentation de Bun pour découvrir encore plus de fonctionnalités et accélérer le processus de développement de vos projets web. 🚀

❤️ Mon coup de cœur va à Bun.js, un outil tout-en-un que je recommande vivement à tous les développeurs web.

À bientôt pour un autre article. Ben


🫶 Si vous aimez mes publications et souhaitez soutenir mon travail, vous pouvez faire un don en cliquant sur le lien Stripe Sponsor ci-dessous ou en scannant le code QR. lien Stripe Sponsor


Stripe Sponsor


👀 See me here :

Top comments (2)

Collapse
 
artydev profile image
artydev

Merci Ben :-)

Collapse
 
benoitpetit profile image
Beπ ✨

Avec plaisir ! Content que l'article t'a plu 😀