将AWS ElastiCache客户端用于本地memcached服务器

时间:2014-02-11 23:30:47

标签: java amazon-elasticache

我一直试图使用ElastiCache客户端和localhost上安装的memcached服务器,但没有成功。生产中的webapp在AWS环境中运行,但在开发期间,我想在本地memcached服务器上使用相同的ElastiCache客户端jar。我目前正在回退使用spymemcached客户端jar进行开发。

我想避免使用不同的jar重新编译应用程序以进行生产和开发。有没有办法配置ElastiCache客户端以供localhost使用?

1 个答案:

答案 0 :(得分:2)

我刚刚尝试过同样的事情,我想我已经开始工作了。看看Amazon's MemcachedClient的构造函数。您需要将clientMode设置为ClientMode.Static以连接到正常的memcached服务器或ClientMode.Dynamic以使用自动发现连接到ElastiCache。根据您使用的构造函数,您可以将ConnectionMactory传递给clientMode设置为static,或者您可以传入一个不包含“.cfg。”的地址。

我正在使用Spring,所以我创建了一个扩展MemcachedClientFactoryBean的类来在connectionFactory上设置clientMode。

<bean id="memcachedClient" class="au.com.mycompany.MyMemcachedClientFactoryBean">
    <property name="servers" value="${memcached.server}"/>
    <property name="protocol" value="BINARY"/>
    <property name="transcoder">
      <bean class="net.spy.memcached.transcoders.SerializingTranscoder">
        <property name="compressionThreshold" value="1024"/>
      </bean>
    </property>
    <property name="opTimeout" value="1000"/>
    <property name="timeoutExceptionThreshold" value="1998"/>
    <property name="hashAlg">
        <value type="net.spy.memcached.DefaultHashAlgorithm">KETAMA_HASH</value>
    </property>
    <property name="locatorType" value="CONSISTENT"/> 
    <property name="failureMode" value="Redistribute"/>
    <property name="useNagleAlgorithm" value="false"/>
  </bean>

这是我的FactoryBean

package au.com.mycompany;

import net.spy.memcached.AddrUtil;
import net.spy.memcached.ClientMode;
import net.spy.memcached.ConnectionFactoryBuilder;
import net.spy.memcached.MemcachedClient;
import net.spy.memcached.spring.MemcachedClientFactoryBean;

public class MyMemcachedClientFactoryBean extends MemcachedClientFactoryBean {
    private final ConnectionFactoryBuilder connectionFactoryBuilder = new ConnectionFactoryBuilder();
    private String servers;

    @Override
    public Object getObject() throws Exception {
        if (servers.contains("127.0.0.1")) {
           connectionFactoryBuilder.setClientMode(ClientMode.Static);
        } else {
           connectionFactoryBuilder.setClientMode(ClientMode.Dynamic);
        }
        return new MemcachedClient(connectionFactoryBuilder.build(), AddrUtil.getAddresses(servers));
    }

    @Override
    public void setServers(final String newServers) {
        this.servers = newServers;
    }
}