庄周梦蝶

生活、程序、未来
   :: 首页 ::  ::  :: 聚合  :: 管理

xmemcached发布1.0版本

Posted on 2009-03-13 22:07 dennis 阅读(1883) 评论(2)  编辑  收藏 所属分类: javamy open-source
    xmemcached发布1.0稳定版,下载地址这里
    相比于1.0-beta版本,这个released版本的主要改进如下:
1、xmemcached跟yanf4j都是默认采用common-logging,你可以使用log4j,也可以默认使用jdk的日志库。1.0添加了log4j的配置和依赖包。log4j的性能比jdk自带的日志库性能好多了。

2、添加了BufferAllocator接口,用于分配ByteBufferWrapper,ByteBufferWrapper顾名思义就是ByteBuffer的包装接口,因此BufferAllocator就是ByteBuffer的分配器,有两个实现:SimpleBufferAllocator,直接调用ByteBuffer.allocate(capacity)方法,不做任何缓存;一个是CachedBufferAllocator,采用ThreadLocal缓存ByteBuffer,避免重复创建,如果你对mina熟悉的话,这个概念没什么特别的。默认xmemcached采用的是SimpleBufferAllocator,你可以通过XMemcachedClient的构造方法设置想要采用的BufferAllocator:

public XMemcachedClient(BufferAllocator allocator) throws IOException;
//其他重载构造函数


    经过测试,采用CachedBufferAllocator并没有带来显著的性能提升,需要更多测试,慎用。

3、允许设置网络参数,在多个memcached节点的情况下,强烈推荐将网络层的读线程数(处理OP_READ)设置为接近节点数(具体还是要看场景测试,因为读线程数本质上是启动了一个线程池来处理读事件,太大也会影响效率):
    //XMemcachedClient的getDefaultConfiguration静态方法,获取默认配置
    public static Configuration getDefaultConfiguration() {
        Configuration configuration 
= new Configuration();
        configuration.setTcpRecvBufferSize(TCP_RECV_BUFF_SIZE);
        configuration.setSessionReadBufferSize(READ_BUFF_SIZE);
        configuration.setTcpNoDelay(TCP_NO_DELAY);
        configuration.setReadThreadCount(READ_THREAD_COUNT);
        
return configuration;
    }

    使用方法:
 Configuration conf=XMemcachedClient.getDefaultConfiguration();
  //设置读线程数为节点数,更多设置方法请参见Configuration类                       
 conf.setReadThreadCount(5);

 XMemcachedClient mc = new XMemcachedClient(
                    conf,
new CachedBufferAllocator());
 mc.addServer(ip1, port1);
 mc.addServer(ip2, port2);
 mc.addServer(ip3,port3);
 mc.addServer(ip4,port4);
 mc.addServer(ip5,port5);


4、修复一系列发现的bug,如Command返回结果需要设置成原子引用、更严格的方法参数检查、提示信息的友好、日志的优化、操作超时的时候取消操作等,重构部分代码

5、提供了javadoc文档,这里下载。



评论

# re: xmemcached发布1.0版本  回复  更多评论   

2009-03-14 11:30 by it
不错。。。。。。。

# re: xmemcached发布1.0版本  回复  更多评论   

2009-04-12 01:23 by risk
有问题请教博主,我重新用jdk1.5 编译后,不把成jar包,能正常运行,但一打成jar包后,就出现下面这个错误:
Exception in thread "main" java.lang.NoSuchMethodError: net.spy.memcached.transcoders.Transcoder.encode(Ljava/lang/Object;)Lnet/spy/memcached/transcoders/CachedData;
at net.rubyeye.xmemcached.XMemcachedClient.sendStoreCommand(XMemcachedClient.java:759)
at net.rubyeye.xmemcached.XMemcachedClient.set(XMemcachedClient.java:490)
at org.ce.fast.test.XMemcachedClientTest.main(XMemcachedClientTest.java:17)

只有注册用户登录后才能发表评论。


网站导航: