spring redis can';无法连接到远程主机
我有一只骆驼,它轮询Redis:spring redis can';无法连接到远程主机,spring,redis,apache-camel,Spring,Redis,Apache Camel,我有一只骆驼,它轮询Redis: from("timer://pollredis?fixedRate=true&period=5") // poll redis .setHeader("CamelRedis.Command", constant("LPOP")) .setHeader("CamelRedis.Key", constant(
from("timer://pollredis?fixedRate=true&period=5")
// poll redis
.setHeader("CamelRedis.Command", constant("LPOP"))
.setHeader("CamelRedis.Key", constant("shipments"))
// from redis, it is a producer, fetch with .to() !
.to(redisUri)
//
.choice().when(simple("${in.body} == null")).stop().otherwise()
//
.to("direct:internal").end();
JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory();
jedisConnectionFactory.afterPropertiesSet();
RedisTemplate<?, ?> redisTemplate = new RedisTemplate();
redisTemplate.setConnectionFactory(jedisConnectionFactory);
redisTemplate.setDefaultSerializer(new StringRedisSerializer());
redisTemplate.afterPropertiesSet();
SimpleRegistry registry = new SimpleRegistry();
registry.put("redisTemplate", redisTemplate);
到
我得到以下错误:
11:42:49.754 INFO Failed delivery for (MessageId: ID-ip-10-12-22-168-43293-1465299763162-0-1 on ExchangeId: ID-ip-10-12-22-168-43293-1465299763162-0-2). On delivery attempt: 0 caught: org.springframework.data.redis.RedisConnectionFailureException: Cannot get Jedis connection; nested exception is redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool | org.apache.camel.util.CamelLogger.log(CamelLogger.java:159) [Camel (camel-1) thread #0 - timer://pollredis]
我已通过Telnet和使用redis cli检查是否可以访问elasticache
这是什么无法从池中获取资源连接到远程主机时出现的错误
我的本地redis和elasticache redis都运行2.8.24。跑步骆驼2.17.1。以下是我如何让它工作的:
JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory();
jedisConnectionFactory.setHostName(redisHost);
jedisConnectionFactory.setPort(Integer.parseInt(redisPort));
jedisConnectionFactory.afterPropertiesSet();
RedisTemplate<String, Object> redisTemplate = new RedisTemplate();
redisTemplate.setConnectionFactory(jedisConnectionFactory);
redisTemplate.setDefaultSerializer(new StringRedisSerializer());
redisTemplate.afterPropertiesSet();
SimpleRegistry registry = new SimpleRegistry();
registry.put("redisTemplate", redisTemplate);
骆驼路线和以前一样
因此,很明显,当您使用连接工厂时,您无法在以后的URI中设置要使用的主机。我签出了,这可能是版本问题。正在使用spring数据redis 1.6.4.RELEASE和绝地2.7.3。另外,如果我删除?redisTemplate=#redisTemplate
部分,它会工作,但是没有StringRedisSerializer:(
11:42:49.754 INFO Failed delivery for (MessageId: ID-ip-10-12-22-168-43293-1465299763162-0-1 on ExchangeId: ID-ip-10-12-22-168-43293-1465299763162-0-2). On delivery attempt: 0 caught: org.springframework.data.redis.RedisConnectionFailureException: Cannot get Jedis connection; nested exception is redis.clients.jedis.exceptions.JedisConnectionException: Could not get a resource from the pool | org.apache.camel.util.CamelLogger.log(CamelLogger.java:159) [Camel (camel-1) thread #0 - timer://pollredis]
JedisConnectionFactory jedisConnectionFactory = new JedisConnectionFactory();
jedisConnectionFactory.setHostName(redisHost);
jedisConnectionFactory.setPort(Integer.parseInt(redisPort));
jedisConnectionFactory.afterPropertiesSet();
RedisTemplate<String, Object> redisTemplate = new RedisTemplate();
redisTemplate.setConnectionFactory(jedisConnectionFactory);
redisTemplate.setDefaultSerializer(new StringRedisSerializer());
redisTemplate.afterPropertiesSet();
SimpleRegistry registry = new SimpleRegistry();
registry.put("redisTemplate", redisTemplate);
redisUri = spring-redis://notused?redisTemplate=#redisTemplate
redisHost = [stuff].xavwv8.ng.0001.euw1.cache.amazonaws.com
redisPort = 6379