1、实例化

MemcachedClient client = new XMemcachedClient();

public XMemcachedClient()
public XMemcachedClient(List<InetSocketAddress> addressList)
public XMemcachedClient(final String server, final int port)
public XMemcachedClient(final String host, final int port, int weight)
public XMemcachedClient(final InetSocketAddress inetSocketAddress, int weight)
public XMemcachedClient(final InetSocketAddress inetSocketAddress)
...

最简单的一个就是最后一个,比如

MemcachedClient cache = new XMemcachedClient(new InetSocketAddress("127.0.0.1", 11211));  

2、常用方法

2、1、add

public <T> boolean add(final String key, final int exp, final T value, final Transcoder<T> transcoder, final long timeout)
public <T> boolean add(final String key, final int exp, final T value, final Transcoder<T> transcoder)
public boolean add(final String key, final int exp, final Object value,final long timeout)
public boolean add(final String key, final int exp, final Object value)

第一个参数:键(key)。
第二个参数:过期时间(单位是秒)。
第三个参数:要设置缓存中的对象(value),如果没有则插入,如果有则修改。
第四个参数:通信编码方式。
第五个参数:超时时间。

2.2、set

public final <T> boolean set(String key, final int exp, final T value, final Transcoder<T> transcoder, final long timeout)
public final <T> boolean set(final String key, final int exp, final T value, final Transcoder<T> transcoder)
public final boolean set(final String key, final int exp, final Object value, final long timeout)
public final boolean set(final String key, final int exp, final Object value)

第一个参数:键(key)。
第二个参数:过期时间(单位是秒)。
第三个参数:要设置缓存中的对象(value),如果没有则插入,如果有则修改。
第四个参数:通信编码方式。
第五个参数:超时时间。

2.3、replace

public <T> boolean replace(final String key, final int exp, final T value, final Transcoder<T> transcoder, final long timeout)
public <T> boolean replace(final String key, final int exp, final T value,final Transcoder<T> transcoder)
public boolean replace(final String key, final int exp, final Object value,final long timeout)
public boolean replace(final String key, final int exp, final Object value)

第一个参数:键(key)。
第二个参数:过期时间(单位是秒)。
第三个参数:要设置缓存中的对象(value),如果没有则插入,如果有则修改。
第四个参数:通信编码方式。
第五个参数:超时时间。

2.4、get

public <T> T get(final String key, final long timeout, final Transcoder<T> transcoder)
public <T> T get(final String key, final long timeout)
public <T> T get(final String key, final Transcoder<T> transcoder)
public <T> T get(final String key)

第一个参数:键(key)
第二个参数:过期时间(单位是秒)
第三个参数:通信编码方式。

3、CAS(Check And Save)协议

基本原理就是:版本号,防止读写冲突。涉及到两个方法gets 和cas

3.1、gets

public <T> GetsResponse<T> gets(final String key, final long timeout, final Transcoder<T> transcoder)
public <T> GetsResponse<T> gets(final String key, final Transcoder transcoder)
public <T> GetsResponse<T> gets(final String key, final long timeout)
public <T> GetsResponse<T> gets(final String key)

参数同get方法,其中GetsResponse只有2个字段,一个value,另一个变量cas就是时间戳。

public final class GetsResponse<T> {
private final long cas;
private final T value;
...
//get and set
// equals and hascode
}

3.2、cas

public boolean cas(final String key, final int exp, final Object value,final long timeout, final long cas)
public boolean cas(final String key, final int exp, final Object value,final long cas) public <T> boolean cas(final String key, final int exp, final T value,final Transcoder<T> transcoder, final long cas)
public <T> boolean cas(final String key, final int exp,final CASOperation<T> operation, final Transcoder<T> transcoder)
public <T> boolean cas(final String key, final int exp,GetsResponse<T> getsReponse, final CASOperation<T> operation,final Transcoder<T> transcoder)
public <T> boolean cas(final String key, final int exp,GetsResponse<T> getsReponse, final CASOperation<T> operation)
public <T> boolean cas(final String key, GetsResponse<T> getsResponse,final CASOperation<T> operation)
public <T> boolean cas(final String key, final int exp,final CASOperation<T> operation)
public <T> boolean cas(final String key, final CASOperation<T> operation)
public <T> boolean cas(final String key, final int exp, final T value,final Transcoder<T> transcoder, final long timeout, final long cas)

4、例子

4。1、非cas方式

import net.spy.memcached.MemcachedClient;  

public class Test {
public static void main(String[] args) throws IOException {
MemcachedClient cache = new MemcachedClient(new InetSocketAddress("127.0.0.1", 11211)); cache.set("x", 1800, "Love"); String obj1 = (String) cache.get("x");
String obj2 = (String) cache.get("x");
obj2 = "Michael"; cache.set("x", 1800, obj2);
System.out.println("Non-CAS 2:\t" + obj2);
System.out.println("Non-CAS 1:\t" + obj1);
}
}

obj1!=obj2,出现读写不一致

4.2、使用cas方式

import java.io.IOException;
import java.net.InetSocketAddress; import net.spy.memcached.CASValue;
import net.spy.memcached.MemcachedClient; public class Test {
@SuppressWarnings("unchecked")
public static void main(String[] args) throws IOException {
MemcachedClient cache = new MemcachedClient(new InetSocketAddress("127.0.0.1", 11211)); cache.set("y", 1800, "Love"); CASValue casValue1 = cache.gets("y");
CASValue casValue2 = cache.gets("y");
cache.cas("y", casValue2.getCas(), casValue2.getValue()); System.out.println("CAS 2:\t" + casValue2.getCas());
System.out.println("Value 2:\t" + casValue2.getValue()); System.out.println("CAS 1:\t" + casValue1.getCas());
System.out.println("Value 1:\t" + casValue1.getValue());
}
}

