`

Memcache初学之三 java客户端三种方式操作

 
阅读更多

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代码  收藏代码
  1. import com.danga.MemCached.MemCachedClient;  
  2. import com.danga.MemCached.SockIOPool;  
  3. import com.schooner.MemCached.MemcachedItem;  
  4.   
  5. public class MemcachedForJavaExample {  
  6.   
  7.     // create a static client as most installs only need  
  8.     // a single instance  
  9.     protected static MemCachedClient mcc = new MemCachedClient();  
  10.   
  11.     // set up connection pool once at class load  
  12.     static {  
  13.   
  14.         // server list and weights  
  15.         String[] servers = { "localhost:11211""localhost:11212""localhost:11213" };  
  16.   
  17.         Integer[] weights = { 332 };  
  18.   
  19.         // grab an instance of our connection pool  
  20.         SockIOPool pool = SockIOPool.getInstance();  
  21.   
  22.         // set the servers and the weights  
  23.         pool.setServers(servers);  
  24.         pool.setWeights(weights);  
  25.         pool.setHashingAlg(SockIOPool.CONSISTENT_HASH);  
  26.   
  27.         // set some basic pool settings  
  28.         // 5 initial, 5 min, and 250 max conns  
  29.         // and set the max idle time for a conn  
  30.         // to 6 hours  
  31.         pool.setInitConn(5);  
  32.         pool.setMinConn(5);  
  33.         pool.setMaxConn(250);  
  34.         pool.setMaxIdle(1000 * 60 * 60 * 6);  
  35.   
  36.         // set the sleep for the maint thread  
  37.         // it will wake up every x seconds and  
  38.         // maintain the pool size  
  39.         pool.setMaintSleep(30);  
  40.   
  41.         // set some TCP settings  
  42.         // disable nagle  
  43.         // set the read timeout to 3 secs  
  44.         // and don't set a connect timeout  
  45.         pool.setNagle(false);  
  46.         pool.setSocketTO(3000);  
  47.         pool.setSocketConnectTO(0);  
  48.   
  49.         // initialize the connection pool  
  50.         pool.initialize();  
  51.     }  
  52.   
  53.     public static void main(String[] args) {  
  54.         System.out.println("SET: " + mcc.set("key1""value1"));  
  55.         System.out.println("SET: " + mcc.set("key2""value2"));  
  56.         System.out.println("SET: " + mcc.set("key3""value3"));  
  57.         System.out.println("GET: " + mcc.get("key1"));  
  58.         MemcachedItem item = mcc.gets("key1");  
  59.         System.out.println("GETS: value=" + item.getValue() + ",CasUnique:"+item.getCasUnique());  
  60.         System.out.println("SET: " + mcc.set("key1""value1_1"));  
  61.         System.out.println("CAS: " + mcc.cas("key1""value1_2", item.getCasUnique())); //必须FALSE  
  62.         System.out.println("getMulti:" + mcc.getMulti(new String[]{"key1","key2","key3"}));  
  63.     }  
  64.   
  65. }  

 

  

分享到:
评论

相关推荐

    memcache学习资料(包含memcache和java_memcache相应的jar)

    `java_memcache`相关的JAR文件通常包含了Java Memcached客户端库,如Xmemcached或spymemcached,这些库提供了API,让Java开发者能够方便地在Java应用中集成和使用Memcached服务。 在Windows环境下部署和使用...

    memcached服务端已经多个客户端

    - "memcached客户端.rar": 这个文件可能包含不同编程语言的客户端库源代码或者预编译的二进制文件,供开发者在他们的应用程序中连接和操作memcached服务。 - "memcached服务端.rar": 提供了memcached服务端的软件包...

    Memcache资料合集

    1. **Java客户端**:如spymemcached、xmemcached等,提供了与Java应用交互的API,方便进行缓存操作。 2. **连接池管理**:使用连接池管理Memcache连接,提高并发处理能力,减少资源消耗。 3. **异常处理**:合理处理...

    memcached_termkqh_memcache_

    4. 学习使用一种编程语言的客户端库与memcached交互。 5. 理解分布式缓存的实现机制,如一致性哈希。 6. 实践中调整memcached的配置参数,优化性能。 7. 学习如何处理数据的持久化和备份,以防止数据丢失。 8. 研究...

    memcachedtest

    在这个测试程序中,开发者可能正在验证Java客户端与Memcached服务器之间的交互。 描述中的"java memcachedtest demo"表明这是一个Java实现的Memcached测试示例。开发者可能创建了一个简单的应用,以演示如何在Java...

    memcache详解

    **Memcached详解** Memcached是一种高性能、分布式内存对象缓存系统,它被广泛应用于Web应用中,用于减轻数据库负载,提高...无论你是初学者还是经验丰富的开发者,这个“memcache详解”都能为你提供有价值的信息。

    ehcachememcacheredis三大缓存男高音.pdf

    【标题】:“ehcache、memcache、redis 三大缓存系统对比分析.pdf” 【描述】:本文将深入探讨三个广泛使用的缓存系统——Ehcache、Memcached 和 Redis,分析它们的特点、优缺点以及适用场景,帮助读者理解这三大...

    memcahched.zip

    2. **windows 64**:这表明压缩包内包含的是适合于 Windows 64 位操作系统的 memcached 安装或客户端工具。 3. **client**:指的是 memcached 的客户端,允许应用程序与 memcached 服务器进行通信,存取数据。 4. **...

    spymemcached-2.7.3应用的演示工程

    而`spymemcached`是Java社区广泛使用的Memcached客户端库之一,版本2.7.3是一个稳定且功能丰富的版本。本篇将深入探讨`spymemcached-2.7.3`在实际应用中的关键知识点,并通过`spymemcacheddemo`项目进行演示。 1. *...

    Redis新手入门详解.pdf

    在Redis中,键(key)总是字符串类型,而值(value)可以是五种基本类型之一:字符串(string)、列表(list)、集合(set)、有序集合(sorted set)和哈希表(hash)。字符串类型的值可以包含任何数据,如JPEG图像...

    memcached教程.PPT.笔记.软件

    - **其他语言支持**:Memcached还支持Python、Java、Ruby、C++等多种语言的客户端,方便不同环境下的开发。 4. **最佳实践** - **缓存策略**:合理设置TTL,避免数据过于频繁地在数据库和缓存之间切换。 - **...

Global site tag (gtag.js) - Google Analytics