缓存应用--Memcached分布式缓存简介
一. 什么是Memcached
Memcached 是一个高性能的分布式内存 对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象 来减少读取数据库的次数,从而提供动态、数据库驱动网站的速度。
相信很多人都用过缓存,在 .net 中也有内置的缓存机制,还有很多第三方工具如apache,nginx等可以做静态资源的缓存,同时我们也可 以制定自己的缓存机制,缓存数据库查询的数据以减少对数据库的频繁操作。但是很多时候我们总是感觉这些缓存总不尽人意, Memcached可以解决你不少的烦恼问题。 最少在我的学习中解决了我不少问题,所以决定记录下来分享。
Memcached基于一 个存储键/值对的hashmap。其守护进程是用C写的,但是客户端可以用任何语言来编写(本文使用C#作为例子),并通过memcached协议与守护进程通信。可 能这些东西都太高深了,我们暂不做研究。
二. 分布式缓存
其实 Memcached作为一个分布式缓存数据服务,但是每个服务之间根本没有进行相互通信,这里可能与 我理解的分布式有点区别,可能是我才疏学浅,也可能是每个人思考问题的角度不同。Memcached 客户端就是通过一种分布式算法将数据保存到不同的Memcached服务器上,将数据进行缓存。分布 式缓存,可以而知memcached可以进行大数据量的缓存。这点可以弥补我们之前很多人都遇到的将 数据缓存到应用服务器上,而且只能缓存少量数据,否则对应用服务器的影响非常大。
Memcached应用机制图:
这个图是有点简陋了,但是问题还是能够描述的清楚的,缓存机制的基本原理就是先查询数据保存到memcached中,地址在此请求就直接从Memcached缓存中取数据,这样就可以减少对服务器请求压力。
三. Memcached 特征
(1) 协议简单: 不使用复杂的xml格式,而是使用文本格式
(2) 基于libevent的事件处理机制 (不懂)
(3) 内置内存存储方式: 数据存在在内存中,所以重启机器会导致数据丢失
(4)Memcached相互不通信的分布式: Memcached 服务器之间不会进行通信,数据都是通过客户端的分布式算法存储到各个服务器中
四. Memcached的安装
首先这里是在windows系统上做测试,Memcached在linux等非windows平台上性能会更高。
下载Memcached 服务端: http://memcached.org/ (官网寻找适用的版本)
1 解压缩文件到D:\Program Files\Memcached
2 命令行输入 D:\Program Files\Memcached\memcached.exe -d install
3 命令行输入 D:\Program Files\Memcached\memcached\memcached.exe -d start,该命令启动 Memcached ,默认监听端口为 11211
当然我们可以在windows 服务中查看到此此服务:

五 .NET 平台下使用Memcached
因为个人首先接触的客户端是memcacheddotnet ,所以习惯了适用这个核心库作为客户端。下载的工作都非常简单,因为客户端都帮我们实现了分布式程序算法,我们关心的只要怎样去存在获取这些数据。下面简单介绍一下:
1 static void Main(string[] args)
2 {
3 SockIOPool pool = SockIOPool.GetInstance();
4 string[] servers = { "127.0.0.1:11211" };
5 pool.SetServers(servers);
6 pool.MinConnections = 3;
7 pool.MaxConnections = 5;
8 pool.InitConnections = 3;
9 pool.SocketConnectTimeout = 5000;
10 pool.Initialize();
11
12 MemcachedClient client = new MemcachedClient();
13 client.EnableCompression = false;
14 Console.WriteLine("-----------------------Memcached Set 设置值--------------------------");
15 client.Set("key1","value1");
16 Console.WriteLine(client.Get("key1"));
17 Console.WriteLine("-----------------------Memcached Add 设置值--------------------------");
18 client.Add("key2","value2");
19 Console.WriteLine(client.Get("key2"));
20 client.Set("key2","value1 value2");
21 Console.WriteLine(client.Get("key2"));
22 Console.WriteLine("-----------------------Memcached Replace 设置值--------------------------");
23 client.Replace("key2", "value3");
24 Console.WriteLine(client.Get("key2"));
25
26 Console.WriteLine("-----------------------Memcached 键值是否存在--------------------------");
27 if (client.KeyExists("key2"))
28 {
29 Console.WriteLine("键key2 存在");
30 }
31 if (client.KeyExists("hechen")==false)
32 {
33 Console.WriteLine("键hechen 不存在");
34 }
35
36 Console.WriteLine("-----------------------Memcached 删除数据--------------------------");
37 client.Add("key4","value4");
38 Console.WriteLine("key4==>" + client.Get("key4"));
39 client.Delete("key4");
40 if (!client.KeyExists("key4"))
41 {
42 Console.WriteLine("key4 已将删除");
43 }
44
45 Console.WriteLine("-----------------------Memcached 数据过期--------------------------");
46 client.Add("key5","value5",DateTime.Now.AddMilliseconds(5000));
47 Console.WriteLine(client.Get("key5"));
48 System.Threading.Thread.Sleep(6000);
49 Console.WriteLine("过期: "+ client.Get("key5"));
50 }
上面的例子虽然简单,包括一些基本的用法,在一般使用Memcached缓存数据的时候都用得到。
Memcached 初始化数据
SockIOPool pool = SockIOPool.GetInstance();
string[] servers = { "127.0.0.1:11211" };
pool.SetServers(servers);
pool.MinConnections = 3;
pool.MaxConnections = 5;
pool.InitConnections = 3;
pool.SocketConnectTimeout = 5000;
pool.Initialize();
SockIOPool 用于初始化分布式缓存池的对象,上面设置了多种属性,我相信这些属性的意思大家都懂。这里要注意的是Initialize () ,只有调用这个方式之后,才能初始化数据。才能使用连接缓存池。
Memcached 设置缓存值的三种方式
MemcachedClient client = new MemcachedClient();
client.EnableCompression = false;
Console.WriteLine("-----------------------Memcached Set 设置值--------------------------");
client.Set("key1","value1");
Console.WriteLine(client.Get("key1"));
Console.WriteLine("-----------------------Memcached Add 设置值--------------------------");
client.Add("key2","value2");
Console.WriteLine(client.Get("key2"));
client.Set("key2","value1 value2");
Console.WriteLine(client.Get("key2"));
Console.WriteLine("-----------------------Memcached Replace 设置值--------------------------");
client.Replace("key2", "value3");
Console.WriteLine(client.Get("key2"));
有心的可以测试一下这三个方法: Set () 如果缓存中存在相同的键值这替换原有的,Add() 只是添加数据,如果存在相同键的不再添加。 Replace() 则用于替换已有的相同的键值。
1 Console.WriteLine("-----------------------Memcached 数据过期--------------------------");
2 client.Add("key5","value5",DateTime.Now.AddMilliseconds(5000));
3 Console.WriteLine(client.Get("key5"));
4 System.Threading.Thread.Sleep(6000);
5 Console.WriteLine("过期: "+ client.Get("key5"));
很多时候我们并不希望数据永久缓存,一般都会有一个过期时间。上面的添加缓存数据就设置了缓存时间,可以达到过期缓存的效果。
案例下载地址 点击下载
此篇文章到此结束,内容比较简单,而且很多都是别人写过的东西。不过为了个人的学习还是积累起来,对于缓存部分后续文章继续更新。
转自:http://www.cnblogs.com/qingyuan/archive/2011/01/17/1937855.html
缓存应用--Memcached分布式缓存简介的更多相关文章
- Memcached 分布式缓存实现原理简介
摘要 在高并发环境下,大量的读.写请求涌向数据库,此时磁盘IO将成为瓶颈,从而导致过高的响应延迟,因此缓存应运而生.无论是单机缓存还是分布式缓存都有其适应场景和优缺点,当今存在的缓存产品也是数不胜数, ...
- Memcached分布式缓存初体验
1 Memcached简介/下载/安装 Memcached是一个高性能的不是内存对象缓存系统,用于动态Web应用以减轻数据库负载.Memcached基于一个存储键/值对的HashMap.其客户端可以使 ...
- Memcached 分布式缓存实现原理
摘要 在高并发环境下,大量的读.写请求涌向数据库,此时磁盘IO将成为瓶颈,从而导致过高的响应延迟,因此缓存应运而生.无论是单机缓存还是分布式缓存都有其适应场景和优缺点,当今存在的缓存产品也是数不胜数, ...
- memcached分布式缓存
1.memcached分布式简介 memcached虽然称为“分布式”缓存服务器,但服务器端并没有“分布式”功能.Memcache集群主机不能够相互通信传输数据,它的“分布式”是基于客户端的程序逻辑算 ...
- Discuz!NT中集成Memcached分布式缓存
大约在两年前我写过一篇关于Discuz!NT缓存架构的文章,在那篇文章的结尾介绍了在IIS中如果开启多个应用程序池会造成多个缓存实例之间数据同步的问题.虽然给出了一个解决方案,但无形中却把压力转移到了 ...
- Memcached 分布式缓存系统部署与调试
Memcache 分布式缓存系统部署与调试 工作机制:通过在内存中开辟一块区域来维持一个大的hash表来加快页面访问速度,和数据库是独立的;目前主要用来缓存数据库的数据;存放在内存的数据通过LRU算法 ...
- memcached分布式缓存系统
在数据驱动的Web开发中,经常要重复从数据库中取出相同的数据,这种重复极大的增加了数据库负载.缓存是解决这个问题的好办法.但是ASP.NET中的虽然已经可以实现对页面局部进行缓存,但还是不够灵活.此时 ...
- 【开源项目系列】如何基于 Spring Cache 实现多级缓存(同时整合本地缓存 Ehcache 和分布式缓存 Redis)
一.缓存 当系统的并发量上来了,如果我们频繁地去访问数据库,那么会使数据库的压力不断增大,在高峰时甚至可以出现数据库崩溃的现象.所以一般我们会使用缓存来解决这个数据库并发访问问题,用户访问进来,会先从 ...
- [Memcached]分布式缓存系统Memcached在Asp.net下的应用
Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度.Memcached ...
随机推荐
- j-query j-query
jQuery 1.安装:http://jquery.com/download/登陆这个jQuery下载2在.html文件的<head>标签中导入3 语法$(selector).acti ...
- silverlight 退出系统(关闭当前网页),通过调用JS
确认后直接退出系统,关闭当前页面 页面部分: <HyperlinkButton x:Name="LinkExit" Style="{StaticResource L ...
- sql分类及基本sql操作,校对规则(mysql学习笔记二)
sql针对操作对象分为不同语言 数据操作(管理)语言 DML或者将其细分为 ( 查询 DQL 管理(增,删,改) DML) 数据定义语言(对保存数据的格式进行定义) DDL 数据库控制语言(针对数 ...
- Material Design:CollapsingToolbarLayout
activity_main.xml: <android.support.design.widget.CoordinatorLayout xmlns:android="http://sc ...
- 开源web终端ssh解决方案-gateone简介
好久都没来写博客,最近忙啥去了呢? 一是忙于saltstack的二次开发,二是云计算的学习研究中,所以就一直没写东西,今天给大家介绍个工具. 1. 首先来说一下为什么要 web ssh? 许多人不是说 ...
- 【easyui】—easyui教你编写一个前台的架子
以前做项目都是在别人搭建好的环境下直接编写单独的页面,也没有处理过怎么搭建一个框架.看到别人的布局都挺好的,自己也想做一个走一下流程. 嘿,刚开始时看着别人写的代码,去找怎么写. 这是我自己的想法,使 ...
- jQuery学习笔记(3)
children():只考虑子元素而不考虑其他后代元素 <html xmlns="http://www.w3.org/1999/xhtml"> <head run ...
- SHOW SLAVE STATUS几个常见参数
--显示当前读取的Master节点二进制日志文件和文件位置,对应线程I/O thread Master_Log_File: mysql-bin.000011 Read_Master_Log_Pos: ...
- Multi-Language IDE for Professional Developers (Komodo)
Komodo is the professional IDE for major web languages, including Python, PHP, Ruby, Perl, HTML, CSS ...
- Mybatis 的日志管理
Mybatis通过日志工厂提供日志信息,Mybatis内置的日志模版是log4j,commons.log,jdk log也可以通过slf4j简单日志模版结合log4j使用日志信息输出.具体选择哪个日志 ...