参考:http://www.linuxidc.com/Linux/2011-12/49516.htm

Memcached基础的更多相关文章

  1. Memcached基础介绍

    1.memcached是什么,有什么作用? )memcached是一个开源的.高性能的内存的缓存软件,从名称上看mem就是内存的意思,而cache就是缓存的意思. )memcached通过在事先规划好 ...

  2. 分布式缓存技术memcached学习(二)——memcached基础命令

    上文<linux环境下编译memcahed>介绍了memcahed在linux环境下的安装以及登录,下面介绍memcahed的基本命令的使用. Add 功能:往内存增加一条新的缓存记录 语 ...

  3. Memcached基础知识

    主要内容: Memcached基本的工作原理 Memcached的两阶段哈希 Memcached的数据存储方式 Memcached新建Item分配内存过程 Memcached的数据过期方式 Memca ...

  4. Memcached 笔记与总结(1)Linux(CentOS 6.6) 和 Windows(7)下安装与配置 Memcached (1.4.24)与 Memcached 基础命令

    Memcached 官方网站:http://memcached.org/ 官网对其的描述是: What is Memcached? Free & open source, high-perfo ...

  5. (转)实战Memcached缓存系统(1)Memcached基础及示例程序

    1.Cache定义 (1)狭义概念:用于CPU的相对高速处理与主存(Main Memory)的相对低速处理的之间起到协调功能的硬件设备. (2)广义概念:用于速度相差较大的两种硬件之间,起到协调两者数 ...

  6. 分布式缓存技术memcached学习系列(二)——memcached基础命令

    上文<linux环境下编译memcahed>介绍了memcahed在linux环境下的安装以及登录,下面介绍memcahed的基本命令的使用. Add 功能:往内存增加一条新的缓存记录 语 ...

  7. 【 学习笔记 】memcached基础知识

    源地址:http://kb.cnblogs.com/page/42731/ 仔细学习了下,以下是记录的笔记备忘内容. 一.memcached是什么?    memcached是高性能的分布式内存缓存服 ...

  8. memcached完全剖析系列——一、memcached基础

    转自:http://blog.charlee.li/memcached-001/

  9. Memcached目录

    Memcached 简介.安装和基本使用 Memcached基础知识 理解Memcached的分布式 Memcached存储命令 - set Memcached存储命令 - add Memcached ...

随机推荐

  1. 【Python】iiacm_filemaker ——简易的.cpp文件创建即初始化脚本,ACMer专用

    代码已全部重写,上次写的真是不忍直视…… 今天刚刚接触Python,本着学以致用的原则,就写了一个按照要求自动生成.cpp文件并初始化头文件的脚本. 确定你的linux中安装了Python,将下面的代 ...

  2. 查询无序列表中第K小元素

    当需要在无需列表中寻找第k小的元素时,一个显然的方法是将所有数据进行排序,然后检索k个元素.这种方法的运行时间为O(n log(n)). 无序列表调用分区函数将自身分解成两个子表,其长度为i和n-i. ...

  3. 全国计算机等级考试二级教程-C语言程序设计_第9章_数组

    四维数组,可用于航天卫星,三维+时间 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> ...

  4. (转)IOS笔记 #pragma mark的用法

    简单的来说就是为了方便查找和导航代码用的.   下面举例如何快速的定位到我已经标识过的代码.     #pragma mark 播放节拍器 - (void) Run:(NSNumber *)tick{ ...

  5. POJ1042 Gone Fishing

    采用贪心策略. 假设他从1湖泊走到x 湖泊,这还剩下 h*12 - sigma(T1--Tx-1).(单位时间为5分钟).然后再用剩下的时间去钓1-x的湖泊的鱼. 每次都选择最多鱼的湖泊钓. code ...

  6. ContextMenuStrip 添加在窗体。点击右键不能显示问题解答

    ContextMenuStrip控件,系统默认为点击菜单,使用时.需要与你的窗体绑定.如图所示,,form窗体上包括一个contextMenustrip信息.默认状态是无.所以在使用contextMe ...

  7. 改良版的SQL Service 通用存储过程分页

    上次写了通用存储过程.感觉还是有很大的BUG.就是条件不能参数画化.这个BUG可以说是致命的.但是我一直想在用什么方法能解决这个东西.其实我只是想写少量的代码来做更多的事情.我想能不能传集合给存储过程 ...

  8. java.lang.IllegalStateException: Target host must not be null, or set in parameters. scheme=null, host=null, path=Aict/listPagedAict.action

    原因:请求的URL地址不完整,没有找到host. 排查解决:发现HTTP请求的URL少加了项目名,导致URL地址不完整.

  9. QF——iOS中数据持久化的几种方式

    数据持久化的几种方式: 一.属性列表文件: .plist文件是种XML文件.数组,字典都可以和它互相转换.数组和字典可以写入本地变成plist文件.也可以读取本地plist文件,生成数组或字典. 读取 ...

  10. what oop ?

    最近在做一个app的后台代码.......到底是什么是Oop ,没有感觉到啊,,,,,