Asynchronous broker for multi-source data collection using redis.
If redmoon.load is called, and it returned to find the data in the cache, if cache data does not exist, call the specified function(subscriber) to subscribe.
// setting
var redmoon = require('redmoon').create(config)
// event handle
redmoon
.on('timeout', function(keyword) {
console.error('redmoon timeout', keyword)
})
.on('error', function(err) {
console.error('redmoon error', err)
});
// express
app.get('/search/:key/:page/:limit?', function (req, res) {
redmoon.load(function (err, items, meta) {
res.json({
meta: meta,
items: items
})
}, req.params.key, req.params.page, req.params.limit)
})
// collector
// The first event is no meta data in moon.
redmoon
.subscribe(subscriber)
.garbage.start(3600) // It deletes the data collected before to 60 minutes.
var subscriber = function (moon) {
redmoon.atomic(moon.uuid, function(cb) {
process(cb, moon)
}, function(err, data) {
complete(moon, data)
})
}
var process = function (cb, moon) {
// call cb when complete load data
cb(err, {
meta: {},
items: {}
})
}
var complete = function(moon, data) {
redmoon.add(function(err) {
redmoon.trigger(moon.topic)
}, moon, data.meta, data.items)
}
// moon
// {
// uuid: uuid,
// key: key,
// topic: topic,
// meta: meta // if first event then it is undefined
// }
Connect redis.
Initialize redmoon events.
- error
- ready
- connect
- end
Load collected data. If not exist data then trigger event for collection.
Load meta data.
Add collected data to cache.
Set callback function for the collection event.
Unset callback function for the collection event.
Trigger event for the specified topic.
The function to prevent the duplication proccess.
If it has available resources, given process
calls and then release the resources used by cb
call in process.
After the release, and it executes the transfer of data in proccess
to complete
.
Close the connection to the redis server.
Deleting cache data collected before a specified time.
It converts uuid to the topic.
Start garbage collection. Deleting cache data collected before a offset time.
Stop garbage collection.
Make unique string.
Return unixtimestamp.
Create Redmoon instance with config.
See the changelog
redmoon is licensed under the MIT license.