有谁能告诉我这个测试代码有什么问题?该程序最初工作正常,但不可避免地,我在几小时不使用后得到Redis超时错误。注意,我已将此帖子上的redis主机和密码更改为虚假信息。
注意,无论是使用node-redis还是iris-redis驱动程序,我都会遇到同样的错误。
var express = require('express');
var app = express();
// Redis Data Store
var redis = require("iris-redis");
var client = redis.createClient( 6379, "nodejitsudb5555563948.redis.irstack.com");
client.auth("fehehyrj971946ef332e975fbebb4");
client.on("ready", function() {
client.iris_config(function(er, config) {
if(er) throw er;
console.log("Got my server config: %j", config)
// client.quit()
});
});
// Define a test route
app.get('/test', function(req, res) {
client.incr("seq:test", function(err, reply) {
console.log("Incremented redis counter: " + reply);
var body = "Incremented Redis Counter: " + reply;
res.setHeader('Content-Type', 'text/plain');
res.setHeader('Content-Length', body.length);
res.end(body);
});
});
app.listen(8001);
console.log('Listening on port 8001');
答案 0 :(得分:1)
您的timeout
可能未将0
设置为redis-server
。如果您的应用程序应该在很长一段时间内处于空闲状态,那么您应该将timeout
设置为0
。您可以通过redis-cli
检查配置文件或使用以下内容:
CONFIG GET timeout
如果您的生产服务器已经存在,并且暂时不允许将其放下,则可以执行以下操作,使用timeout
动态设置redis redis-cli
:
CONFIG SET timeout 0
然后不要忘记在redis配置文件中设置以下行:
timeout 0