【发布时间】:2019-02-23 21:12:26
【问题描述】:
我已经在 Elastic Beanstalk 上设置了一个可用的 Parse 服务器。我添加了一个 AWS ElasticCache Redis 服务器用于缓存,但是在使用密码时我无法使连接正常工作,只有没有。在我创建新 Parse 服务器的 Parse 服务器 index.js 文件中,我像这样连接 Redis:
// Redis cache server
var RedisCacheAdapter = require('parse-server').RedisCacheAdapter;
var redisurl='rediss://:'+process.env.REDIS_PASS+'@'+process.env.REDIS_URL
var redisOptions = {url: redisurl};
var redisCache = new RedisCacheAdapter(redisOptions);
我的网址看起来像REDIS_URL=clustercfg.xxxx.xxxx.use1.cache.amazonaws.com
redis:// 和 rediss:// 我都试过了。我知道 RedisCacheAdapter 只需要一个选项 - URL。我以为我可以直接在链接中添加密码,但似乎适配器不会解析为密码和 URL,而只是期望 URL。
我的问题是我在这里做错了什么还是有其他使用密码的方法?如果无法使用密码,我想知道原因是什么(是因为 ElastiCache 对 Internet 隐藏,只有 EC2 上的服务器可以看到)?
更新: 基于来自@MarkB 的 cmets,我测试了 ElastiCache 的一些不同设置,并将上面的代码修改为也使用密码。
var redisOptions = {url: redisurl, password: process.env.REDIS_PASS};
- 以集群模式、静态加密、传输中加密和 Redis 密码运行 ElastiCache 失败。
- 使用静态加密、传输中加密和 Redis 密码运行 ElastiCache 失败。
- 运行 ElastiCache,静态加密和传输中加密,无密码失败。
- 运行 ElastiCache 没有静态加密、传输中加密和无密码成功。
在我看来,从 Parse 服务器连接时使用静态和传输中的加密会导致问题,我不知道如何解决。正如@MarkB 所提到的,Parse server (EC2) and ElastiCache 之间的连接仅限于 VPC,所以我可以没有安全选项,但仍然很好。
【问题讨论】:
-
这里有一些相关的答案 - serverfault.com/questions/837283/…
标签: amazon-web-services amazon-ec2 redis parse-server amazon-elasticache