该帖已经被评为良好帖
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
作者 | 正文 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2009-03-04
最后修改:2009-04-28
xmemcached发布1.0-beta,从0.60直接到1.0-beta,主要改进如下: 更多信息参考这里
1、xmemcached是什么?
基于java nio实现的memcached客户端API。 实际上是基于我实现的一个简单nio框架 http://code.google.com/p/yanf4j/的基础上实现的(目前是基于yanf4j 0.54),序列化机制直接挪用spymemcached的Transcoder。 性 能方面与spymemcached相比各有优势,spymemcached在windows和linux两个平台上的效率差异很大(特别是容器类大对象的 读写上),而xmemcached就没有这个问题,如果你的get操作远远多于存储操作,那么xmemcached对于get的优化在并发下的效果更加明 显。 当 前1.0-beta版本,支持memcached的分布式(余数哈希和一致性哈希算法)。目前已经支持get、set、add、replace、cas、 append、prepend、批量get/gets、delete、incr、decr、version这几个协议。API为阻塞模型,而非 spymemcached的异步模型,异步模型在批处理的时候有优势,但是阻塞模型在编程难度和使用上会容易很多。 后续计划: 1.0 正式稳定版 1.1 着重性能优化
2、为什么叫xmemcached? 因为我在厦门(XM)混饭...... 3、xmemcached的下载和使用 项目主页:http://code.google.com/p/xmemcached/ 下载地址:http://code.google.com/p/xmemcached/downloads/list wiki地址:http://code.google.com/p/xmemcached/w/list 下载的压缩包中包括了依赖库、源码和打包后的jar,放到项目的lib目录下即可使用。
使用:
import net.rubyeye.xmemcached.XMemcachedClient; ...... ...... //XMemcachedClient是线程安全的,可以被多线程使用 XMemcachedClient client= new XMemcachedClient(ip, port); //存储操作 if (!client.set("hello", 0, "dennis")){ System.err.println("set error"); } client.add("hello", 0, "dennis"); client.replace("hello", 0, "dennis"); //get操作 String name=(String)client.get("hello"); //批量获取 List<String> keys=new ArrayList<String>(); keys.add("hello"); keys.add("test"); Map<String,Object> map=client.get(keys); //delete操作 if (!client.delete("hello",1000)){ System.err.println("delete error"); } //incr,decr操作 client.incr("a",4); client.decr("a",4); //查看memcached版本 String version=client.version(); client.shutdown();
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2009-03-04
对yanf4j很感兴趣
Reactor 好像就是cindy的那个 我记得cindy里就是Reactor单线程处理注册事件,dispatcher事件,外部通过将感兴趣的事件加到Reactor的interestQueue里,由Reactor在beforeSelect时读取并注册,感兴趣的事件被触发交给另一个线程处理(filterChain) 也就是说cindy是1个dispatcher线程,1个workers线程,workers可以自己扩展(加个线程池什么的),说的不对的地方还请指出 我想问下yanf4j的线程模型,呵呵,这样看代码时能快点,o(∩_∩)o... |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2009-03-04
最后修改:2009-03-05
bachmozart 写道 对yanf4j很感兴趣
Reactor 好像就是cindy的那个 我记得cindy里就是Reactor单线程处理注册事件,dispatcher事件,外部通过将感兴趣的事件加到Reactor的interestQueue里,由Reactor在beforeSelect时读取并注册,感兴趣的事件被触发交给另一个线程处理(filterChain) 也就是说cindy是1个dispatcher线程,1个workers线程,workers可以自己扩展(加个线程池什么的),说的不对的地方还请指出 我想问下yanf4j的线程模型,呵呵,这样看代码时能快点,o(∩_∩)o... yanf4j的线程模型是Selector.select跟OP_WRITE的处理共用一个线程,而OP_READ是可配置,默认是一个线程,也就是select、OP_READ和OP_WRITE的处理是1:1的配置,而对于message的派发默认是没有dispacher这个概念的,派发要多线程还是就是原read线程取决于应用层。yanf4j就是在cindy2.x的基础上改的,揉和一些grizzly的想法(如使用临时selector阻塞读写)和我想要的功能,做了大幅度简化,只提供非阻塞模型。 |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2009-03-04
最后修改:2009-03-04
哦 这个是你写的呀 呵呵 太好了 你qq号告诉我吧 多多向你请教
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2009-03-04
bachmozart 写道 对yanf4j很感兴趣
Reactor 好像就是cindy的那个 我记得cindy里就是Reactor单线程处理注册事件,dispatcher事件,外部通过将感兴趣的事件加到Reactor的interestQueue里,由Reactor在beforeSelect时读取并注册,感兴趣的事件被触发交给另一个线程处理(filterChain) 也就是说cindy是1个dispatcher线程,1个workers线程,workers可以自己扩展(加个线程池什么的),说的不对的地方还请指出 我想问下yanf4j的线程模型,呵呵,这样看代码时能快点,o(∩_∩)o... cindy里面的workers应该默认是1,具体数量是可配置的。在内部实现中,是一个worker线程数组()来对Dispatcher分发的任务进行处理的。 mina的线程模型其实跟cindy差不多,IoAcceptor采用executor线程池方式来调度worker线程,负责与客户端建立连接以及创建Session。IoProcessor也采用线程池方式,其worker线程负责轮询selector,如果当前的key可读取,则读取数据,并触发filterChain的messageRecevie方法(如果没有进行线程池扩展,所有的filter和IoHandler的messageRecv方法都在worker中被执行)。同时,IoProcessor还负责flush待发送数据的Session。 呵呵,yanf4j没有研究过,不好意思,感觉有点跑题了。权当冒个泡,别管我,大家继续! PS:楼上的,难得遇到还有cindy的粉丝,幸会啊。Cindy当年是何等辉煌,国人在sf的骄傲啊。个人感觉完全强于mina的前身netty。自从Roger Chen去了HP,ms就停止了对cindy的维护。反观netty,被apache招安后,改名mina,作者都已经连续参加两届JavaOne了。 |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2009-03-06
支持原创,开源,和性能改进。
spymemcached之前在部分项目中的hibernate缓存有用, 性能不错, 对集群支持很好。 希望楼主继续推出对集群的支持。 |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2009-03-06
最新测试结果,xmemcached发布0.60版本
测试1:开N个线程读写删各10000次,key是String,Value是Integer,数据单位皆为TPS
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2009-03-06
LZ的贴图是用什么工具画的?
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2009-03-07
pandonix 写道 LZ的贴图是用什么工具画的?
图表网 http://www.tubiao.net/ |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
发表时间:2009-03-07
linux下的测试报告
翠花,上图,首先是容器类和自定义对象的get、set在不同并发下的表现 |
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
返回顶楼 | |||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||