Building Communication Services Using RabbitMQ and Node.JS Training Course

Building Communication Services Using RabbitMQ and Node.JS Training Course

Overview

Course Duration: 5 Days

Objectives

  • This workshop is aimed at imparting the required know-how to build and manage applications using Node.js & RabbitMQ

MESSAGING SOLUTIONS USING RABBITMQ (1 DAY)
  • Introduction to RabbitMQ
  • Understanding Queueing Architecture
a. Message Queueing
b. Uses for Message Queueing
  • Core Concepts
a. AMQP Messaging Standard
b. Exchanges
c. Queues, Bindings & Consumers
d. Standard Queue
e. Worker Queue
f. Publish & Subscribe
g. Direct Routing
  • Exchanges & Bindings 
a. Direct Exchange
b. Default Exchange 
c. Topic Exchange
d. Fanout Exchange
e. Dead Letter Exchange
  • Understanding Messaging 
a. The role of a consumer
b. The role of a producer
c. Bindings consumers and producers
d. Messages and durability
e. How to verify delivery

ES6 (0.25 DAYS)

  • New in ES6 
a. Classes
b. let and const
c. Arrow functions
d. Enhanced Object Literals
e. Array & Object Destructuring
f. Spread Operator
g. Generators and Iterators
h. Symbols
i. Comprehensions
j. Async Programming using Promises
k. Async Await


BUILDING APPLICATIONS USING NODE.JS (1.75 DAYS)
  • Introduction to Node.js 
a. Installing Node.js
b. Node’s Event Loop
c. Alternatives to Node.js
d. Writing asynchronous code
  • Modularizing code
a. Understanding built-in modules
b. Techniques for modularizing JavaScirpt code
c. Using require() to modularize application code
d. Using npm for third-party modules
e. Handling Exceptions
  • Events and Streams
a. Understanding Events
b. EventEmitter class
c. Understanding Streams
d. Reading and writing streams
e. Using pipe()

  • Accessing Local Resources
a. Process Object
b. Manipulating File System
c. Understanding Buffers
  • Node.js and the web

a. Handling web requests
b. Building a web server
c. Understanding the need for web sockets
d. Realtime interaction using socket.io
  • Building web API using Express.js 

a. Installing Express.js
b. Routing
c. Parameters and queries in routing
d. Working with cookies and sessions
e. Authentication and authorization
f. Error Handling
  • Data Persistence in Node.js 

a. Installing SQLite client module
b. Establishing connections
c. Executing Queries
d. Binding Parameters
d. Inserting, Updating and Deleting Data
  • Building Network Servers & Clients
a. Creating a TCP Server
b. Creating a TCP Client
c. Creating a HTTP/HTTPS client
d. Using the Restler module
  • Testing Node.js Applications

a. Introduction to TAP
b. Installing node-tap
c. Test Organization
d. Performing Assertions
e. Testing Async with Promises
f. Mocking dependencies using Nock
g. Test Coverage 
  • Scaling Node applications

a. The Child process model
b. exec, spawn, and fork functions
c. Using the Cluster module
  • Node.js Eco System

a. ONode Packages
b. Packages of interest
c. Deciding Factors
  • Debugging Node Applications 
BUILDING API FOR MESSAGING INTERFACES USING NODE.JS & RABBITMQ (1.5 DAYS)
  • Building RabbitMQ service consumers 
a. Installing RabbitMQ Client
b. Connecting to Message Broker
c. Sending Messages
d. Receiving Messages
  • Implementing Queuing Code 
a. Topic Based Publisher & Subscriber for Notifications
        ?Simple Publish & Subscribe
        ?Publisher Confirmation
        ?Polymorphic Publish and Subscribe
        ?Controlling Queues and Exchange Names

b. Remote Procedure Calls ?Synchronous RPC
        ?Asynchronous RPC oTargeted Messaging
        ?Using Send and Receive Pattern oFlexible Routing
        ?Topic based publish & subscribe

RABBITMQ ADMINISTRATION (0.5 DAYS)
(Duration for this topic is reduced because of the usage of managed services)
  • Administering RabbitMQ oClusters & Nodes 
a. Creating and starting a managed instance
  • Managing Connections & Channels 
a. Starting and stopping nodes
b. RabbitMQ configuration files
c. How to manage privileges
d. Viewing statistics and analyzing logs
e. Sending alerts
f. How to set up parallel processing

  • High availability with cluster
a. Architecture of a cluster
b. Queues in a cluster
c. Setting up a test cluster
d. Distributing the nodes to more machines
e. How to preserve messages: mirrored queues
  • Implementing failover and replication 
a. Setting up a load balancer-based master/slave
b. Installing the Shovel plugin
c. Configuring and running Shovel
  • Web tools to administer RabbitMQ 
a. The RabbitMQ Management plugin
b. Managing RabbitMQ from the web console
c. Administering users from the web console
d. Managing queue from the web console
e. Using the command line interface
  • RabbitMQ and the REST API 
a. REST API features
b. Accessing statistics
c. vhost and user provisioning
  • Monitoring and securing RabbitMQ 
a. Message durability and Message acknowledgement
b. Memory usage and process limits
c. Setting up SSL
-
-
Course ID:
BCSURN


Show Schedule for: