Checkout the Java or the Python versions of BigIO.
BigIO is a fast, distributed messaging framework for a variety of languages. This version of BigIO runs in NodeJS, and is fully interoperable with the Java version.
Note: BigIO is only compatible with Node versions > 0.12.x.
Add bigio to your package.json.
"dependencies": {
"bigio" : "0.1.13"
}
Then type npm install
Register a listener on a topic:
var bigio = require('bigio');
bigio.initialize(function() {
bigio.addListener( {
topic: 'HelloWorld',
listener: function(message) {
console.log('Received a message');
console.log(message[0]);
}
});
});
Send a message on a topic:
var bigio = require('bigio');
bigio.initialize(function() {
setInterval(function() {
bigio.send( {
topic: 'HelloWorld',
message: { content : 'HelloWorld' }
});
}, 1000);
});
To use BigIO messages to update a web app, I'd recommend using the awesome project socket.io. This is necessary since the BigIO messages come to the Node.js server and not the browser. To bridge this gap, we use socket.io.
Here's an example using Express, socket.io, and JQuery:
var app = require('express');
var http = require('http').Server(app);
var io = require('socket.io');
var bigio = require('bigio');
var $ = require('jquery');
http.listen(3000, function() {
console.log('Listening on port 3000');
});
app.get('/', function(req, res) {
res.sendFile(__dirname + '/index.html');
});
bigio.initialize(function() {
bigio.addListener( {
topic: 'HelloWorld',
listener: function(message) {
var messageStr = message[0];
io.emit('hello_world', { 'message': messageStr });
}
});
});
<!doctype html>
<html>
<head>
<title>BigIO Web App</title>
</head>
<script src="https://cdn.socket.io/socket.io-1.3.5.js"></script>
<script src="http://code.jquery.com/jquery-1.11.1.js"></script>
<script>
var socket = io();
socket.on('hello_world', function(msg) {
$('#messages').append($('<li>' + msg['message'] + '</li>'));
});
</script>
<body>
<ul id="messages"></ul>
</body>
</html>
To override the default configuration, add a configuration object to the initialize()
function:
const config = {
protocol: 'tcp',
useMulticast: true,
multicastGroup: '239.0.0.1',
multicastPort: 8989,
logLevel: 'debug',
network: 'wlan0',
};
bigio.initialize(config, function() {
// ...
});
- Added configuration option to specify the network
- Fixed port reuse issue
- Implemented encrypted messaging
- Implemented message templates
- Better logging to console
- Added unit tests
- Refactored into fewer files
- Numerous bug fixes
- Better error handling
- Critical bug fix
- Bug fixes on Mac and Linux
- Critical bug fixes
- Interoperability with Java BigIO