SlideShare a Scribd company logo
Intro to Node.js
        Chris Cowan
            Lead Engineer
    http://www.plus3network.com
Node’s Goal is to provide an
 easy way to build scalable
    network programs.
Node.js is NOT another
  web framework!

  But you can create a web framework using NPM modules.
Node.js is…
             Web Server
              TCP Server
     Awesome Robot Controller
     Command Line Application
            Proxy Server
          Streaming Server
          VoiceMail Server
           Music Machine
Anything that has to deal with high I/O
Node.js is
Server Side JavaScript!
Node.js is

FUN!
Why Node.js?
• Non Blocking I/O
• Based on Chrome’s V8 Engines (FAST!)
• 15,000+ Modules
• Active Community (IRC, Mailing
  Lists, Twitter, Github)
• Mac, Linux and Windows (all first class citizens)
• One Language for Frontend and Backend
• JavaScript is the Language of the Web
Installing Node.js
Mac OS X
1. Go to http://nodejs.org and click install
2. Install the downloaded package

Windows
1. Go to http://nodejs.org and click install
2. Install the downloaded package

Linux (and *nix variants)
1. Go to http://nodejs.org and click install
2. Decompress source and… ./configure … make … make install
   ( for Ubuntu use Chris Lea’s PPA – ppa:chris-lea/node.js )
Some Basic
 Examples
Hello World
Create hello-world.js
console.log(‘Hello World’);

On the command line run
node hello-world.js

You should see
Hello World
Basic HTTP Server
var http = require('http');

var server = http.createServer(function (req, res) {
  res.writeHead(200);
  res.end('Hello World');
});

server.listen(4000);



                   *Running this script my development box,
                   I can achieve 10,000+ requests per second
                        with 100 concurrent connections
                            without breaking a sweat
Some people use the
 core http module to
build their web apps,
most use a framework
     like Express
 or Connect or Flatiron or Tako or Derby or Geddy or Mojito or …
Visit
http://expressjs.com/guide.html
       for a detailed guide
         on using Express
What is Non-Blocking I/O?
    And why should I care?
Blocking I/
// Get User – 20ms
$query = 'SELECT * FROM users WHERE id = ?';
$users = query($query, array($id));
print_r($users);

// Get Activities – 100ms
$query = 'SELECT * FROM activities ORDER BY timestamp LIMIT 50';
$activities = query($query);
print_r($activities);

// Get Leader Board – 150ms
$query = 'SELECT count(points) as total, user_id FROM activities LIMIT 50';
$leader_board = query($query);




          270ms = SUM(user, activities, leaderboard)
Non-Blocking I/
// Get User – 20ms
var query = 'SELECT * FROM users WHERE id = ?';
db.query(query, [userId], function (err, results) {
  console.log(results);
});

// Get Activities – 100ms
var query = 'SELECT * FROM activities ORDER BY timestamp LIMIT 50';
db.query(query, function (err, results) {
  console.log(results);
});

// Get Leader Board – 150ms
var query = 'SELECT count(points) as total, user_id FROM activities LIMIT 50';
db.query(query, function (err, results) {
  console.log(results);
});




           150ms = MAX(user, activities, leaderboard)
The most jarring thing
about Server Side JavaScript
  is thinking in callbacks
The Node Callback Pattern
awesomeFunction(arg, function (err, data) {
   if (err) {
      // Handle Error
   }
   // Do something awesome with results.
});

• Error first then success… ALWAYS!
• Because this is the de-facto standard 99.99999% of the time
  you will be able to guess how a Node library will work.
Callbacks are the Devil’s Work!
                          Don’t go down this rabbit hole…
var userQuery = 'SELECT * FROM users WHERE id = ?';
var activityQuery = 'SELECT * FROM activities ORDER BY timestamp LIMIT 50';
var leaderBoardQuery = 'SELECT count(points) as total, user_id FROM activities LIMIT 50';

db.query(userQuery, [id], function (userErr, userResults) {
 db.query(activityQuery, function (activityErr, activityResults) {
    db.query(leaderBoardQuery, function (leaderBoardErr, leaderBoardResults) {

        // Do something here

      });
   });
});


   One of the biggest mistakes is to get yourself in
    to callback hell by nesting callbacks inside of
          callbacks inside of more callbacks.
