Redis客户端连接到redis远程服务器,但无法读取或写入

时间:2015-10-14 11:16:39

标签: node.js express redis digital-ocean express-session

在DegitalOcean,我必须管理两台服务器' Nodeserver'和redis服务器' Redisserver'通过使用前者的节点/表达应用程序建立连接以使用后者的数据库。

出于本地测试的目的,我还安装了另一台redis服务器' LocalRedisOnNodeServer'本地点在节点服务器'。

我已经配置了' Redisserver'接受https://www.digitalocean.com/community/tutorials/how-to-set-up-a-redis-server-as-a-session-handler-for-php-on-ubuntu-14-04中的外部连接,并且当尝试从' LocalRedisOnNodeServer的redis-cli连接时,我能够访问远程“Redis_server”。通过它也可以实现数据库和读写操作。

我仍然没有为Redis_server' Redis_server'配置任何安全措施。 (至于编辑iptables ..)我只设置了一个密码(在redis.conf中的requirepass),我仍然不知道是否可以在这台服务器上使用SSH进行更安全的身份验证(或者为它配置我的应用程序代码。)

以下是app.js文件,其中包含传递给会话的快递会话和RedisStore(接收redis客户端为args)。

var express = require('express');
var app = express();
var routes = require('./routes');
var errorHandlers = require('./middleware/errorhandlers');
var log = require('./middleware/log');
var partials = require('express-partials');
var cookieParser = require('cookie-parser');
var session = require('express-session');
var RedisStore = require('connect-redis')(session);
var bodyParser = require('body-parser');
var redis = require('redis');
var config = require('./config');

app.set('view engine', 'ejs');
app.set('view options', {defaultLayout: 'layout'});

app.use(partials());
app.use(log.logger);
app.use(express.static(__dirname + '/static'));
app.use(cookieParser(config.secret));

console.log(config.redisConf);

var redisClient = redis.createClient(config.redisConf);

redisClient.on('connect', function() {
console.log('connected to redis!!');
});

redisClient.set('framework', 'AngularJS', function(err, reply) {
console.log('the framwork var was SET to AngularJS : the following is the server answer : ');
console.log(reply);
});

app.use(session({
secret: config.secret,
resave: false,
saveUninitialized: true,
store: new RedisStore({client: redisClient})

}));

// right after the session
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({extended: false}));

app.get('/', routes.index);
app.get('/login', routes.login);
app.post('/login', routes.loginProcess);
app.get('/chat', routes.chat);
app.get('/account/login', routes.login);

app.get('/error', function(req, res, next){
next(new Error('A contrived error'));
});

app.use(errorHandlers.error);
app.use(errorHandlers.notFound);

app.listen(config.port);
console.log("App server running on port " + config.port);

这是config.js:

var config = {
port: 3000,
secret: 'secret',

redisConf: {
host: 'xxx.xxx.xxx.xxx.', // The redis's server ip 
port: '6379',
pass: 'theredispass'
}
};    
module.exports = config;

我已经测试了应用程序与本地redis服务器的连接' LocalRedisOnNodeServer'并且它是成功的以及读取和写入键(对于set和get ..)。 这是应用程序代码正常的证据。但是当我从redis主机(redisConf.host)从本地127.0.0.1更改为' Redisserver' ip,只发生连接(redisClient.on('连接'回调记录它已连接到redis !!'但是读取和写入功能(获取和设置) )因为他们的回调没有被触发而失败,另一个问题是快递的会话无法创建,其价值仍未定义。

我想知道为什么连接以及读写操作都可以在Node_server的shell(redis-cli)上的本地redis服务器客户端到远程服务器上进行。而应用程序代码中的redisClient失败。

redis_6379.log

中未提及任何错误

祝你好运

1 个答案:

答案 0 :(得分:5)

我先添加

解决了这个问题
client.on("error", function (err) {
    console.log("Error " + err);
});

所以我可以看到出了什么问题(确实我的错误是认为redisClient属于connect-redis模块,因此我没有在node_redis模块上看到所有这些可用选项..)并且添加了代码告诉我问题就像在this thread中并且感谢this answer而且,我发现最好将get方法移动到set的回调中,因为远程服务器会异步回答..