SlideShare a Scribd company logo
1 of 38
Introduction to Node.js
  Sudar Muthu (@sudarmuthu)
      Research Engineer
           Yahoo! Labs
    http://github.com/sudar
     http://sudarmuthu.com
Agenda
   What Node.JS is not
   What is Node.JS
   Why Node.JS?
   Using Node.JS
    ›   As a interactive shell
    ›   As a Server
    ›   As a Client
 Common Modules
 Terminologies
 Workshop
Node.JS is not …

   Ruby on Rails
   Django
   Codeigniter
   CakePHP



    Node.JS is bare bone and the community are making stuff like
     Express, connect etc.
What is Node.JS
 JavaScript Programming Environment for creating highly
  scalable network programs
 Provides Evented, non-blocking I/O
 Built on top of V8 engine
 Supports C/C++ based addons
 Supports CommonJS Module format
 Is fast .. in fact very fast.
 Similar to Event machine in Ruby or Twisted in Python
What is Evented I/O
Single thread Synchronous I/O
Single thread Synchronous I/O
Multi thread Synchronous I/O
Multi thread Synchronous I/O
You can throw in more servers, but
  that will cost you lot of money.
Synchronous I/O
Synchronous I/O
Synchronous I/O
Single thread Asynchronous I/O
Why Node.JS?
So, code like this

var result = db.query("select..");
// use result

either blocks the entire process or
implies multiple execution stacks (threads).
Why Node.JS?
But code like this

db.query("select..", function (result) {
    // use result
});

allows the program to return to the event loop immediately. No
   more unnecessary threads.
Demo of Callback
// execute the callback after 2 seconds
setTimeout(function () {
   console.log("World!");
}, 2000);

// print in console
console.log("Hello");



https://github.com/sudar/node.js-samples/blob/master/callback.js
Using Node.JS
 Install Node.JS
 Install NPM
 Install other modules you want by doing

npm install <module_name>

 You are good to go

(This setup is already done for you. Use the Ubuntu image in the
pen drive)
Node.JS – as an interactive shell
Similar to Python’s shell

$> node
>3+1
4
> true != false
true
>.help
>.exit
Node.JS – As a server
var http = require('http'); // require the http module

// create a server
http.createServer(function (req, res) {
    // call this function when a request is received

  res.writeHead(200, {
      'Content-Type': 'text/plain'
  });

    // send this as part of the response
    res.end('Hello Worldn');
}).listen(1337, "127.0.0.1"); // listen on port 1337

// debug information
console.log('Server running at http://127.0.0.1:1337/');



https://github.com/sudar/node.js-samples/blob/master/http-server.js
Node.JS – As a client
var http = require('http'); // require the needed modules

// make the request object
var request = http.request({
    'host': 'sudarmuthu.com',
    'port': 80,
    'path': '/',
    'method': 'GET'
});

// assign callbacks
request.on('response', function (response) {
   console.log('Response Status Code: ' + response.statusCode);

      response.on('data', function (data) {
          console.log('Body: ' + data);
      });
});

https://github.com/sudar/node.js-samples/blob/master/http-client.js
Core Modules

   Processes
   Filesystem
   Networking
   Utilities

The entire list can be found at http://nodejs.org/api/
Core Modules - Processes
Node allows you to analyze your process and manage external
 process

Available Modules

 process
 child_process

Code samples: https://github.com/sudar/node.js-
 samples/blob/master/process.js
Core Modules - Filesystem
Low level API to manipulate files

Available Modules

 fs
 path

Code Samples: https://github.com/sudar/node.js-
 samples/blob/master/filesystem.js
Core Modules - Networking
 Available Modules

    net
    dgram
    http
    tls
    https
    dns

 Code Samples: https://github.com/sudar/node.js-
  samples/blob/master/dns.js
Core Modules - Utilities
 Provides utility methods

 Available Modules

  console
  util

 Code Samples: https://github.com/sudar/node.js-
  samples/blob/master/console.js
Node.JS is useful for..
   Writing highly concurrent server applications
   Sharing application logic between server and client
   Peer-to-peer web applications using websockets
   Real-time applications
Terminologies
   NPM – Package manager (like apt-get)
   Modules – Plugins or add-ons for Node.JS
   Express – MVC framework (like RoR)
   Jade – Template Engine (like Smarty)
   Socket.IO – A websockets Library
