3. INDICE DEL CORSO
CORE
• Introduzione su node
• Installazione
• Struttura base di un progetto
• npm
• Hands on: Esempi di funzionalita’ di base
• Hands on: Esempi di piccole applicazioni
Wednesday, May 22, 13
4. INDICE DEL CORSO
EXPRESS
• Installazione
• Generazione di un progetto
• Routes
• Views
• Middle wares
• Sessions and Error Handling
Wednesday, May 22, 13
6. INDEX
• Cos’e’ Node.js
• Come e perche’ nasce
• Async e NextTick
• Esempi di architettura in cui usarlo
Wednesday, May 22, 13
7. Node.js is a platform built on Chrome's JavaScript runtime for easily building fast, scalable network
applications. Node.js uses an event-driven, non-blocking I/O model that makes it lightweight and
efficient, perfect for data-intensive real-time applications that run across distributed devices.
CurrentVersion: v0.8.21
Wednesday, May 22, 13
9. RYAN DAHL
Studente in Matematica
Si trasferisce in Sud America
Incontra un programmatore php
Inizia a sviluppare siti ed “applicazioni” web
Incontra ROR
Si accorge che il Web e’ lento!
Wednesday, May 22, 13
10. Il Web e’ lento!
Per via di Java ;)
Wednesday, May 22, 13
11. Il Web e’ lento!
Per via di Java ;)
Alcuni cominciano a lavorare per velocizzare ROR
Wednesday, May 22, 13
12. Il Web e’ lento!
Per via di Java ;)
Alcuni cominciano a lavorare per velocizzare ROR
Ma il problema risiede nell’intero stack
Wednesday, May 22, 13
13. Il Web e’ lento!
Per via di Java ;)
Alcuni cominciano a lavorare per velocizzare ROR
Ma il problema risiede nell’intero stack
Il lavoro di Zed Shaw da vita a Mongel
Wednesday, May 22, 13
15. Mongrel
Per via di Java ;)
E’ sia una libreria http, sia un webserver!
Wednesday, May 22, 13
16. Mongrel
Per via di Java ;)
E’ sia una libreria http, sia un webserver!
Il web server non e’ piu’ solo “una directory “
Wednesday, May 22, 13
17. Mongrel
Per via di Java ;)
E’ sia una libreria http, sia un webserver!
Il web server non e’ piu’ solo “una directory “
Puo’ racchiudere direttamente la logica
Wednesday, May 22, 13
19. Il Web Server
Per via di Java ;)
Distillato, e’ fatto per gestire richieste e risposte
Wednesday, May 22, 13
20. Il Web Server
Per via di Java ;)
Distillato, e’ fatto per gestire richieste e risposte
Servire files e’ una parte ma non e’ obbligatoria
Wednesday, May 22, 13
22. THE FILE UPLOAD PROBLEM
Caricare files via http non era poi cosi’ comune
Wednesday, May 22, 13
23. THE FILE UPLOAD PROBLEM
Caricare files via http non era poi cosi’ comune
Con la nascita di Ajax si cominciavano a caricareVIDEO!
Wednesday, May 22, 13
24. THE FILE UPLOAD PROBLEM
Caricare files via http non era poi cosi’ comune
Con la nascita di Ajax si cominciavano a caricareVIDEO!
Ed ecco un nuovo problema da affrontare:
Wednesday, May 22, 13
26. LA PROGRESS BAR
Il DOM non dava alcuna informazione sul file
Wednesday, May 22, 13
27. LA PROGRESS BAR
Il DOM non dava alcuna informazione sul file
Il trucco era controllare lo stato del file lato server in batch.
Wednesday, May 22, 13
28. LA PROGRESS BAR
Il DOM non dava alcuna informazione sul file
Il trucco era controllare lo stato del file lato server in batch.
Ma l’http 1.1 ci da connessioni che possono restare aperte!
Wednesday, May 22, 13
29. LA PROGRESS BAR
Il DOM non dava alcuna informazione sul file
Il trucco era controllare lo stato del file lato server in batch.
Ma l’http 1.1 ci da connessioni che possono restare aperte!
Nasce un interessante plugin per Mongrel
Wednesday, May 22, 13
31. IL LONG POLLING
Non piu’ continue richieste Ajax temporizzate
Wednesday, May 22, 13
32. IL LONG POLLING
Non piu’ continue richieste Ajax temporizzate
Il Web Server non risponde e chiude subito la connessione
Wednesday, May 22, 13
33. IL LONG POLLING
Non piu’ continue richieste Ajax temporizzate
Il Web Server non risponde e chiude subito la connessione
La connessione resta aperta finche’ la si puo’ usare
Wednesday, May 22, 13
34. IL LONG POLLING
Non piu’ continue richieste Ajax temporizzate
Il Web Server non risponde e chiude subito la connessione
La connessione resta aperta finche’ la si puo’ usare
Il Server continua a spedire lo stato del file fino al termine
Wednesday, May 22, 13
35. IL WEB SERVER E’APPENA
DIVENTATO MOLTO PIU’
INTELLIGENTE! :)
Wednesday, May 22, 13
38. IL WEB E’ANCORA LENTO!
Ruby, Python, ecc sono troppo lenti by design
Wednesday, May 22, 13
39. IL WEB E’ANCORA LENTO!
Ruby, Python, ecc sono troppo lenti by design
Gli interpreti sono singoli thread bloccanti
Wednesday, May 22, 13
40. IL WEB E’ANCORA LENTO!
Ruby, Python, ecc sono troppo lenti by design
Gli interpreti sono singoli thread bloccanti
Il C e’ veloce ma uno sconosciuto per troppi webdev
Wednesday, May 22, 13
50. LA RISPOSTA:
Tutto in un solo thread
Migliora?
SI! Si possono evitare tutti i problemi derivanti dai lock!
Wednesday, May 22, 13
51. LA RISPOSTA:
Tutto in un solo thread
Migliora?
SI! Si possono evitare tutti i problemi derivanti dai lock!
C’e’ un linguaggio che tutto cio’ lo fa di natura:
Wednesday, May 22, 13
54. JAVASCRIPT
Negli ultimi anni ha preso sempre piu’ piede
Tutti i maggiori browser stavano gia’ “combattendo su js”
Wednesday, May 22, 13
55. JAVASCRIPT
Negli ultimi anni ha preso sempre piu’ piede
Tutti i maggiori browser stavano gia’ “combattendo su js”
Nel 2008 era stato rilasciatoV8
Wednesday, May 22, 13
56. JAVASCRIPT
Negli ultimi anni ha preso sempre piu’ piede
Tutti i maggiori browser stavano gia’ “combattendo su js”
Nel 2008 era stato rilasciatoV8
Ha le caratteristiche adatte:
Wednesday, May 22, 13
57. JAVASCRIPT
Negli ultimi anni ha preso sempre piu’ piede
Tutti i maggiori browser stavano gia’ “combattendo su js”
Nel 2008 era stato rilasciatoV8
Ha le caratteristiche adatte:
Closures
Wednesday, May 22, 13
58. JAVASCRIPT
Negli ultimi anni ha preso sempre piu’ piede
Tutti i maggiori browser stavano gia’ “combattendo su js”
Nel 2008 era stato rilasciatoV8
Ha le caratteristiche adatte:
Closures
Funzioni anonime
Wednesday, May 22, 13
59. JAVASCRIPT
Negli ultimi anni ha preso sempre piu’ piede
Tutti i maggiori browser stavano gia’ “combattendo su js”
Nel 2008 era stato rilasciatoV8
Ha le caratteristiche adatte:
Closures
Funzioni anonime
Non e’ usato al di fuori dei browser
Wednesday, May 22, 13
60. JAVASCRIPT
Negli ultimi anni ha preso sempre piu’ piede
Tutti i maggiori browser stavano gia’ “combattendo su js”
Nel 2008 era stato rilasciatoV8
Ha le caratteristiche adatte:
Closures
Funzioni anonime
Non e’ usato al di fuori dei browser
Quindi non ha preconcetti su come fare le cose.
Wednesday, May 22, 13
63. NASCE NODE.JS
Viene presentato alla javascript conf di Berlino
La prima app di demo: un IRC Server, 400 linee di codice!
Wednesday, May 22, 13
64. NASCE NODE.JS
Viene presentato alla javascript conf di Berlino
La prima app di demo: un IRC Server, 400 linee di codice!
Ed e’ fatto per costruire network servers!
Wednesday, May 22, 13
65. NASCE NODE.JS
Viene presentato alla javascript conf di Berlino
La prima app di demo: un IRC Server, 400 linee di codice!
Ed e’ fatto per costruire network servers!
Il suo nome indica che e’ fatto per essere un nodo tra molti
Wednesday, May 22, 13
66. NASCE NODE.JS
Viene presentato alla javascript conf di Berlino
La prima app di demo: un IRC Server, 400 linee di codice!
Ed e’ fatto per costruire network servers!
Il suo nome indica che e’ fatto per essere un nodo tra molti
E’ adatto alla Cloud* per sua natura.
*Una volta si chiamava internet
Wednesday, May 22, 13
69. ASYNC E NEXTTICK
le applicazioni node girano in un singolo thread
Wednesday, May 22, 13
70. ASYNC E NEXTTICK
Le applicazioni node girano in un singolo thread
Questo comporta che ad ogni dato momento viene eseguito
solo un task nell’event loop
Wednesday, May 22, 13
71. ASYNC E NEXTTICK
Le applicazioni node girano in un singolo thread
Questo comporta che ad ogni dato momento viene eseguito
solo un task nell’event loop
Possiamo immaginare l’event loop come una coda di callback
Wednesday, May 22, 13
72. ASYNC E NEXTTICK
Le applicazioni node girano in un singolo thread
Questo comporta che ad ogni dato momento viene eseguito
solo un task nell’event loop
Possiamo immaginare l’event loop come una coda di callback
Ad ogni tick dell’event loop viene eseguida una delle callback
nella coda
Wednesday, May 22, 13
73. ASYNC E NEXTTICK
Le applicazioni node girano in un singolo thread
Questo comporta che ad ogni dato momento viene eseguito
solo un task nell’event loop
Possiamo immaginare l’event loop come una coda di callback
Ad ogni tick dell’event loop viene eseguida una delle callback
nella coda
Non c’e’ concorrenza ne’ multicore
Wednesday, May 22, 13
74. User NODE
NODE
Client Web Engine
Database
Logging facility
Mass storage
(big slow disk)
DB
Disk
ESEMPIO DI ARCHITETTURA
In questo modo i logs non rallentano piu’ i processi critici
Wednesday, May 22, 13
76. UN CASO COMPLESSO
Il backend di SaveThe Mom e’ tutto in node.js e ne sfrutta
pesantemente il modello asincrono con l’aiuto di bus e code
Wednesday, May 22, 13