在AWS Elasticache上使用SAVE命令的Jedis(Redis)

时间:2017-02-21 20:18:59

标签: java amazon-web-services redis jedis amazon-elasticache

以下内容来自AWS中的Tomcat服务器,我们在其中设置了Redis Elasticache实例:

redis.clients.jedis.exceptions.JedisDataException: ERR unknown command 'SAVE'
at redis.clients.jedis.Protocol.processError(Protocol.java:127)
at redis.clients.jedis.Protocol.process(Protocol.java:161)
at redis.clients.jedis.Protocol.read(Protocol.java:215)
at redis.clients.jedis.Connection.readProtocolWithCheckingBroken(Connection.java:340)
at redis.clients.jedis.Connection.getStatusCodeReply(Connection.java:239)
at redis.clients.jedis.BinaryJedis.save(BinaryJedis.java:2700)
at cl.waypoint.util.CacheReports.setCacheReports(CacheReports.java:51)
at cl.waypoint.reports3.ReportStatus.setProgress(ReportStatus.java:86)
at cl.waypoint.reports3.Report101.getData(Report101.java:210)
at cl.waypoint.reports3.Report101.createXLS(Report101.java:274)
at cl.waypoint.reports3.ReportStatus.run(ReportStatus.java:38)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
at java.lang.Thread.run(Thread.java:745)

似乎Elasticache缺少对此类命令的支持,因为Redis本身确实支持它。任何想法或解决方法将不胜感激

PS1:Jedis v2.9.0和Elasticache实例具有引擎版本兼容性:3.2.4

PS2:我刚刚向AWS支持提出了同样的问题,遗憾的是我在这里没有任何反馈意见:(

1 个答案:

答案 0 :(得分:-2)

你看过Redisson了吗? AWS Elasticache SAVE命令中的某些Redis命令不可用。以下是此类commands的完整列表。尽管有这样的限制,Redisson仍然可以与AWS Elasticache完全集成。

以下是与AWS Elasticache一起使用的代码示例:

// 1. Create config object
Config config = new Config();
config.useReplicatedServers()
    .addNodeAddress("redis://first-node.aws.com:7000", "redis://second-node.aws.com:7001");

// 2. Create Redisson instance
RedissonClient redisson = Redisson.create(config);

// 3. Get object you need
RMap<MyKey, MyValue> map = redisson.getMap("myMap");

RLock lock = redisson.getLock("myLock");

RExecutorService executor = redisson.getExecutorService("myExecutorService");

// over 30 different objects and services are available...