Links
 http://github.com/sudar/node.js-samples (all code samples
  used in this talk)
 http://nodejs.org
 http://npmjs.org
 http://expressjs.com
 http://socket.io
Workshop
Express JS
   Basic web framework
   Runs on top of node.js
   Provides routing and redirection helpers
   Dynamic view helpers
   Has support for sessions
   Focus on high performance
Hello World Express App


https://github.com/sudar/node.js-samples/tree/master/express/hello-world
Square Things App
   Allows you to choose the color of a square region
   A very simple server implementation
   A very simple client MVC implementation
   Uses node.js on the server
   Uses Y.App implementation on the client




https://github.com/ericf/square-thing-app
Thank you

More Related Content

What's hot

What's hot (20)

Nodejs presentation
Nodejs presentationNodejs presentation
Nodejs presentation
 
Introduction to Node js
Introduction to Node jsIntroduction to Node js
Introduction to Node js
 
Non-blocking I/O, Event loops and node.js
Non-blocking I/O, Event loops and node.jsNon-blocking I/O, Event loops and node.js
Non-blocking I/O, Event loops and node.js
 
Nodejs getting started
Nodejs getting startedNodejs getting started
Nodejs getting started
 
Introduction Node.js
Introduction Node.jsIntroduction Node.js
Introduction Node.js
 
node.js: Javascript's in your backend
node.js: Javascript's in your backendnode.js: Javascript's in your backend
node.js: Javascript's in your backend
 
Create a RESTful API with NodeJS, Express and MongoDB
Create a RESTful API with NodeJS, Express and MongoDBCreate a RESTful API with NodeJS, Express and MongoDB
Create a RESTful API with NodeJS, Express and MongoDB
 
Node ppt
Node pptNode ppt
Node ppt
 
Introduction to Node.js
Introduction to Node.jsIntroduction to Node.js
Introduction to Node.js
 
Use Node.js to create a REST API
Use Node.js to create a REST APIUse Node.js to create a REST API
Use Node.js to create a REST API
 
Building your first Node app with Connect & Express
Building your first Node app with Connect & ExpressBuilding your first Node app with Connect & Express
Building your first Node app with Connect & Express
 
Introduction to Node.js
Introduction to Node.jsIntroduction to Node.js
Introduction to Node.js
 
Node.js Patterns for Discerning Developers
Node.js Patterns for Discerning DevelopersNode.js Patterns for Discerning Developers
Node.js Patterns for Discerning Developers
 
Nodejs intro
Nodejs introNodejs intro
Nodejs intro
 
Intro to Node.js (v1)
Intro to Node.js (v1)Intro to Node.js (v1)
Intro to Node.js (v1)
 
JavaScript as a Server side language (NodeJS): JSConf 2011, Dhaka
JavaScript as a Server side language (NodeJS): JSConf 2011, DhakaJavaScript as a Server side language (NodeJS): JSConf 2011, Dhaka
JavaScript as a Server side language (NodeJS): JSConf 2011, Dhaka
 
Introduction to REST API with Node.js
Introduction to REST API with Node.jsIntroduction to REST API with Node.js
Introduction to REST API with Node.js
 
NodeJS ecosystem
NodeJS ecosystemNodeJS ecosystem
NodeJS ecosystem
 
NodeJS for Beginner
NodeJS for BeginnerNodeJS for Beginner
NodeJS for Beginner
 
Introduction to node.js by jiban
Introduction to node.js by jibanIntroduction to node.js by jiban
Introduction to node.js by jiban
 

Similar to Introduction to node.js GDD

An Overview of Node.js
An Overview of Node.jsAn Overview of Node.js
An Overview of Node.js
Ayush Mishra
 

Similar to Introduction to node.js GDD (20)

Node.js: A Guided Tour
Node.js: A Guided TourNode.js: A Guided Tour
Node.js: A Guided Tour
 
Node.js Workshop - Sela SDP 2015
Node.js Workshop  - Sela SDP 2015Node.js Workshop  - Sela SDP 2015
Node.js Workshop - Sela SDP 2015
 
Node js beginner
Node js beginnerNode js beginner
Node js beginner
 
