ASP.NET使用Memcached
一、安装Memcached及Memcached配置和状态查询
要想使用Memcached做缓存首先需要安装Memcached服务,安装方法如下:
- memcached.exe下载
- 保存至相应路径
- 打开cmd命令行
- 输入memcached.exe保存的所在路径 –d install 回车
- 打开控制面板的程序与功能选项
- 打开和关闭windows功能,选择telnet客户端和服务端
- 在cmd命令行中输入telnet 127.0.0.1 11211
- 获得以下相关memcaced运行信息
- 打开系统的管理工具,查看服务
- 找到Memcached Server服务
- 运行框中输入regedit,打开注册表
- 找到HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\memcached Server
- 找到ImagePath项,值为"d:\memcached\memcached.exe" -d runservice,在后面加上-l 127.0.0.1 -m 3000 -c 2048
- 已经将最大内存修改成3000
- 在cmd命令行输入telnet 127.0.0.1 11211
返回如下的数据:
time: 1255537291 服务器当前的unix时间戳
total_items:
54
从服务器启动以后存储的items总数量
connection_structures:
19
服务器分配的连接构造数
version:
1.2.6
memcache版本
limit_maxbytes:
67108864
分配给memcache的内存大小(字节)
cmd_get:
1645
get命令(获取)总请求次数
evictions:
0
为获取空闲内存而删除的items数(分配给memcache的空间用满后需
要删除旧的items来得到空间分配给新的items)
total_connections:
19
从服务器启动以后曾经打开过的连接数
bytes:
248723
当前服务器存储items占用的字节数
threads:
1
当前线程数
get_misses:
82
总未命中次数
pointer_size:
32
当前操作系统的指针大小(32位系统一般是32bit)
bytes_read:
490982
总读取字节数(请求字节数)
uptime:
161
服务器已经运行的秒数
curr_connections:
18
当前打开着的连接数
pid:
2816
memcache服务器的进程ID
bytes_written:
16517259
总发送字节数(结果字节数)
get_hits:
1563
总命中次数
cmd_set:
54
set命令(保存)总请求次数
curr_items:
28
服务器当前存储的items数量
- 16.
在web项目下的Config文件夹中添加Memcached.config文件,文件内容如下
<?xml version="1.0" encoding="utf-8" ?>
<memcached-configuration xmlns="urn:memcached-configuration">
<master>
<memcached>
<server address="127.0.0.1" port="11211" />
<socket-pool minPoolSize="10" maxPoolSize="999" connectionTimeout="00:00:10" deadTimeout="00:02:00" />
</memcached>
</master>
</memcached-configuration>
Address主机号
Port端口号
使用注册表修改端口号:
- 17.
在项目中引入Enyim.Caching.dll文件,Enyim.Caching.dll会读取项目下Config文件夹下的Memcached.config文件
程序中引入
using Enyim.Caching;
using
Enyim.Caching.Memcached;
- 18.
获取缓存客户端实例
MemcachedClient mc = MemcachedClient.CacheClient
mc.FlushAll() 清理缓存
mc.KeyExists(key.ToLower())
判断key是否存在
mc.Get<Value>(key.ToLower())
根据key获取value
- 19.
帮助类如下
public class MemcacheDictionary<Value>
{
private MemcachedClient mc = MemcachedClient.CacheClient;
public
MemcacheDictionary()
{
mc.FlushAll();
}
public bool Exists(string key)
{
return
mc.KeyExists(key.ToLower());
}
public Value Get(string key)
{
if (key == null)
return
default(Value);
return
mc.Get<Value>(key.ToLower());
}
public List<Value>
GetAll(string CacheKeyPrefix)
{
List<string>
keys = mc.Get_Keys(CacheKeyPrefix);
List<Value> data = new List<Value>();
var fromcache = mc.Get_Multi(keys);
foreach (string
key in keys)
{
if
(fromcache.ContainsKey(key.ToLower()))
data.Add((Value)fromcache[key.ToLower()]);
}
return data;
}
public List<Value>
GetAll()
{
List<string>
keys = mc.Get_Keys();
List<Value>
data = new List<Value>();
var fromcache = mc.Get_Multi(keys);
foreach (string
key in keys)
{
if
(fromcache.ContainsKey(key.ToLower()))
data.Add((Value)fromcache[key.ToLower()]);
}
return data;
}
public void
Set(string key, Value value)
{
mc.Store(StoreMode.Set,
key.ToLower(), value);
}
public void
Set(string key, Value value, DateTime expiresAt)
{
mc.Store(StoreMode.Set,
key.ToLower(), value, expiresAt);
}
public void
Set(string key, Value value, TimeSpan validFor)
{
mc.Store(StoreMode.Set,
key.ToLower(), value, validFor);
}
public bool
Remove(string key)
{
return mc.Remove(key.ToLower());
}
public void
RemoveAll(string CacheKeyPrefix)
{
List<string>
keys = mc.Get_Keys(CacheKeyPrefix);
keys.ForEach(key => mc.Remove(key.ToLower()));
}
public List<string> GetAllKeyList()
{
return mc.Get_Keys();
}
}
ASP.NET使用Memcached的更多相关文章
- ASP.Net MVC4+Memcached+CodeFirst实现分布式缓存
ASP.Net MVC4+Memcached+CodeFirst实现分布式缓存 part 1:给我点时间,允许我感慨一下2016年 正好有时间,总结一下最近使用的一些技术,也算是为2016年画上一个完 ...
- ASP.NET版Memcached监控工具(转载)
在上一篇文章<使用Memcached提高.NET应用程序的性能>中周公讲述如何在.NET中使用Memcached来提高.NET应用程序的性 能.在实际的使用中有可能出现Memcached因 ...
- ASP.NET中MEMCACHED
一,准备 你需要有一下软件: VS.NET(05/08) SQLSERVER memcached服务器端以及客户端类库(开源软件,下载即可)其中,客户 ...
- ASP.NET使用Memcached高缓存实例的初级介绍
Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提供动态.数据库驱动网站的速度.Memcached ...
- 在windows10上创建ASP.NET mvc5+Memcached服务
感谢两位两位大佬: https://blog.csdn.net/l1028386804/article/details/61417166 https://www.cnblogs.com/running ...
- 高性能的分布式内存对象缓存系统Memcached
Memcached概述 什么是Memcached? 先看看下面几个概念: Memory:内存存储,不言而喻,速度快,对于内存的要求高,不指出的话所缓存的内容非持久化.对于CPU要求很低,所以常常采 ...
- Memcached安装配置最大使用内存
Memcached安装配置最大使用内存 项目做了很多,虽然用memcached的项目也有很多.但是没有太关注安装memcached细节问题 最近做了一个项目,把很多东西都放到memcached缓存中, ...
- 在ASP.Net MVC 中如何实现跨越Session的分布式TempData
Hi,guys!Long time no see! 1.问题的引出 我相信大家在项目中都使用过TempData,TempData是一个字典集合,一般用于两个请求之间临时缓存数据或者页面之间传递消息.也 ...
- 窥探ASP.Net MVC底层原理 实现跨越Session的分布式TempData
1.问题的引出 我相信大家在项目中都使用过TempData,TempData是一个字典集合,一般用于两个请求之间临时缓存数据或者页面之间传递消息.也都知道TempData是用Session来实现的,既 ...
随机推荐
- 69个经典Spring面试题和答案
Spring 是个java企业级应用的开源开发框架.Spring主要用来开发Java应用,但是有些扩展是针对构建J2EE平台的web应用.Spring 框架目标是简化Java企业级应用开发,并通过PO ...
- 树莓派系统介绍:DIetPi
项目主页:http://fuzon.co.uk/phpbb/viewtopic.php?f=8&t=6 当前版本:V34(15年4月16日发布) DietPi是国外一个基于Raspbian的精 ...
- Table
Table tb = new Table();TableRow r = new TableRow(); TableCell c = new TableCell();c.Text = "Sta ...
- Google 地图 API V3 之事件
Google官方教程: Google 地图 API V3 使用入门 Google 地图 API V3 针对移动设备进行开发 Google 地图 API V3 之事件 Google 地图 API V3 ...
- webpack-dev-server
webpack-dev-server是一个小型的node.js Express服务器,它使用webpack-dev-middleware中间件来为通过webpack打包生成的资源文件提供Web服务.它 ...
- scp命令详解
\ svn 删除所有的 .svn文件 find . -name .svn -type d -exec rm -fr {} \; linux之cp/scp命令+scp命令详解 名称:cp 使用权限: ...
- 搭建一个简单struts2框架的登陆
第一步:下载struts2对应的jar包,可以到struts官网下载:http://struts.apache.org/download.cgi#struts252 出于学习的目的,可以把整个完整的压 ...
- C和指针 第六章 指针6.2 6.3字符串中查找的两个版本
int find_char(char **strings, char ch) { char *string; while ((string = *strings++) != NULL) { while ...
- C和指针 第四章 习题
4.1正数的n的平方根可以通过: ai+1= (ai + n / ai ) / 2 得到,第一个a1是1,结果会越来越精确. #include <stdio.h> int main() { ...
- 听说你们要开始学C了
同学们好: 先自我介绍一下,我是你们的助教吴喆(厚颜无耻地要求大家叫我吉吉老师:-D),本科学的电子,所以陆陆续续接触了不少C/C++的工作,曾经被编码折磨得死去活来,如今却对其念念不舍,颇有点“斯德 ...