The Node.js based Messaging Node is one of the reference implementations of the CSP Messaging services in the reTHINK Architecture.
The role of Messaging Nodes in the reTHINK Architecture is described in detail in Hyperty Messaging Framework. Overall, as part of CSP backend services, it interacts with other rethink CSP backend components like the CSP domain registry, CSP catalogue. On the other hand, the runtime device (browser or server) where the hyperty is executed.
You will find a general documentation and guideline Message nodes Development in Message Nodes and Protostubs Development.
This documentation does not provide an OS dependant instructions : this NodeJS message node can be used on any OS compatible with redis & nodejs tools.
In case you don't have redis & nodejs tools installed on your local environement. A dockerfile is provided, so it can be integrated in a docker instance as well, see Run using Docker
section.
First you need to clone this repository:
git clone https://github.com/reTHINK-project/dev-msg-node-nodejs.git
cd dev-msg-node-nodejs
Performance consideration You can find some results executed with testbeds unit test. To obtain better performance on production it strongly recommanded to use a high log level (e.g. "ERROR") in logLevel setting.
You can skip this part, in case you have redis & Node.js installed.
In order to build dev-msg-node-nodejs you must have docker running. Otherwise, docker can be installed from docker installation. After having installed correctly docker, run the following command :
$ docker build -t msg-node-nodejs .
Afterwards, run the following :
$ docker run -e url=domain.tld -e PORT=9090 -e domainRegistryUrl=http://domain.tld:4567 msg-node-nodejs
Run with docker compose :
This tools allow to start multiple docker container at once. To be more convenient, a docker-compose.yml example configuration file is provide with start & stop script, this file also gives some example for environment configuration. Once you set the correct image name (for msg-node & domain-registry), you can start with :
$ ./start.sh
Then to stop :
$ ./stop.sh
Then run the command :
$ npm run init-setup
After running successfully this command you will have 2 folders (node_modules and vendor), these folders are excluded from the commit process, and are only for development.
Check the server configuration file for custom setting (url, port, ...) :
Now start server with the following command :
$ node src/main/server.js
You should see a log like the following :
[Date] [INFO] server - [S] HTTP & WS server listening on 9090
JavaScript code should be written in ES6.
Please follow instructions on official nodejs installation documentation to setup the Node.js environnement. This include the npm manager for node modules.
- Node.js
- npm
- karma - A simple tool that allows you to execute JavaScript code in multiple real browsers. See more on karma
- mocha - Unit test tool. See more on http://mochajs.org
- gulp - Automate and enhance your workflow. See more about gulp on gulp
The figure below illustrates the service architecture of the Node.js Messaging Node.
Combine with node redis sentinel client, each node shares data sessions with each others through redis storage.
Redis-Sentinel monitor & notify redis cluster of data changes between Node.js instances.
This repository is ready to start working on development. The code will go to the src folder, it contains also the main server script in src/main/ folder.
The unit tests will be on test folder, following the name standard .spec.js
Server (config.js) & tools (gulp, karma, etc...) configurations are located in root folder.
On the root directory you will find .jshintrc and .jscsrc, these files are helpers to maintain syntax consistency.
- jscs - Maintain JavaScript Code Style
- jshint - Detect errors and potential problems in JavaScript code.
To generates api documentation you can run : $ gulp doc This will generate HTML documentation in docs/ folder.
We use Karma test runner to execute mocha test.
To run unit test, you need first to lauch a server node with command :
$ node src/main/server.js
Then start karma test (from main directory) :
$ karma start
Karma will launch the browser to execute all tests in test/ folder and show result in console. Tests are automatically redone when code is modified.
Socket.io is a well-known library that provides real-time bidirectionnal event-based communications. It handles the connection transparently for developpers :
- the protocol negociation (long-polling, websocket,etc...) with client depending of network capabilities
- connection always on with heartbeat packets
- message broadcasting
- session data
- clustering consideration with multiple data storage drivers
Express.js is a minimalist web framework commonly used in front of socket.io server. It provide a robust set of features for web and mobile applications, like request routing, and a solid stack for third-party middleware.
Redis is an in-memory data structure store, used as database, cache and message broker. It supports various type of data structures such as string, hashes, lists... It support data persistency, but it's mainly used to store temporary datas like session or connection information.
Redis has built-in replication, and provides high availability via Redis Sentinel and automatic partitioning with Redis Cluster.
This section describes the functional blocks of the Messaging Node architecture.
The graph below describes message event processing with components.
Msg node starts with server.js script that reads configuration from config.js and instantiate <> class.
This singleton class initialize main components and start listening for incoming clients' websockets . On each new ProtoStub connection, socket.io events are binded to <> instance associated with socket id.
A global Registry class is used by MsgNode to manage internal components and configuration. It allows internal components to share reference to with other components in the architecture.
The SessionManager class handles client connection state changes.
MessageBus class provides a message system that publish information to all components.
The class AddressAllocationManager handles hyperty URLs allocations once client ask for registration.
On each message received from ProtoStub, MsgNode instantiate a ClientMessage instance containing Messages, and dispatch to Client instances.
A PEP/PDP structured Policy Engine is deployed to handle the authorization and access control of messages.