JavaScript
côté serveur

Plusieurs technologies

  • NodeJS
  • Deno
  • Bun

Parse l'url et utilise le router

Récupère les informations de la base de données

Traite les infos 

Sauvegarde les modifications en base de données

Génère la page

Parse l'url et utilise le router

Traite les infos 

Génère la page

Client 1

Client 2

Client 3

Event loop & Async I/O 

crédit Jeff Kunkle

NodeJS

Du code !

Non bloquant

// Code bloquant 
const content = readFileSync('MonFichier.txt'); 
console.log('Mon fichier : ', content); 



// Code non bloquant
readFile('MonFichier.txt', (err, content) => {
    if (err) {
        throw err;
    }
    console.log('Mon fichier : ', content); 
});
console.log('Autres opérations')

Cas concret

import {createServer} from 'http'
import {readFile} from 'fs'

createServer((req, res) => {
  readFile('/var/www/demo/log.txt', 'utf8', (err, data) => {
    if (err) {
      res.writeHead(500, err.message)
      res.end()
    } else {
      res.writeHead(200, {
        'Content-Type': 'text/plain'
      });
      res.end(data)
    }
  })
}).listen(80)

Inconvénients

const fs = require('fs')
const file = '/var/www/site/demo.txt'
 
fs.stat(file, function (err, stats) {
  if (err) return
  if (stats.isFile()) {
    fs.readFile(file, function (err, data) {
      if (err) throw err
      console.log(data)
    })
  }
})
<?php
$file = '/var/www/site/demo.txt'
if (file_exists($file)) {
    echo file_get_contents($file); 
} 

Single Thread

Ne rien faire qui demande beaucoup de calculs

Bas niveau

Il faudra créer le serveur web au niveau de notre code

Avantages

Beaucoup d'I/O

Multi-plateforme

Un seul langage

"Un Anneau pour les gouverner tous"

Facile à apprendre

Vous connaissez déjà le JavaScript

Gestionnaire de paquet pour NodeJs

NodeJS

By Jonathan Boyer

NodeJS

  • 1,430