A slightly advanced introduction to node.js
A slightly advanced introduction to node.jsA slightly advanced introduction to node.js
A slightly advanced introduction to node.js
 
Node.js essentials
 Node.js essentials Node.js essentials
Node.js essentials
 
Nodejs a-practical-introduction-oredev
Nodejs a-practical-introduction-oredevNodejs a-practical-introduction-oredev
Nodejs a-practical-introduction-oredev
 
Intro To Node.js
Intro To Node.jsIntro To Node.js
Intro To Node.js
 
Practical Use of MongoDB for Node.js
Practical Use of MongoDB for Node.jsPractical Use of MongoDB for Node.js
Practical Use of MongoDB for Node.js
 
Node.js: The What, The How and The When
Node.js: The What, The How and The WhenNode.js: The What, The How and The When
Node.js: The What, The How and The When
 
Proposal
ProposalProposal
Proposal
 
Getting Started with MongoDB and Node.js
Getting Started with MongoDB and Node.jsGetting Started with MongoDB and Node.js
Getting Started with MongoDB and Node.js
 
node.js.pptx
node.js.pptxnode.js.pptx
node.js.pptx
 
soft-shake.ch - Hands on Node.js
soft-shake.ch - Hands on Node.jssoft-shake.ch - Hands on Node.js
soft-shake.ch - Hands on Node.js
 
Exploring Node.jS
Exploring Node.jSExploring Node.jS
Exploring Node.jS
 
Intro to Node.js
Intro to Node.jsIntro to Node.js
Intro to Node.js
 
Introduction to Node.JS
Introduction to Node.JSIntroduction to Node.JS
Introduction to Node.JS
 
Introduction to Node.js: What, why and how?
Introduction to Node.js: What, why and how?Introduction to Node.js: What, why and how?
Introduction to Node.js: What, why and how?
 
Node JS | Dilkash Shaikh Mahajan
Node JS | Dilkash Shaikh MahajanNode JS | Dilkash Shaikh Mahajan
Node JS | Dilkash Shaikh Mahajan
 
An Overview of Node.js
An Overview of Node.jsAn Overview of Node.js
An Overview of Node.js
 
Introduce about Nodejs - duyetdev.com
Introduce about Nodejs - duyetdev.comIntroduce about Nodejs - duyetdev.com
Introduce about Nodejs - duyetdev.com
 

More from Sudar Muthu

Capabilities of Arduino (including Due)
Capabilities of Arduino (including Due)Capabilities of Arduino (including Due)
Capabilities of Arduino (including Due)
Sudar Muthu
 

More from Sudar Muthu (20)

A quick preview of WP CLI - Chennai WordPress Meetup
A quick preview of WP CLI - Chennai WordPress MeetupA quick preview of WP CLI - Chennai WordPress Meetup
A quick preview of WP CLI - Chennai WordPress Meetup
 
WordPress Developer tools
WordPress Developer toolsWordPress Developer tools
WordPress Developer tools
 
WordPress Developer Tools to increase productivity
WordPress Developer Tools to increase productivityWordPress Developer Tools to increase productivity
WordPress Developer Tools to increase productivity
 
Unit testing for WordPress
Unit testing for WordPressUnit testing for WordPress
Unit testing for WordPress
 
Unit testing in php
Unit testing in phpUnit testing in php
Unit testing in php
 
Using arduino and raspberry pi for internet of things
Using arduino and raspberry pi for internet of thingsUsing arduino and raspberry pi for internet of things
Using arduino and raspberry pi for internet of things
 
How arduino helped me in life
How arduino helped me in lifeHow arduino helped me in life
How arduino helped me in life
 
Having fun with hardware
Having fun with hardwareHaving fun with hardware
Having fun with hardware
 
Getting started with arduino workshop
Getting started with arduino workshopGetting started with arduino workshop
Getting started with arduino workshop
 
Python in raspberry pi
Python in raspberry piPython in raspberry pi
Python in raspberry pi
 
Hack 101 at IIT Kanpur
Hack 101 at IIT KanpurHack 101 at IIT Kanpur
Hack 101 at IIT Kanpur
 
PureCSS open hack 2013
PureCSS open hack 2013PureCSS open hack 2013
PureCSS open hack 2013
 
Pig workshop
Pig workshopPig workshop
Pig workshop
 
