memcached简介及java使用方法
来源:互联网 发布:7级野猪骑士升级数据 编辑:程序博客网 时间:2024/05/27 00:49
一、 概念
Memcached是danga.com(运营LiveJournal的技术团队)开发的一套分布式内存对象缓存系统,用于在动态系统中减少数据库负载,提升性能。
二、 适用场合
1. 分布式应用。由于memcached本身基于分布式的系统,所以尤其适合大型的分布式系统。
2. 数据库前段缓存。数据库常常是网站系统的瓶颈。数据库的大并发量访问,常常造成网站内存溢出。当然我们也可以使用Hibernate的缓存机制。但memcached是基于分布式的,并可独立于网站应用本身,所以更适合大型网站进行应用的拆分。
3. 服务器间数据共享。举例来讲,我们将网站的登录系统、查询系统拆分为两个应用,放在不同的服务器上,并进行集群,那这个时候用户登录后,登录信息如何从登录系统服务器同步到查询系统服务器呢?这时候,我们便可以使用memcached,登录系统将登录信息缓存起来,查询系统便可以获得登录信息,就像获取本地信息一样。
三、 不适用场合
那些不需要“分布”的,不需要共享的,或者干脆规模小到只有一台服务器的应用,memcached不会带来任何好处,相反还会拖慢系统效率,因为网络连接同样需要资源
四、 安装
这里介绍windows环境的安装。
1. 下载memcache的windows稳定版,解压放某个盘下面,比如在c:\memcached
2. 在cmd下输入 'c:\memcached\memcached.exe -d install'安装
3. 再输入: 'c:\memcached\memcached.exe -d start'启动。
以后memcached将作为windows的一个服务每次开机时自动启动。这样服务器端已经安装完毕了。
五、 客户端
Memcached本身是使用C开发的,客户端可以是php、C#、或者java。我是做java的,所以这里只介绍基于java的客户端。
我在网上看到基于java的客户端有两个
1. java_memcached-release_2.6.3
1) 简介
这是比较通用的Memcached客户端框架。具体原创不详。
2) 依赖的jar
A. commons-pool-1.5.6.jar
B. java_memcached-release_2.6.3.jar
C. slf4j-api-1.6.1.jar
D. slf4j-simple-1.6.1.jar
2. alisoft-xplatform-asf-cache-2.5.1
1) 简介
这个东东是阿里软件的架构师岑文初进行封装的。里面的注释都是中文的,比较好。
2) 依赖的jar
A. alisoft-xplatform-asf-cache-2.5.1.jar
B. commons-logging-1.0.4.jar
C. hessian-3.0.1.jar
D. log4j-1.2.9.jar
E. stax-api-1.0.1.jar
F. wstx-asl-2.0.2.jar
六、使用memcached缓存java bean自定义对象
Memcached可以缓存String,也可以缓存自定义java bean。但必须是可序列化的java bean(implements Serializable即可)
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- memcached简介及java使用方法
- java“块”的研究
- 2-3-4树
- 云渲染从入门到精通
- C++实现反射机制(二)
- 正则表达式 基础认识
- memcached简介及java使用方法
- AtomicInteger简介
- override equals后也要override hashcode方法,否则hashmap,hashset,hashtable这三个集合中的操作会出问题。 (其他情况下,不重写hashcode没)
- 学习Cinder——建立Cinder工程
- 设计一种100%可用性服务的架构--适用于任何系统(B/S,C/S)[中英文版本]
- [Erlang]配置文件读取方式(ETS,BEAM)性能研究
- MySQL 存储过程传参数实现where id in('40288c81494f088601494f92938d0002,40288c81494f088601494f92938d0012,')示例
- 轻松玩转Java配置的Classpath
- 装饰者模式总结