首页服务器Web服务器 Memcached简介_动力节点Java学院整理

Memcached简介_动力节点Java学院整理

Memcached是danga.com(运营LiveJournal的技术团队)开发的一套分布式内存对象缓存系统,用于在动态系统中减少数据库负载,提升性能。 适用场合 1.分布式应用。由于memcached本身…

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的客户端有两个:

1.javamemcached-release2.6.3

①简介

这是比较通用的Memcached客户端框架。具体原创不详。
②依赖的jar

  • commons-pool-1.5.6.jar
  • javamemcached-release2.6.3.jar
  • slf4j-api-1.6.1.jar
  • slf4j-simple-1.6.1.jar

2.alisoft-xplatform-asf-cache-2.5.1

①简介

这个东东是阿里软件的架构师岑文初进行封装的。里面的注释都是中文的,比较好。

②依赖的jar

  • alisoft-xplatform-asf-cache-2.5.1.jar
  • commons-logging-1.0.4.jar
  • hessian-3.0.1.jar
  • log4j-1.2.9.jar
  • stax-api-1.0.1.jar
  • wstx-asl-2.0.2.jar

范例

基于javamemcached-release2.6.3

package com.bjpowernode.memcached.cache;import java.util.Date;import com.danga.MemCached.MemCachedClient;import com.danga.MemCached.SockIOPool;public class MyCache {  public static void main(String[] args) {    MemCachedClient client=new MemCachedClient();    String [] addr ={"127.0.0.1:11211"};    Integer [] weights = {3};    SockIOPool pool = SockIOPool.getInstance();    pool.setServers(addr);    pool.setWeights(weights);    pool.setInitConn(5);    pool.setMinConn(5);    pool.setMaxConn(200);    pool.setMaxIdle(1000*30*30);    pool.setMaintSleep(30);    pool.setNagle(false);    pool.setSocketTO(30);    pool.setSocketConnectTO(0);    pool.initialize();//   String [] s =pool.getServers();    client.setCompressEnable(true);    client.setCompressThreshold(1000*1024);//   将数据放入缓存    client.set("test2","test2");//   将数据放入缓存,并设置失效时间    Date date=new Date(2000000);    client.set("test1","test1", date);//   删除缓存数据//   client.delete("test1");//   获取缓存数据    String str =(String)client.get("test1");    System.out.println(str);  }}
本文来自网络,不代表1号站长-站长学院|资讯交流平台立场。转载请注明出处: https://www.1cn.cc/fwq/web/3280.html
上一篇git自定义_动力节点Java学院整理
下一篇 CentOS Yum编译安装MySQL 5.6
admin

作者: admin

这里可以再内容模板定义一些文字和说明,也可以调用对应作者的简介!或者做一些网站的描述之类的文字或者HTML!

为您推荐

评论列表()

    联系我们

    联系我们

    0898-88888888

    在线咨询: QQ交谈

    邮箱: email@wangzhan.com

    工作时间:周一至周五,9:00-17:30,节假日休息

    关注微信
    微信扫一扫关注我们

    微信扫一扫关注我们

    关注微博
    返回顶部