Arduino Robotics workshop day2
Arduino Robotics workshop day2Arduino Robotics workshop day2
Arduino Robotics workshop day2
 
Arduino Robotics workshop Day1
Arduino Robotics workshop Day1Arduino Robotics workshop Day1
Arduino Robotics workshop Day1
 
Hands on Hadoop and pig
Hands on Hadoop and pigHands on Hadoop and pig
Hands on Hadoop and pig
 
Lets make robots
Lets make robotsLets make robots
Lets make robots
 
Capabilities of Arduino (including Due)
Capabilities of Arduino (including Due)Capabilities of Arduino (including Due)
Capabilities of Arduino (including Due)
 
Controlling robots using javascript
Controlling robots using javascriptControlling robots using javascript
Controlling robots using javascript
 
Picture perfect hacks with flickr API
Picture perfect hacks with flickr APIPicture perfect hacks with flickr API
Picture perfect hacks with flickr API
 

Recently uploaded

CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Service
giselly40
 
Artificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and MythsArtificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and Myths
Joaquim Jorge
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI Solutions
Enterprise Knowledge
 

Recently uploaded (20)

Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024Finology Group – Insurtech Innovation Award 2024
Finology Group – Insurtech Innovation Award 2024
 
Exploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone ProcessorsExploring the Future Potential of AI-Enabled Smartphone Processors
Exploring the Future Potential of AI-Enabled Smartphone Processors
 
How to convert PDF to text with Nanonets
How to convert PDF to text with NanonetsHow to convert PDF to text with Nanonets
How to convert PDF to text with Nanonets
 
Data Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt RobisonData Cloud, More than a CDP by Matt Robison
Data Cloud, More than a CDP by Matt Robison
 
Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024Axa Assurance Maroc - Insurer Innovation Award 2024
Axa Assurance Maroc - Insurer Innovation Award 2024
 
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men08448380779 Call Girls In Greater Kailash - I Women Seeking Men
08448380779 Call Girls In Greater Kailash - I Women Seeking Men
 
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
Strategies for Unlocking Knowledge Management in Microsoft 365 in the Copilot...
 
Breaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path MountBreaking the Kubernetes Kill Chain: Host Path Mount
Breaking the Kubernetes Kill Chain: Host Path Mount
 
Automating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps ScriptAutomating Google Workspace (GWS) & more with Apps Script
Automating Google Workspace (GWS) & more with Apps Script
 
Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)Powerful Google developer tools for immediate impact! (2023-24 C)
Powerful Google developer tools for immediate impact! (2023-24 C)
 
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
08448380779 Call Girls In Diplomatic Enclave Women Seeking Men
 
CNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of ServiceCNv6 Instructor Chapter 6 Quality of Service
CNv6 Instructor Chapter 6 Quality of Service
 
Presentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreterPresentation on how to chat with PDF using ChatGPT code interpreter
Presentation on how to chat with PDF using ChatGPT code interpreter
 
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
Raspberry Pi 5: Challenges and Solutions in Bringing up an OpenGL/Vulkan Driv...
 
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
04-2024-HHUG-Sales-and-Marketing-Alignment.pptx
 
Artificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and MythsArtificial Intelligence: Facts and Myths
Artificial Intelligence: Facts and Myths
 
Driving Behavioral Change for Information Management through Data-Driven Gree...
Driving Behavioral Change for Information Management through Data-Driven Gree...Driving Behavioral Change for Information Management through Data-Driven Gree...
Driving Behavioral Change for Information Management through Data-Driven Gree...
 
IAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI SolutionsIAC 2024 - IA Fast Track to Search Focused AI Solutions
IAC 2024 - IA Fast Track to Search Focused AI Solutions
 
The Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptxThe Codex of Business Writing Software for Real-World Solutions 2.pptx
The Codex of Business Writing Software for Real-World Solutions 2.pptx
 
08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men08448380779 Call Girls In Civil Lines Women Seeking Men
08448380779 Call Girls In Civil Lines Women Seeking Men
 

