java memcached delete_memcached简介及java使用方法

一、什么是Memcache

Memcache是一套分布式高速缓存系统,

分布式:即在多台服务器上安装Memcache服务,达到很好的集群效果

高速:即所有的数据都是在内存中的,它的读取速度高于我们的硬盘

2.Memcache有什么用?

当数据量大的时候,我们数据库的压力也大,Memcache的出现可以在我们的数据库和应用之间充当缓冲层

即我们在数据库中读取过的数据,在接下来的第二次,第三次就可以直接访问Memcache去读取数据,从而减轻数据库压力

3.怎么理解Memcache?

key value

4.使用场景?

1>非持久化存储:即对数据存储要求不高,悲观情况数据丢失不会对系统造成大影响——断电、重启

2>分布式存储:不适合单机使用——对内存消耗比较大;不要把数据库和Memcache放在一个机器

3>Key/Value存储:不支持List,Array数据格式,即value存储是数据的所有部分,不能再继续拆分

二、Memcached的安装

分为window和linux安装,请自行百度

三、Memcached的操作实现

Memcached是基于C开发的,客户端可以是php、java或者其他,此处已java为基础

从现有网络资料得知,java的客户端主要有2个

1.java_memcached-release  通用的Memcached客户端框架

2.alisoft-xplatform-asf-cache 阿里软件的架构师岑文初进行封装的

四、范例

1.基于java_memcached-releaseMemCachedClient client = new MemCachedClient();

String[] addr = {"127.0.0.1:11211"};

Integer[] weights = {10};

SockIOPool pool = SockIOPool.getInstance();

pool.setServers(addr);

pool.setWeights(weights);

pool.setInitConn(10);

pool.setMinConn(10);

pool.setMaxConn(200);

pool.setMaxIdle(1000*30*30);

pool.setMaintSleep(30);

pool.setNagle(false);

pool.setSocketTO(30);

pool.setSocketConnectTO(0);

pool.initialize();

//client.setCompressEnable(true);

//client.setCompressThreshold(1000*1024);

//将数据放入缓存

client.set("test", "test-------");

//设置失效时间

Date date = new Date(1000000);

client.set("test1", "test1++++",date);

//删除缓存

client.delete("test");

//获取缓存数据

String str = (String)client.get("test");

System.out.println(str);

2.基于alisoft-xplatform-asf-cache-

首先由个memcached.xml<?xml  version="1.0" encoding="UTF-8"?>

socketpool="pool_0">

com.alisoft.xplatform.asf.cache.memcached.MemcachedErrorHandler

failover="true" aliveCheck="true" initConn="5" minConn="5" maxConn="250"

nagle="false">

127.0.0.1:11211

然后测试如下:ICacheManager manager;

manager=CacheUtil.getCacheManager(IMemcachedCache.class, MemcachedCacheManager.class.getName());

manager.setConfigFile("memcached.xml");

manager.start();

try{

IMemcachedCache cache = manager.getCache("mclient_0");

cache.put("key", "value");

System.out.println(cache.get("key"));

}finally{

manager.stop();

}

五、使用memcached缓存Javabean自定义对象

Memcached可以缓存String,也可以缓存自定义java bean。但必须是可序列化的java bean(implements Serializable即可)

不再做具体演示

文章大部分转载自:http://blog.csdn.net/seelye/article/details/8511073

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值