Redis - ECONNREFUSED。即使服务器正在运行

时间:2014-07-18 11:21:00

标签: node.js redis hiredis

我已经阅读了有关ECONNREFUSED错误的stackoverflow上的所有其他线程,但仍然无效。 目前我正在研究Ubuntu 12.04.1 LTS

对于测试我有这个非常简单的代码:

var redis = require("redis"),
    client = redis.createClient(6379,"127.0.0.1");

redis.debug_mode = true;

client.on("connect", function () {
    client.set("foo_rand000000000000", "some fantastic value");
});

但无论何时我开始,我得到的只是ECONNREFUSED错误:

root@oncn05:~/ba# node test.js
hiredis parser not installed.
Redis connection to 127.0.0.1:6379 failed - connect ECONNREFUSED

node.js:201
    throw e; // process.nextTick error, or 'error' event on first tick
          ^
Error: Redis connection to 127.0.0.1:6379 failed - connect ECONNREFUSED
    at RedisClient.on_error (/root/ba/node_modules/redis/index.js:196:24)
    at Socket.<anonymous> (/root/ba/node_modules/redis/index.js:106:14)
    at Socket.emit (events.js:67:17)
    at Array.0 (net.js:319:25)
    at EventEmitter._tickCallback (node.js:192:41)
root@oncn05:~/ba#

问题是:用redis-cli连接redis没问题。

root@oncn05:~/ba# redis-cli
redis 127.0.0.1:6379>

此外,日志不会显示任何可疑内容。 为什么甚至说没有安装hiredis解析器?我用npm install hiredis安装了它。但即使我没有。它甚至在哪里使用?

我感谢你的每一次帮助。

1 个答案:

答案 0 :(得分:2)

首先:感谢所有阅读和/或回答我问题的人。

通常情况下,如果传递createClient这些参数没有区别,因为127.0.0.1:6379是默认设置。

我认识到我有一个旧的node.js版本(0.6.xx),所以我决定完全删除它而不是重新安装它。

所以,首先我用命令sudo apt-get remove nodejs删除了节点。之后我安装了新版本,如下所示:installing via package manager

sudo apt-get install python-software-properties
sudo add-apt-repository ppa:chris-lea/node.js
sudo apt-get update
sudo apt-get install nodejs

现在一切都按预期工作了。我不知道为什么我之前没有想到这一点。