节点& Heroku上的Redis应用程序错误

时间:2015-04-11 20:26:26

标签: node.js heroku redis

我是Heroku&的新手节点所以请耐心等待。我将我的工作聊天应用程序(在localhost上)部署到Heroku但无法打开Heroku应用程序。

任何人都可以帮我解决这个问题吗?

我在stackoverflow上查看了一些类似的问题,并heroku config:add REDISCLOUD_URL='redis_cloud_url'heroku config:add NODE_ENV='production'但这些都没有用。


这是我的heroku日志。

2015-04-11T19:42:35.568690+00:00 heroku[api]: Deploy 0244dd7 by MYMAIL@gmail.com
2015-04-11T19:42:38.004491+00:00 heroku[web.1]: Starting process with command `node app.js`
2015-04-11T19:42:39.182617+00:00 app[web.1]: Detected 512 MB available memory, 512 MB limit per process (WEB_MEMORY)
2015-04-11T19:42:39.182639+00:00 app[web.1]: Recommending WEB_CONCURRENCY=1
2015-04-11T19:42:39.793252+00:00 app[web.1]: events.js:85
2015-04-11T19:42:39.793258+00:00 app[web.1]:       throw er; // Unhandled 'error' event
2015-04-11T19:42:39.793260+00:00 app[web.1]:             ^
2015-04-11T19:42:39.793262+00:00 app[web.1]: Error: Redis connection to 127.0.0.1:6379 failed - connect ECONNREFUSED
2015-04-11T19:42:39.793264+00:00 app[web.1]:     at RedisClient.on_error (/app/node_modules/redis/index.js:196:24)
2015-04-11T19:42:39.793266+00:00 app[web.1]:     at Socket.<anonymous> (/app/node_modules/redis/index.js:106:14)
2015-04-11T19:42:39.793268+00:00 app[web.1]:     at Socket.emit (events.js:107:17)
2015-04-11T19:42:39.793270+00:00 app[web.1]:     at net.js:459:14
2015-04-11T19:42:39.793271+00:00 app[web.1]:     at process._tickCallback (node.js:355:11)
2015-04-11T19:42:40.546881+00:00 heroku[web.1]: State changed from starting to crashed

2 个答案:

答案 0 :(得分:4)

好的,我实际上知道这个问题,问题是您使用的是redis cloud,因此redis在127.0.0.1上运行

在Heroku上查看the official documentation;您不能将REDISCLOUD_URL设置为redis_cloud_url,您必须让Heroku将其设置为您的帐户的REDISCLOUD_URL,您可以在终端中执行此操作

heroku config:get REDISCLOUD_URL

它应该返回这样的东西;

http://rediscloud:password@hostname:port

如果它返回没有此格式的内容,则表示没有为您的应用正确配置/激活插件。

连接到redis的代码应如下所示:

var redis = require('redis');
var url = require('url');
var redisURL = url.parse(process.env.REDISCLOUD_URL);
var client = redis.createClient(redisURL.port, redisURL.hostname, {no_ready_check: true});
client.auth(redisURL.auth.split(":")[1]);

答案 1 :(得分:2)

我使用Heroku Redis,而不是Redis To Go,也遇到了这样的问题。但是我通过更改Redis客户端的初始化方式解决了该问题,之前我有以下代码:

const
  redisOptions = require('./redisOptions'),
  redis = require('redis'),
  redisClient = redis.createClient(redisOptions);

现在我从 redisOptions 中删除了 url 参数,然后将其添加到 createClient 方法中,即:

const
  redisOptions = require('./redisOptions'),
  redis = require('redis'),
  redisClient = redis.createClient(REDIS_URL, redisOptions);

然后错误已解决。真的不确定为什么我的本地环境没有问题,但是我需要在Heroku上进行此修复。