2013-06-21 66 views
2

我试图使用memcache-client连接创建的amazon elastiCache集群端点。 但正在错误与ruby一起使用memcache客户端

MemCache::MemCacheError: No connection to server (testcachecluster.u098ed.cfg.us 
e1.cache.amazonaws.com:11211 DEAD (Timeout::Error: execution expired), will retr 
y at 2013-06-21 11:34:15 +0530) 
     from C:/ProgramData/RailsInstaller/Ruby1.9.3/lib/ruby/gems/1.9.1/gems/me 
mcache-client-1.8.5/lib/memcache.rb:863:in `with_socket_management' 
     from C:/ProgramData/RailsInstaller/Ruby1.9.3/lib/ruby/gems/1.9.1/gems/me 
mcache-client-1.8.5/lib/memcache.rb:370:in `block in set' 
     from C:/ProgramData/RailsInstaller/Ruby1.9.3/lib/ruby/gems/1.9.1/gems/me 
mcache-client-1.8.5/lib/memcache.rb:886:in `with_server' 
     from C:/ProgramData/RailsInstaller/Ruby1.9.3/lib/ruby/gems/1.9.1/gems/me 
mcache-client-1.8.5/lib/memcache.rb:361:in `set' 
     from (irb):5 
     from C:/ProgramData/RailsInstaller/Ruby1.9.3/bin/irb:12:in `<main>' 

但使用Amazon elastiCache集群端点的本地主机instread我正确地得到。

irb(main):006:0> m = MemCache.new('localhost:11211') 
=> <MemCache: 1 servers, ns: nil, ro: false> 
irb(main):007:0> m.set 'abc', 'xyz' 
=> "STORED\r\n" 
irb(main):008:0> m.get 'abc' 
=> "xyz" 
irb(main):009:0> 
+0

你解决了这个问题吗?我有类似的问题。 –

+0

不,我没有解决这个问题!我用memcache和memcache客户端,而不是memcache.but同样的错误发生 – chinchu

+0

如果你有任何解决方案请帮助我也 – chinchu

回答

5

好的,对我来说,问题是安全组织。您只能从具有Elasticache安全组中所列安全组的ec2实例访问Elasticache节点。

因此,对于我来说,我的ec2实例有一个“web”安全组。在elasticache中,我然后将“web”添加到“default”弹性缓存安全组。

这里进一步解释:http://docs.aws.amazon.com/AmazonElastiCache/latest/UserGuide/CacheSecurityGroup.html

而且,尝试使用这两种宝石:

https://github.com/mperham/dalli

https://github.com/ktheory/dalli-elasticache

我使用的是后者,并因为它使用它的伟大工程自动发现节点。

+0

你可以告诉我们在config/initializers/session_store中使用什么代码。 rb和config/environments/production.rb与dalli-elasticache一起使用? –

+0

dalli-elasticache作品。我刚刚检查了Rails 4.2.5 –

相关问题