注册 登录  
 加关注
   显示下一条  |  关闭
温馨提示!由于新浪微博认证机制调整,您的新浪微博帐号绑定已过期,请重新绑定!立即重新绑定新浪微博》  |  关闭

Alex的博客

 
 
 

日志

 
 

分布式缓存系统memcached简介与实践  

2011-05-11 16:38:28|  分类: 编程 |  标签: |举报 |字号 订阅

  下载LOFTER 我的照片书  |

memcached是什么?

memcached是由Danga Interactive开发的,高性能的,分布式的内存对象缓存系统,用于在动态应用中减少数据库负载,提升访问速度。

memcached能缓存什么?

通过在内存里维护一个统一的巨大的hash表,Memcached能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。

memcached快么?

非常快。memcached使用了libevent(如果可以的话,在linux下使用epoll)来均衡任何数量的打开链接,使用非阻塞的网络I/O,对内部对象实现引用计数(因此,针对多样的客户端,对象可以处在多样的状态), 使用自己的页块分配器和哈希表, 因此虚拟内存不会产生碎片并且虚拟内存分配的时间复杂度可以保证为O(1).。

Danga Interactive为提升Danga Interactive的速度研发了memcached。目前,LiveJournal.com每天

已经在向一百万用户提供多达两千万次的页面访问。而这些,是由一个由web服务器和数据库服务器组成的集群完成的。memcached几乎完全放弃了任何数据都从数据库读取的方式,同时,它还缩短了用户查看页面的速度、更好的资源分配方式,以及memcache失效时对数据库的访问速度。

memcached的特点

memcached的缓存是一种分布式的,可以让不同主机上的多个用户同时访问, 因此解决了共享内存只能单机应用的局限,更不会出现使用数据库做类似事情的时候,磁盘开销和阻塞的发生。

memcached的使用

memcached服务器端的安装 (此处将其作为系统服务安装)

下载文件:memcached 1.2.1 for Win32 binaries (Dec 23, 2006)

1. 解压缩文件到

c:\memcached

2. 命令行输入

'c:\memcached\memcached.exe -d install'

3. 命令行输入

'c:\memcached\memcached.exe -d start'

该命令启动 memcached ,默认监听端口为 11211,通过 memcached.exe -h 可以查看其帮助。

.NET memcached client library

下载文件:https://sourceforge.net/projects/memcacheddotnet/

里面有.net1.1 和 .net2.0的两种版本 还有一个不错的例子。

应用

1. 将Commons.dll,ICSharpCode.SharpZipLib.dll,log4net.dll,Memcached.ClientLibrary.dll 等放到bin目录

2. 引用Memcached.ClientLibrary.dll

3. 代码

 namespace Memcached.MemcachedBench   {       using System;       using System.Collections;         using Memcached.ClientLibrary;          public class MemcachedBench         {            [STAThread]           public static void Main(String[] args)             {              string[] serverlist = { "10.0.0.131:11211", "10.0.0.132:11211" };                  //初始化池                SockIOPool pool = SockIOPool.GetInstance();                pool.SetServers(serverlist);                   pool.InitConnections = 3;                pool.MinConnections = 3;                pool.MaxConnections = 5;                   pool.SocketConnectTimeout = 1000;                pool.SocketTimeout = 3000;                   pool.MaintenanceSleep = 30;                pool.Failover = true;                   pool.Nagle = false;                pool.Initialize();                  // 获得客户端实例                MemcachedClient mc = new MemcachedClient();                mc.EnableCompression = false;                   Console.WriteLine("------------测   试-----------");                mc.Set("test", "my value");  //存储数据到缓存服务器,这里将字符串"my value"缓存,key 是"test"                  if (mc.KeyExists("test"))   //测试缓存存在key为test的项目               {                    Console.WriteLine("test is Exists");                    Console.WriteLine(mc.Get("test").ToString());  //在缓存中获取key为test的项目                }               else                {                    Console.WriteLine("test not Exists");                }                   Console.ReadLine();                   mc.Delete("test");  //移除缓存中key为test的项目                 if (mc.KeyExists("test"))                {                    Console.WriteLine("test is Exists");                    Console.WriteLine(mc.Get("test").ToString());                }               else                {                    Console.WriteLine("test not Exists");                }                Console.ReadLine();                               SockIOPool.GetInstance().Shutdown();  //关闭池, 关闭sockets            }        }   }  

4. 运行结果

  评论这张
 
阅读(93)| 评论(0)
推荐 转载

历史上的今天

评论

<#--最新日志,群博日志--> <#--推荐日志--> <#--引用记录--> <#--博主推荐--> <#--随机阅读--> <#--首页推荐--> <#--历史上的今天--> <#--被推荐日志--> <#--上一篇,下一篇--> <#-- 热度 --> <#-- 网易新闻广告 --> <#--右边模块结构--> <#--评论模块结构--> <#--引用模块结构--> <#--博主发起的投票-->
 
 
 
 
 
 
 
 
 
 
 
 
 
 

页脚

网易公司版权所有 ©1997-2018