JS Everywhere
by Matteo Collina
This blink like it's 1998
what js is good for
if (el.style.visibility === 'hidden') {
el.style.visibility = 'visible'
} else {
el.style.visibility = 'hidden'
}
Flow control is built-in
If applications sends too much data, we can slow them down with backpressure!
function process(data, cb) {
/* oh yeah, we are processing one
thing at a time
or we can do batches! */
setTimeout(cb, 500)
}
Node.js has streams too!
source.pipe(dest).pipe(source)
Microservices
- AWS Lambda
- Netflix
- Uber
- ... and many others!
The best community ever
we love you too, npm
data:image/s3,"s3://crabby-images/98091/980915b1a9e8a1eb34cbba055369d6733b90c92b" alt=""
var HelloMessage = React.createClass({
render: function() {
return Hello {this.props.name};
}
});
ReactDOM.render(<HelloMessage name="John" />, mountNode);
NodeBots
Credits http://github.com/nodebots
data:image/s3,"s3://crabby-images/6f43c/6f43c0b696ed166412e4d6e47af04ea07d51b471" alt=""
Credits http://github.com/nodebots
data:image/s3,"s3://crabby-images/707e3/707e37558bd5f02cb2952bff6571f93246088970" alt=""
Johnny Five
var five = require("johnny-five")
var board = new five.Board()
board.on('ready', function () {
/* Create an Led on pin 13 */
var led = new five.Led(13)
/* Blink every half second */
led.blink(500)
})
You should not see this!
Universal JS
data:image/s3,"s3://crabby-images/aea09/aea097b8eb2851aeb677e90197b99f2401a1feab" alt=""
- use the same libraries in browsers, servers, and devices
- simple architecture, fewer components
- can we use all of this to build an IoT system?
An IoT system
Another IoT system
One more IoT system
The world is our playground..
..for now :)
What is an IoT system?
data:image/s3,"s3://crabby-images/a067b/a067bf227f193341ecf2b8c344507343b8130d38" alt=""
Architecture
data:image/s3,"s3://crabby-images/2e01c/2e01cf52860b7032709d83ee8bc3f31b2c6ac8f2" alt=""
Sensor Data Flow
data:image/s3,"s3://crabby-images/d55ec/d55ecfe40615552c686c5c283a22737852cca95d" alt=""
Commands Flow
data:image/s3,"s3://crabby-images/0a063/0a063427c06d60f5ac0a3b4358f4300c9b9d0506" alt=""
data:image/s3,"s3://crabby-images/5ebdc/5ebdcbbd1d390c7e4f7ec108a79a03b4bd04ff87" alt=""
Problems
- Latency
- no reuse
- complex
- lots of moving parts
Using a pub/sub broker
Sensor Data Flow
data:image/s3,"s3://crabby-images/c7345/c73455090c0b09f46c36ac4b36dd35901944451d" alt=""
Commands Flow
data:image/s3,"s3://crabby-images/3fb42/3fb42d041dc41a934a376763df722fb849e77a27" alt=""
data:image/s3,"s3://crabby-images/acfbc/acfbc9e26039231824310f22c1f3bfd55942e510" alt=""
MQTT.js works on
- browsers
- servers
- devices
MQTT
- publish/subscribe protocol
- multiple quality of service level..
- ..with at-least-once and exactly-once semantics
- low overhead (2 bytes at minimum)
- offline messaging
- retained messages, like a key/value store
- can run over WebSocket
Publish-Subscribe
data:image/s3,"s3://crabby-images/3ed92/3ed9250e3e391d702c738203986409116a763f92" alt=""
data:image/s3,"s3://crabby-images/d5ea5/d5ea58d1ee3a6c97a6fb52398994d29a1ff0cb37" alt=""
MQTT broker in Node.js
Mosca
- http://npm.im/mosca
- Standalone usage, through `$ mosca`
- Embeddable in your app, so you can do X for every message
- Authentication APIs
- Supports Mongo, Redis, AMQP, and MQTT as pub/sub backends
- Needs a DB, such as LevelDB, Mongo, or Redis
- Support websockets
- Test instance available at test.mosca.io
- New version coming with 10x throughput improvement
Authentication in Mosca
var server = new mosca.Server(settings);
/* Accepts the connection if the username
and password are valid */
function authClient(client, user, pass, cb) {
var authorized = (
user=== 'alice' &&
pass.toString() == 'secret' );
if (authorized) client.user = user;
callback(null, authorized);
}
server.authenticate = authClient;
Publish Authorization in Mosca
var server = new mosca.Server(settings);
function authPub(client, topic, payload, cb) {
var ok = client.user == topic.split('/')[1];
/* we can alter the message here */
if (ok) callback(null, payload);
else callback(null, false);
}
server.authorizePublish = authPub;
Subscribe Authorization in Mosca
var server = new mosca.Server(settings);
function authSub(client, topic, cb) {
var ok = client.user === topic.split('/')[1];
cb(null, ok);
}
server.authorizeSubscribe = authSub;
Storing data in a timeseries
var server = new mosca.Server(settings);
function published(packet, client, callback) {
timeseries.store(packet, callback);
}
server.published = published;
http://senecajs.org
var seneca = require('seneca')()
seneca.add({
role:'user',
cmd:'login'
}, function (args, callback) {
var loggedIn = args.username === 'matteo' &&
args.password === 'collina'
callback(null, { loggedIn:loggedIn })
})
seneca.listen()
var seneca = require('seneca')()
var client = seneca.client()
client.act({
role:'user',
cmd:'login',
username: 'matteo',
password: 'collina'
}, function (err, result) {
console.log(result.loggedIn)
})
data:image/s3,"s3://crabby-images/7178d/7178d210570dac408cef7432ff51d3290f659c98" alt=""
Features
- multiple transports, from bare TCP to busses
- build a monolith, and then split it away
- deep inspection & debugging tools
- authentication/user managament system
- control panel
- integration with HAPI
- gossip-based service discovery
Demo: an IoT system
- microservice based
- on top of MQTT
- service discovery based on gossip
data:image/s3,"s3://crabby-images/a27e2/a27e22c754eeb1a56ae3ea62d6c6fe9962e4c9a1" alt=""
data:image/s3,"s3://crabby-images/50230/502307f6016713c65a8627dbcc917f3a90aba140" alt=""
Demo!
Links
- MQTT.js: http://npm.im/mqtt
- Mosca: http://mosca.io
- Seneca: http://senecajs.org/
- Fuge: http://fuge.io
- Vidi: https://github.com/vidi-insights/vidi-dashboard
- seneca-mesh: http://npm.im/seneca-mesh
- toolbag: http://npm.im/toolbag
- swim-js: http://npm.im/swim-js
- baseswim: http://npm.im/baseswim
This presentation
data:image/s3,"s3://crabby-images/99e76/99e761e29fefe768aa1ba0be45294f276ab5ce2e" alt=""
Thanks!
If you need help with Node
or the Internet of Things