Avoiding Callback Hell
• Keep your code shallow
• Break up your code into small chunks
• Use a sequential library like async
• Visit http://callbackhell.com
Async to the rescue!
var async = require('async');
var db = require(’db');

function getUser (callback) {
  var query = 'SELECT * FROM users WHERE id = ?';
  db.query(query, [userId], callback);
}

function getActivities (callback) {
  var query = 'SELECT * FROM activities ORDER BY timestamp LIMIT 50';
  db.query(query, callback);
}

function getLeaderBoard (callback) {
  var query = 'SELECT count(points) as total, user_id FROM activities LIMIT 50';
  db.query(query, callback);
}

var tasks = [getUser, getActivities, getLeaderBoard];
async.parallel(tasks, function (err, results) {
  var user       = results[0][0];
  var activities = results[1];
  var leaderBoard = results[2];
});
Async provides several useful
 patterns for asynchronous control
            flow including:
 parallel, series, waterfall, auto and
                queue.
                      Visit
        https://github.com/caolan/async
for a detailed guide on using the async module.
The Node Package Manager
 otherwise know as… NPM

 It’s how you harness the
    awesomeness of the
    Node.js community!
Using NPM
It’s standard practice to install modules locally for your current project.
Modules are installed in the ./node_modules in the current directory.

To Install a new module

npm install <module>

To find a module in the NPM repository

npm search <search string>

To list the modules (and their dependencies) in the current project

npm list

To see module details

npm info <module>
DON’T INSTALL
MODULES GLOBALLY!
 Unless they are tools like node-dev, jake, express, minify-js
  OR linked development modules but more on that later.
NPM is awesome sauce!

               Visit
        https://npmjs.org
for more details about NPM and to
browse the current NPM Repository
Creating your own modules
• Node.js uses CommonJS Modules
• require(‘./example’) will load either
  example.js or example/index.js or the entry
  point specified in package.json
• Run npm init to bootstrap your new module
• Try to stick to creating Pure JavaScript
  modules if possible. It will give you less
  headaches down the road.
Basic Module Example
Everything exposed via module.exports is available as an instance variable.

var currentCount = 0;

module.exports.incr = function () {
  return ++currentCount;
};

Once you’ve created a module in counter.js you use it like this…
var counter = require(’./counter');
var count = counter.incr();

Keep this in mind… modules are loaded once and cached. So when
you load the module a second time in your app, require just
returns the cache copied. This lets you do interesting things…
Installing your module
• Run npm link in the module working directory
• Then run npm link <module> in the your project
  folder to link it from the global module to your
  local node_modules.

• OR you can create a private registry
  (See https://npmjs.org/doc/registry.html)

• OR just link it by hand :P
My Favorite Modules
• request      • jake
• async        • hogan.js
• node-dev     • connect
• underscore   • moment
• express      • mysql
Questions?
Contact me at chris@chriscowan.us

More Related Content

PPTX
Node.js debugging
PPTX
Introduction Node.js
PPTX
introduction to node.js
KEY
Introduction to node.js
PDF
Introduction to Node.js: What, why and how?
PPTX
Node.js Patterns for Discerning Developers
PDF
NodeJS for Beginner
PPTX
Introduction to Node.js
Node.js debugging
Introduction Node.js
introduction to node.js
Introduction to node.js
Introduction to Node.js: What, why and how?
Node.js Patterns for Discerning Developers
NodeJS for Beginner
Introduction to Node.js

What's hot (20)

PPTX
Introduction to Node js
PDF
All aboard the NodeJS Express
PPTX
Nodejs intro
PDF
Node.js and How JavaScript is Changing Server Programming
KEY
Writing robust Node.js applications
PPTX
Java script at backend nodejs
KEY
OSCON 2011 - Node.js Tutorial
PDF
PPTX
Node js introduction
PDF
Node Architecture and Getting Started with Express
PPT
Node js presentation
PDF
Use Node.js to create a REST API
PPT
RESTful API In Node Js using Express
PPTX
NodeJS - Server Side JS
PDF
Nodejs in Production
KEY
node.js: Javascript's in your backend
PDF
Building servers with Node.js
PDF
Non-blocking I/O, Event loops and node.js
PDF
Original slides from Ryan Dahl's NodeJs intro talk
PDF
Node.js Explained
Introduction to Node js
All aboard the NodeJS Express
Nodejs intro
Node.js and How JavaScript is Changing Server Programming
Writing robust Node.js applications
Java script at backend nodejs
OSCON 2011 - Node.js Tutorial
Node js introduction
Node Architecture and Getting Started with Express
Node js presentation
Use Node.js to create a REST API
RESTful API In Node Js using Express
NodeJS - Server Side JS
Nodejs in Production
node.js: Javascript's in your backend
Building servers with Node.js
Non-blocking I/O, Event loops and node.js
Original slides from Ryan Dahl's NodeJs intro talk
Node.js Explained
Ad

Viewers also liked (20)

PPSX
Node.js In The Enterprise - A Primer
PDF
Node.js in action
PDF
#7 "Многообещающий JavaScript – Promises" Денис Речкунов
PPTX
Why Node, Express and Postgres - presented 23 Feb 15, Talkjs, Microsoft Audit...
PDF
Migrating a Monolithic App to Microservices on Cloud Foundry
PPTX
Microservices and modern backends - Azure Meetup Frankfurt
PPTX
A High-Performance Solution To Microservices UI Composition
PPTX
Building a Web Frontend with Microservices and NGINX Plus
PDF
Node.js & Twitter Bootstrap Crash Course
PDF
Building microservices web application using scala & akka
PDF
Burgas Conf 21.06.2014 - Single page application Angularjs and Nodejs
PDF
Introduction to Node.js: perspectives from a Drupal dev
PDF
Webconf nodejs-production-architecture
PDF
Introduction to node js - From "hello world" to deploying on azure
PDF
Building Scalable Web Applications Using Microservices Architecture and NodeJ...
PPTX
An Unexpected Solution to Microservices UI Composition
PDF
Complete MVC on NodeJS
PPT
Nodejs Event Driven Concurrency for Web Applications
PPTX
Create Rest API in Nodejs
PDF
Workshop 4: NodeJS. Express Framework & MongoDB.
Node.js In The Enterprise - A Primer
Node.js in action
#7 "Многообещающий JavaScript – Promises" Денис Речкунов
Why Node, Express and Postgres - presented 23 Feb 15, Talkjs, Microsoft Audit...
Migrating a Monolithic App to Microservices on Cloud Foundry
Microservices and modern backends - Azure Meetup Frankfurt
A High-Performance Solution To Microservices UI Composition
Building a Web Frontend with Microservices and NGINX Plus
Node.js & Twitter Bootstrap Crash Course
Building microservices web application using scala & akka
Burgas Conf 21.06.2014 - Single page application Angularjs and Nodejs
Introduction to Node.js: perspectives from a Drupal dev
Webconf nodejs-production-architecture
Introduction to node js - From "hello world" to deploying on azure
Building Scalable Web Applications Using Microservices Architecture and NodeJ...
An Unexpected Solution to Microservices UI Composition
Complete MVC on NodeJS
Nodejs Event Driven Concurrency for Web Applications
Create Rest API in Nodejs
Workshop 4: NodeJS. Express Framework & MongoDB.
Ad

Similar to Intro To Node.js (20)

PPTX
Intro to node and mongodb 1
PPTX
Intro to Node.js (v1)
PDF
An introduction to Node.js
ODP
Introduce about Nodejs - duyetdev.com
PPTX
PPTX
Node js Introduction
PPTX
Kalp Corporate Node JS Perfect Guide
KEY
Playing With Fire - An Introduction to Node.js
DOCX
unit 2 of Full stack web development subject
PPTX
Building Applications With the MEAN Stack
PDF
Node.js Course 1 of 2 - Introduction and first steps
PPTX
Introduction to node.js GDD
PPTX
Server Side Web Development Unit 1 of Nodejs.pptx
PPTX
An overview of node.js
PPTX
NodeJS guide for beginners
PDF
Download full ebook of Learning Node Shelley Powers instant download pdf
PPT
Node js
PDF
Node.js - async for the rest of us.
KEY
Practical Use of MongoDB for Node.js
PPTX
NodeJS
Intro to node and mongodb 1
Intro to Node.js (v1)
An introduction to Node.js
Introduce about Nodejs - duyetdev.com
Node js Introduction
Kalp Corporate Node JS Perfect Guide
Playing With Fire - An Introduction to Node.js
unit 2 of Full stack web development subject
Building Applications With the MEAN Stack
Node.js Course 1 of 2 - Introduction and first steps
Introduction to node.js GDD
Server Side Web Development Unit 1 of Nodejs.pptx
An overview of node.js
NodeJS guide for beginners
Download full ebook of Learning Node Shelley Powers instant download pdf
Node js
Node.js - async for the rest of us.
Practical Use of MongoDB for Node.js
NodeJS

Recently uploaded (20)

PPTX
Machine Learning_overview_presentation.pptx
PDF
gpt5_lecture_notes_comprehensive_20250812015547.pdf
PDF
NewMind AI Weekly Chronicles - August'25-Week II
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
Encapsulation theory and applications.pdf
PPTX
TechTalks-8-2019-Service-Management-ITIL-Refresh-ITIL-4-Framework-Supports-Ou...
PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
PPTX
TLE Review Electricity (Electricity).pptx
PDF
Accuracy of neural networks in brain wave diagnosis of schizophrenia
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
PDF
A comparative study of natural language inference in Swahili using monolingua...
PDF
Empathic Computing: Creating Shared Understanding
PDF
Getting Started with Data Integration: FME Form 101
PDF
Profit Center Accounting in SAP S/4HANA, S4F28 Col11
PDF
MIND Revenue Release Quarter 2 2025 Press Release
PPTX
Group 1 Presentation -Planning and Decision Making .pptx
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PPTX
Programs and apps: productivity, graphics, security and other tools
PPT
Teaching material agriculture food technology
PPTX
Digital-Transformation-Roadmap-for-Companies.pptx
Machine Learning_overview_presentation.pptx
gpt5_lecture_notes_comprehensive_20250812015547.pdf
NewMind AI Weekly Chronicles - August'25-Week II
Advanced methodologies resolving dimensionality complications for autism neur...
Encapsulation theory and applications.pdf
TechTalks-8-2019-Service-Management-ITIL-Refresh-ITIL-4-Framework-Supports-Ou...
Reach Out and Touch Someone: Haptics and Empathic Computing
TLE Review Electricity (Electricity).pptx
Accuracy of neural networks in brain wave diagnosis of schizophrenia
Mobile App Security Testing_ A Comprehensive Guide.pdf
A comparative study of natural language inference in Swahili using monolingua...
Empathic Computing: Creating Shared Understanding
Getting Started with Data Integration: FME Form 101
Profit Center Accounting in SAP S/4HANA, S4F28 Col11
MIND Revenue Release Quarter 2 2025 Press Release
Group 1 Presentation -Planning and Decision Making .pptx
Agricultural_Statistics_at_a_Glance_2022_0.pdf
Programs and apps: productivity, graphics, security and other tools
Teaching material agriculture food technology
Digital-Transformation-Roadmap-for-Companies.pptx

Intro To Node.js

  • 1. Intro to Node.js Chris Cowan Lead Engineer http://www.plus3network.com
  • 2. Node’s Goal is to provide an easy way to build scalable network programs.
  • 3. Node.js is NOT another web framework! But you can create a web framework using NPM modules.
  • 4. Node.js is… Web Server TCP Server Awesome Robot Controller Command Line Application Proxy Server Streaming Server VoiceMail Server Music Machine Anything that has to deal with high I/O
  • 7. Why Node.js? • Non Blocking I/O • Based on Chrome’s V8 Engines (FAST!) • 15,000+ Modules • Active Community (IRC, Mailing Lists, Twitter, Github) • Mac, Linux and Windows (all first class citizens) • One Language for Frontend and Backend • JavaScript is the Language of the Web
  • 8. Installing Node.js Mac OS X 1. Go to http://nodejs.org and click install 2. Install the downloaded package Windows 1. Go to http://nodejs.org and click install 2. Install the downloaded package Linux (and *nix variants) 1. Go to http://nodejs.org and click install 2. Decompress source and… ./configure … make … make install ( for Ubuntu use Chris Lea’s PPA – ppa:chris-lea/node.js )
  • 10. Hello World Create hello-world.js console.log(‘Hello World’); On the command line run node hello-world.js You should see Hello World
  • 11. Basic HTTP Server var http = require('http'); var server = http.createServer(function (req, res) { res.writeHead(200); res.end('Hello World'); }); server.listen(4000); *Running this script my development box, I can achieve 10,000+ requests per second with 100 concurrent connections without breaking a sweat
  • 12. Some people use the core http module to build their web apps, most use a framework like Express or Connect or Flatiron or Tako or Derby or Geddy or Mojito or …
  • 13. Visit http://expressjs.com/guide.html for a detailed guide on using Express
  • 14. What is Non-Blocking I/O? And why should I care?
  • 15. Blocking I/ // Get User – 20ms $query = 'SELECT * FROM users WHERE id = ?'; $users = query($query, array($id)); print_r($users); // Get Activities – 100ms $query = 'SELECT * FROM activities ORDER BY timestamp LIMIT 50'; $activities = query($query); print_r($activities); // Get Leader Board – 150ms $query = 'SELECT count(points) as total, user_id FROM activities LIMIT 50'; $leader_board = query($query); 270ms = SUM(user, activities, leaderboard)
  • 16. Non-Blocking I/ // Get User – 20ms var query = 'SELECT * FROM users WHERE id = ?'; db.query(query, [userId], function (err, results) { console.log(results); }); // Get Activities – 100ms var query = 'SELECT * FROM activities ORDER BY timestamp LIMIT 50'; db.query(query, function (err, results) { console.log(results); }); // Get Leader Board – 150ms var query = 'SELECT count(points) as total, user_id FROM activities LIMIT 50'; db.query(query, function (err, results) { console.log(results); }); 150ms = MAX(user, activities, leaderboard)
  • 17. The most jarring thing about Server Side JavaScript is thinking in callbacks
  • 18. The Node Callback Pattern awesomeFunction(arg, function (err, data) { if (err) { // Handle Error } // Do something awesome with results. }); • Error first then success… ALWAYS! • Because this is the de-facto standard 99.99999% of the time you will be able to guess how a Node library will work.
  • 19. Callbacks are the Devil’s Work! Don’t go down this rabbit hole… var userQuery = 'SELECT * FROM users WHERE id = ?'; var activityQuery = 'SELECT * FROM activities ORDER BY timestamp LIMIT 50'; var leaderBoardQuery = 'SELECT count(points) as total, user_id FROM activities LIMIT 50'; db.query(userQuery, [id], function (userErr, userResults) { db.query(activityQuery, function (activityErr, activityResults) { db.query(leaderBoardQuery, function (leaderBoardErr, leaderBoardResults) { // Do something here }); }); }); One of the biggest mistakes is to get yourself in to callback hell by nesting callbacks inside of callbacks inside of more callbacks.
  • 20. Avoiding Callback Hell • Keep your code shallow • Break up your code into small chunks • Use a sequential library like async • Visit http://callbackhell.com
  • 21. Async to the rescue! var async = require('async'); var db = require(’db'); function getUser (callback) { var query = 'SELECT * FROM users WHERE id = ?'; db.query(query, [userId], callback); } function getActivities (callback) { var query = 'SELECT * FROM activities ORDER BY timestamp LIMIT 50'; db.query(query, callback); } function getLeaderBoard (callback) { var query = 'SELECT count(points) as total, user_id FROM activities LIMIT 50'; db.query(query, callback); } var tasks = [getUser, getActivities, getLeaderBoard]; async.parallel(tasks, function (err, results) { var user = results[0][0]; var activities = results[1]; var leaderBoard = results[2]; });
  • 22. Async provides several useful patterns for asynchronous control flow including: parallel, series, waterfall, auto and queue. Visit https://github.com/caolan/async for a detailed guide on using the async module.
  • 23. The Node Package Manager otherwise know as… NPM It’s how you harness the awesomeness of the Node.js community!
  • 24. Using NPM It’s standard practice to install modules locally for your current project. Modules are installed in the ./node_modules in the current directory. To Install a new module npm install <module> To find a module in the NPM repository npm search <search string> To list the modules (and their dependencies) in the current project npm list To see module details npm info <module>
  • 25. DON’T INSTALL MODULES GLOBALLY! Unless they are tools like node-dev, jake, express, minify-js OR linked development modules but more on that later.
  • 26. NPM is awesome sauce! Visit https://npmjs.org for more details about NPM and to browse the current NPM Repository
  • 27. Creating your own modules • Node.js uses CommonJS Modules • require(‘./example’) will load either example.js or example/index.js or the entry point specified in package.json • Run npm init to bootstrap your new module • Try to stick to creating Pure JavaScript modules if possible. It will give you less headaches down the road.
  • 28. Basic Module Example Everything exposed via module.exports is available as an instance variable. var currentCount = 0; module.exports.incr = function () { return ++currentCount; }; Once you’ve created a module in counter.js you use it like this… var counter = require(’./counter'); var count = counter.incr(); Keep this in mind… modules are loaded once and cached. So when you load the module a second time in your app, require just returns the cache copied. This lets you do interesting things…
  • 29. Installing your module • Run npm link in the module working directory • Then run npm link <module> in the your project folder to link it from the global module to your local node_modules. • OR you can create a private registry (See https://npmjs.org/doc/registry.html) • OR just link it by hand :P
  • 30. My Favorite Modules • request • jake • async • hogan.js • node-dev • connect • underscore • moment • express • mysql