设为首页 收藏本站
查看: 2541|回复: 0

[经验分享] Memcache初学之三 java客户端三种方式操作

[复制链接]

尚未签到

发表于 2017-4-16 10:56:27 | 显示全部楼层 |阅读模式
Memcached 客户端程序
    Memcached的java客户端已经存在三种了:
 一、官方提供的基于传统阻塞io由Greg Whalin维护的客户端    memcached client for java
 二、Dustin Sallings实现的基于java nio的Spymemcached      spymemcached
 三、XMemcached      xmemcached
 
 三种API比较 
 
  1 ) memcached client for java
  较早推出的memcached JAVA客户端API,应用广泛,运行比较稳定。
  
         2) spymemcached
  A simple, asynchronous, single-threaded memcached client written in java. 支持异步,单线程的      memcached客户端,用到了java1.5版本的concurrent和nio,存取速度会高于前者,但是稳定性不好,测试中常 报timeOut等相关异常。
  
         3) xmemcached
  XMemcached同样是基于java nio的客户端,java nio相比于传统阻塞io模型来说,有效率高(特别在高并发下)和资源耗费相对较少的优点。传统阻塞IO为了提高效率,需要创建一定数量的连接形成连接 池,而nio仅需要一个连接即可(当然,nio也是可以做池化处理),相对来说减少了线程创建和切换的开销,这一点在高并发下特别明显。因此 XMemcached与Spymemcached在性能都非常优秀,在某些方面(存储的数据比较小的情况下)Xmemcached比 Spymemcached的表现更为优秀,具体可以看这个Java Memcached Clients Benchmark。
  
  Memcached java client
  
Memcached java client是官方推荐的最早的memcached java客户端。最新版本:java_memcached-release_2.6.1。
官方下载地址:https://github.com/gwhalin/Memcached-Java-Client

采用阻塞式SOCKET通讯,据说目前版本进行了很多优化,性能有所提高(只看过1.5的源代码,还没来及看最新的)
提供key方式的连接池,默认连接池key为default。(老版本了)。2.6.1版本支持apache-commoms-pool作为连接池。
支持权重配置。
后期的版本提增加了cas支持和getMutl功能
官方示例代码
 
Java代码   DSC0000.png


  • import com.danga.MemCached.MemCachedClient;  
  • import com.danga.MemCached.SockIOPool;  
  • import com.schooner.MemCached.MemcachedItem;  
  •   
  • public class MemcachedForJavaExample {  
  •   
  •     // create a static client as most installs only need  
  •     // a single instance  
  •     protected static MemCachedClient mcc = new MemCachedClient();  
  •   
  •     // set up connection pool once at class load  
  •     static {  
  •   
  •         // server list and weights  
  •         String[] servers = { "localhost:11211""localhost:11212""localhost:11213" };  
  •   
  •         Integer[] weights = { 332 };  
  •   
  •         // grab an instance of our connection pool  
  •         SockIOPool pool = SockIOPool.getInstance();  
  •   
  •         // set the servers and the weights  
  •         pool.setServers(servers);  
  •         pool.setWeights(weights);  
  •         pool.setHashingAlg(SockIOPool.CONSISTENT_HASH);  
  •   
  •         // set some basic pool settings  
  •         // 5 initial, 5 min, and 250 max conns  
  •         // and set the max idle time for a conn  
  •         // to 6 hours  
  •         pool.setInitConn(5);  
  •         pool.setMinConn(5);  
  •         pool.setMaxConn(250);  
  •         pool.setMaxIdle(1000 * 60 * 60 * 6);  
  •   
  •         // set the sleep for the maint thread  
  •         // it will wake up every x seconds and  
  •         // maintain the pool size  
  •         pool.setMaintSleep(30);  
  •   
  •         // set some TCP settings  
  •         // disable nagle  
  •         // set the read timeout to 3 secs  
  •         // and don't set a connect timeout  
  •         pool.setNagle(false);  
  •         pool.setSocketTO(3000);  
  •         pool.setSocketConnectTO(0);  
  •   
  •         // initialize the connection pool  
  •         pool.initialize();  
  •     }  
  •   
  •     public static void main(String[] args) {  
  •         System.out.println("SET: " + mcc.set("key1""value1"));  
  •         System.out.println("SET: " + mcc.set("key2""value2"));  
  •         System.out.println("SET: " + mcc.set("key3""value3"));  
  •         System.out.println("GET: " + mcc.get("key1"));  
  •         MemcachedItem item = mcc.gets("key1");  
  •         System.out.println("GETS: value=" + item.getValue() + ",CasUnique:"+item.getCasUnique());  
  •         System.out.println("SET: " + mcc.set("key1""value1_1"));  
  •         System.out.println("CAS: " + mcc.cas("key1""value1_2", item.getCasUnique())); //必须FALSE  
  •         System.out.println("getMulti:" + mcc.getMulti(new String[]{"key1","key2","key3"}));  
  •     }  
  •   
  • }  

  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-365231-1-1.html 上篇帖子: Java开发中的Memcache原理及实现 【转】 下篇帖子: memcache通过telnet连接 命令
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表