`

Memcached学习笔记 — 第四部分:Memcached Java 客户端-gwhalin(5)-主要API解析

 
阅读更多

 

找了很久都找不到官方的APIdoc,木有办法,只有看源代码整理个。

SocketIOPool


主要负责客户端连接池,通讯和定位。2.6.0后的版本是由schooner重新实现的,只是保持了API接口没有改变,新的实现是:com.schooner.MemCached.SchoonerSockIOPool

public static SockIOPool getInstance()
获得连接池的单态方法。这个方法有一个重载方法getInstance( String poolName ),每个poolName只构造一个SockIOPool实例。缺省构造的poolName是default。

public void setServers( String[] servers )
设置连接池可用的cache服务器列表

public void setWeights( Integer[] weights )
设置连接池可用cache服务器的权重,与servers对应,建议有多少太服务器就相应设置多少个权重值,否则可以不设置,默认都是1:1对应。

public void setInitConn( int initConn )
设置开始时每个cache服务器的可用连接数

public void setMinConn( int minConn )
设置每个服务器最少可用连接数

public void setMaxConn( int maxConn )
设置每个服务器最大可用连接数

public void setMaxIdle( long maxIdle )
设置可用连接池的最长等待时间

public void setMaintSleep( long maintSleep )
设置连接池维护线程的睡眠时间,设置为0,维护线程不启动

public void setNagle( boolean nagle )
设置是否使用Nagle算法,因为我们的通讯数据量通常都比较大(相对TCP控制数据)而且要求响应及时,因此该值需要设置为false(默认是true)

public void setSocketTO( int socketTO )
设置socket的读取等待超时值

public void setSocketConnectTO( int socketConnectTO )
设置socket的连接等待超时值

public void setAliveCheck( boolean aliveCheck )
设置连接心跳监测开关。设为true则每次通信都要进行连接是否有效的监测,造成通信次数倍增,加大网络负载,因此该参数应该在对HA要求比较高的场合设为TRUE,默认状态是false。

public void setFailback( boolean failback )
设置连接失败恢复开关,设置为TRUE,当宕机的服务器启动或中断的网络连接后,这个socket连接还可继续使用,否则将不再使用,默认状态是true,建议保持默认。

public void setFailover( boolean failover )
设置容错开关,设置为TRUE,当当前socket不可用时,程序会自动查找可用连接并返回,否则返回NULL,默认状态是true,建议保持默认。

public void setHashingAlg( int alg )
设置服务器定位算法:
1.    使用String.hashCode()获得hash code,该方法依赖JDK,可能和其他客户端不兼容,建议不使用
2.    使用original 兼容hash算法,兼容其他客户端
3.    使用CRC32兼容hash算法,兼容其他客户端,性能优于original算法
4.    使用一致性HASH算法
采用前三种hash算法的时候,查找cache服务器使用余数方法。采用最后一种是一致性HASH,也是默认算法。

public void initialize()
设置完pool参数后最后调用该方法,启动pool。

public void shutdown
释放连接池pool,释放资源。

MemCachedClient主要方法

 

add方法

public boolean add(String key, Object value)
public boolean add(String key, Object value, Integer hashCode)
public boolean add(String key, Object value, Date expiry)
public boolean add(String key, Object value, Date expiry, Integer hashCode)
将数据添加到cache服务器,如果保存成功则返回true
如果cache服务器存在同样key,则返回false
add有4个重载方法,key和value是必须的参数,还有过期时间,hash码两个可选参数
注意:
1.    官方协议支持的是UNIX DATE或当前时间秒的偏移量,这里的API支持的是是java.util.Date。
2.    hashCode是用于客户端分布式定位的自定义hashCode值。可以不用设置,客户端会根据设置的算法,计算key的hashCode来定位。

set方法

public boolean set(String key, Object value)
public boolean set(String key, Object value, Date expiry)
public boolean set(String key, Object value, Date expiry, Integer hashCode)
设置key对应的缓存,缓存中是否存在都可以使用。
有3个重载,key和value是必须的。过期时间和hashCode是可选。

replace方法

public boolean replace(String key, Object value)
public boolean replace(String key, Object value, Integer hashCode)
public boolean replace(String key, Object value, Date expiry)
public boolean replace(String key, Object value, Date expiry, Integer hashCode)
将数据替换cache服务器中相同的key,如果保存成功则返回true,如果缓存不存在,会返回false,请注意add/set/replace的微妙区别。

append/prepend

public boolean append(String key, Object value)
public boolean append(String key, Object value, Integer hashCode)
public boolean prepend(String key, Object value)
public boolean prepend(String key, Object value, Integer hashCode)
append表示在现有缓存前添加数据,生成新的缓存;prepend表示在现有缓存后添加数据,生成新的缓存。
分别提供2个重载。设置成功返回true,其它或Key不存在返回false。

get方法

public Object get(String key)
public Object get(String key, Integer hashCode)

get方法从cache服务器获取一个数据,没有提供独立的读取超时,是通过SocketIOPool. setSocketTO(int socketTO)统一设置的。

gets方法

public MemcachedItem gets(String key)
public MemcachedItem gets(String key, Integer hashCode)
gets出来会返回缓存值外,还会返回当前缓存的版本号,一般是用于协同CAS完成原子操作使用。

getMulti方法

public Map<String, Object> getMulti(String[] keys)
public Map<String, Object> getMulti(String[] keys, Integer[] hashCodes)
public Map<String, Object> getMulti(String[] keys, Integer[] hashCodes, boolean asString)
使用getMulti方法从cache服务器获取一组数据,get方法的数组实现,输入参数keys是一个key数组,返回是一个map。

getMultiArray方法

public Object[] getMultiArray(String[] keys)
public Object[] getMultiArray(String[] keys, Integer[] hashCodes)
public Object[] getMultiArray(String[] keys, Integer[] hashCodes, boolean asString)
返回缓存的数组。

CAS方法

public boolean cas(String key, Object value, long casUnique)
public boolean cas(String key, Object value, Date expiry, long casUnique)
public boolean cas(String key, Object value, Date expiry, Integer hashCode, long casUnique)
原子设置缓存操作,通过版本号casUnique保证设置的唯一性,如果发现服务器的缓存版本与传入的不同,则放弃设置缓存,返回false。请参见前面协议详解。

Count计数相关方法

public boolean storeCounter(String key, long counter)
public boolean storeCounter(String key, Long counter)
public boolean storeCounter(String key, Long counter, Integer hashCode)

public long getCounter(String key)
public long getCounter(String key, Integer hashCode)

public long incr(String key)
public long incr(String key, long inc)
public long incr(String key, long inc, Integer hashCode)
public long decr(String key)
public long decr(String key, long inc)
public long decr(String key, long inc, Integer hashCode)

public long addOrIncr(String key)
public long addOrIncr(String key, long inc)
public long addOrIncr(String key, long inc, Integer hashCode)
public long addOrDecr(String key)
public long addOrDecr(String key, long inc)
public long addOrDecr(String key, long inc, Integer hashCode)
1.    使用storeCounter方法初始化一个计数器
2.    使用getCounter方法获取当前的计数器值
3.    使用incr方法对计数器增量操作,只有一个key的方法默认加1。
4.    使用decr对计数器减量操作,只有一个key的方法默认减1。
5.    addOrIncr,addOrDecr:key存在则与incr和decr相同,不存在则相当于storeCounter

setPrimitiveAsString方法

public void setPrimitiveAsString( boolean primitiveAsString )
设置cache数据的原始类型存储方式是String,默认值是false,只有在确定cache的数据类型是string的情况下才设为true,这样可以加快处理速度。

setDefaultEncoding方法

public void setDefaultEncoding( String defaultEncoding )
当primitiveAsString为true时使用的编码转化格式,默认值是utf-8,如果确认主要写入数据是中文等非ASCII编码字符,建议采用GBK等更短的编码格式

分享到:
评论

相关推荐

    Memcached学习笔记 — 第四部分:Memcached Java 客户端-gwhalin(1)-介绍及使用

    本篇学习笔记将重点介绍如何在Java环境中使用gwhalin提供的Memcached客户端进行开发。gwhalin的Memcached Java客户端是一个轻量级、高性能的库,使得Java开发者可以轻松地与Memcached服务器进行交互。 ### 一、...

    java_memcached-release_2.5.1.jar Memcache java jar 包

    Java Memcached客户端库由Danga Interactive开发,该公司是Memcached的主要贡献者之一。"danga MemCached"标签可能指的是这个特定版本的客户端库与Danga Interactive的工作有关。`MemCachedManager.java`可能是库中...

    java-memcached-2.6.6.jar

    java-memcached-2.6.6.jar

    java_memcached-release_2.6.6.zip

    memcache客户端jar包: 1,java_memcached-release_2.6.6.jar 2,commons-pool-1.5.6.jar 3,slf4j-api-1.6.1.jar 4,slf4j-simple-1.6.1.jar

    memcached-1.2.1-win32.zip 和 java_memcached-release_1.6.zip

    `memcached-1.2.1-win32.zip` 提供了Memcached服务端,而`java_memcached-release_1.6.zip` 提供了Java客户端,使得开发者能够轻松地在Java环境中集成和使用Memcached。学习和掌握这些资源,将有助于构建更加快速、...

    java_memcached-release_2.6.3.rar 客户端所有包

    - `java_memcached-release_2.6.3.jar`:这是Java Memcached客户端的主要库,包含客户端接口和实现。 - `slf4j-api-1.6.0.jar`:Simple Logging Facade for Java (SLF4J)是一个日志抽象层,允许用户在部署时插入所...

    memcached安装及java应用使用memcached

    虽然描述部分是空的,但我们可以推测文章可能涵盖了安装memcached的基本步骤,以及Java开发者如何集成并利用memcached来提升应用性能。 **标签解析:** 1. **源码**:可能意味着文章会涉及memcached的源代码安装或...

    Memcached最新版Jar包

    Memcached最新版Jar包: spymemcached-2.11.6.jar spymemcached-2.11.6-javadoc.jar spymemcached-2.11.6-sources.jar https://github.com/dustin/java-memcached-client

    memcached linux安装说明+ java客户端调用例子

    在Linux系统上安装和配置memcached,并通过Java客户端进行调用是常见的操作流程,下面将详细介绍这一过程。 ### 一、memcached的Linux安装 1. **更新系统**: 首先确保你的Linux系统已经更新到最新版本,运行`sudo ...

    memcached的三种java客户端jar

    Memcached的java客户端已经存在三种了: 1.官方提供的基于传统阻塞io由Greg Whalin维护的客户端。 较早推出的memcached JAVA客户端API,应用广泛,运行比较稳定。 2.spymemcached,支持异步,单线程的memcached客户端...

    hibernate-memcached包

    **hibernate-memcached包** 是一个专为Hibernate框架设计的扩展,目的是将流行的分布式内存缓存系统Memcached整合到Hibernate中,作为其二级缓存解决方案。在大型分布式应用中,缓存技术是提高性能的关键,特别是...

    Memcached-Java-Client-release_2.6.1.zip

    - Memcached-Java-Client是Java开发者与Memcached进行交互的主要工具,它提供了简单易用的API接口,允许开发者方便地在Java应用中存取缓存数据。 - 版本2.6.1是该客户端的一个稳定版本,包含了一系列优化和改进,...

    java_memcached-release_2.5.1

    每一次对于客户端的性能提升,总会给服务集成平台性能带来不小的影响,但是每一次优化速度后,客户端可以优化的空间越来越小,这时候需要一些策略来配合,提升应用整体性能。当前主要采用了以下几点策略:

    java_memcached-release_2.6.3.zip

    Java Memcached 客户端是Java开发者用于与Memcached分布式内存缓存系统交互的一个库。在版本2.6.3中,它提供了高效且可靠的连接管理,以及对Memcached服务器的全面支持。这个压缩包“java_memcached-release_2.6.3....

    java memcached-session 配置

    Java Memcached-Session配置在Tomcat环境中主要用于将Web应用程序中的用户会话数据持久化到分布式缓存系统Memcached中,从而提高系统的可扩展性和性能。Memcached是一个高性能、分布式的内存对象缓存系统,用于在...

    memcached 完整的项目,服务端(win) 客户端 包括jar包

    4. **故障恢复**:当 Memcached 服务端宕机后,Java 客户端可能会遇到连接问题,需要有适当的重试机制。 总之,Memcached 项目为开发者提供了一个高效、易用的缓存解决方案,通过 Java 客户端可以轻松地在 Java ...

    MemCached开发java客户端的使用

    这是MemCached的java客户端连接使用的例子,里面包含了MemCached的增删改查操作,对字符串 list set map 对象的操作等。看就会就入门了,

    Memcached学习笔记

    ### Memcached学习笔记 #### 一、Memcached简介 Memcached是一种高性能的分布式内存对象缓存系统,主要用于在动态应用程序中减少数据库负载,提高访问速度。最初由Danga Interactive为优化LiveJournal.com网站的...

    Memcached客户端手册

    本文主要介绍了Memcached的基本概念及其Java客户端库的使用方法,特别是针对`MemcachedClient`的接口定义、依赖配置以及配置文件的细节进行了详细解释。通过这些知识点的学习,读者可以更好地理解和掌握如何在实际...

Global site tag (gtag.js) - Google Analytics