我一直试图使用ElastiCache客户端和localhost上安装的memcached服务器,但没有成功。生产中的webapp在AWS环境中运行,但在开发期间,我想在本地memcached服务器上使用相同的ElastiCache客户端jar。我目前正在回退使用spymemcached客户端jar进行开发。
我想避免使用不同的jar重新编译应用程序以进行生产和开发。有没有办法配置ElastiCache客户端以供localhost使用?
答案 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;
}
}