Introduction to node.js GDD

  • 1.
  • 2. Introduction to Node.js Sudar Muthu (@sudarmuthu) Research Engineer Yahoo! Labs http://github.com/sudar http://sudarmuthu.com
  • 3. Agenda  What Node.JS is not  What is Node.JS  Why Node.JS?  Using Node.JS › As a interactive shell › As a Server › As a Client  Common Modules  Terminologies  Workshop
  • 4. Node.JS is not …  Ruby on Rails  Django  Codeigniter  CakePHP Node.JS is bare bone and the community are making stuff like Express, connect etc.
  • 5. What is Node.JS  JavaScript Programming Environment for creating highly scalable network programs  Provides Evented, non-blocking I/O  Built on top of V8 engine  Supports C/C++ based addons  Supports CommonJS Module format  Is fast .. in fact very fast.  Similar to Event machine in Ruby or Twisted in Python
  • 11. You can throw in more servers, but that will cost you lot of money.
  • 12.
  • 13.
  • 14.
  • 19. Why Node.JS? So, code like this var result = db.query("select.."); // use result either blocks the entire process or implies multiple execution stacks (threads).
  • 20. Why Node.JS? But code like this db.query("select..", function (result) { // use result }); allows the program to return to the event loop immediately. No more unnecessary threads.
  • 21. Demo of Callback // execute the callback after 2 seconds setTimeout(function () { console.log("World!"); }, 2000); // print in console console.log("Hello"); https://github.com/sudar/node.js-samples/blob/master/callback.js
  • 22. Using Node.JS  Install Node.JS  Install NPM  Install other modules you want by doing npm install <module_name>  You are good to go (This setup is already done for you. Use the Ubuntu image in the pen drive)
  • 23. Node.JS – as an interactive shell Similar to Python’s shell $> node >3+1 4 > true != false true >.help >.exit
  • 24. Node.JS – As a server var http = require('http'); // require the http module // create a server http.createServer(function (req, res) { // call this function when a request is received res.writeHead(200, { 'Content-Type': 'text/plain' }); // send this as part of the response res.end('Hello Worldn'); }).listen(1337, "127.0.0.1"); // listen on port 1337 // debug information console.log('Server running at http://127.0.0.1:1337/'); https://github.com/sudar/node.js-samples/blob/master/http-server.js
  • 25. Node.JS – As a client var http = require('http'); // require the needed modules // make the request object var request = http.request({ 'host': 'sudarmuthu.com', 'port': 80, 'path': '/', 'method': 'GET' }); // assign callbacks request.on('response', function (response) { console.log('Response Status Code: ' + response.statusCode); response.on('data', function (data) { console.log('Body: ' + data); }); }); https://github.com/sudar/node.js-samples/blob/master/http-client.js
  • 26. Core Modules  Processes  Filesystem  Networking  Utilities The entire list can be found at http://nodejs.org/api/
  • 27. Core Modules - Processes Node allows you to analyze your process and manage external process Available Modules  process  child_process Code samples: https://github.com/sudar/node.js- samples/blob/master/process.js
  • 28. Core Modules - Filesystem Low level API to manipulate files Available Modules  fs  path Code Samples: https://github.com/sudar/node.js- samples/blob/master/filesystem.js
  • 29. Core Modules - Networking Available Modules  net  dgram  http  tls  https  dns Code Samples: https://github.com/sudar/node.js- samples/blob/master/dns.js
  • 30. Core Modules - Utilities Provides utility methods Available Modules  console  util Code Samples: https://github.com/sudar/node.js- samples/blob/master/console.js
  • 31. Node.JS is useful for..  Writing highly concurrent server applications  Sharing application logic between server and client  Peer-to-peer web applications using websockets  Real-time applications
  • 32. Terminologies  NPM – Package manager (like apt-get)  Modules – Plugins or add-ons for Node.JS  Express – MVC framework (like RoR)  Jade – Template Engine (like Smarty)  Socket.IO – A websockets Library
  • 33. Links  http://github.com/sudar/node.js-samples (all code samples used in this talk)  http://nodejs.org  http://npmjs.org  http://expressjs.com  http://socket.io
  • 35. Express JS  Basic web framework  Runs on top of node.js  Provides routing and redirection helpers  Dynamic view helpers  Has support for sessions  Focus on high performance
  • 36. Hello World Express App https://github.com/sudar/node.js-samples/tree/master/express/hello-world
  • 37. Square Things App  Allows you to choose the color of a square region  A very simple server implementation  A very simple client MVC implementation  Uses node.js on the server  Uses Y.App implementation on the client https://github.com/ericf/square-thing-app