我可以使用kue / node.js保存数据吗?

时间:2016-01-08 11:44:49

标签: javascript node.js database persistence kue

我目前正在使用kue / node.js

https://github.com/Automattic/kue

创建并保存作业后,数据将在我的本地redis服务器中。

  var job = queue.create('new_job', {
        title: 'welcome email for tj'
        , to: 'tj@learnboost.com'
        , template: 'welcome-email'
    }).save( function(err){
        if( !err ) console.log( job.id );
    });

Redis Cli

127.0.0.1:6379> keys *
 1) "q:job:12"
 2) "q:jobs:inactive"
 3) "q:stats:work-time"
 4) "q:ids"
 5) "q:job:11"
 6) "q:job:7"
 7) "q:search:object:13"
 8) "q:search:word:TTL"
 9) "q:search:object:2"
10) "q:jobs:new_job:inactive"
  ..........

现在我重新启动机器并再次检查后,

127.0.0.1:6379> keys *
(empty list or set)

所以它是空的。

这很明显,但我想保留数据,我检查了kue文档,但我找不到任何东西?

有没有办法做到这一点。

提前感谢。

2 个答案:

答案 0 :(得分:3)

我认为可以通过redis服务器配置来处理持久性。在redis.conf中,您有一个评论snapshotting的部分,您应该进行探讨。有许多方法可以配置持久性,但我认为最适合您的用例的是AOF,其中所有对redis服务器的传入写入都记录到文件中。请阅读有关如何为持久性here配置redis的信息。您可以通过将此行添加到配置文件来启用AOF持久性:

appendonly true

答案 1 :(得分:0)

实际上,除非您手动删除作业,否则kue不会删除作业。

这是一个示例,保存为test.js:

const kue = require('kue')
const queue = kue.createQueue()
queue.process('echo', (job, done) => {
  console.log(job.data.message)
  done();
})
const job = queue.create('echo', {
  message: 'hello world'
}).save((err) => {
  if (err) {
    console.log(job.id)
  }
})

当我通过

执行时
node test.js

我在redis中检查队列信息,redis-cli keys "q*"的结果如下:

enter image description here

然后我重启node test.js,`redis-cli keys“q *”的结果如下:

enter image description here

实际上,这里添加了一个新任务:q:job:2。致电kue时,job.remove会删除工作。所以你应该检查redis-server的日志文件,看看发生了什么。