我目前正在使用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文档,但我找不到任何东西?
有没有办法做到这一点。
提前感谢。
答案 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*"
的结果如下:
然后我重启node test.js
,`redis-cli keys“q *”的结果如下:
实际上,这里添加了一个新任务:q:job:2
。致电kue
时,job.remove
会删除工作。所以你应该检查redis-server的日志文件,看看发生了什么。