ASP.NET使用Memcached高缓存实例

Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载。它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提供动态、数据库驱动网站的速度。Memcached作为缓存技术的解决方案,已经是众所周知了;现在很多WEB应用都在使用它——包括一些知名的网站。若你还不知道这些,请在阅读之前先了解一下。 在ASP.NET中使用Memcached,有很多文章都有介绍,以下是我个人的使用经验。 一,准备 你需要有一下软件: VS.NET(05/08) SQLSERVER memcached服务器端以及客户端类库(开源软件,下载即可) 下载地址:HERA 其中,客户端类库包括以下几个DLL: Memcached.ClientLibrary.dll ICSharpCode.SharpZipLib.dll log4net.dll 二,安装memcached服务器端 将memcached.exe复制到任意目录下,如 c:,在命令行输入: memcached.exe -d install memcached将作为一个服务常驻系统内存了 三,建立ASP.NET工程 创建一个ASP.NETWEB项目,命名为MMCWEB,添加以上提到的几个客户端类库的引用。 四,配置 memcached使用了log4net,所以我们先配置log4net 在web.config里找到configSections节点,添加以下内容
再在configSections节点之外,增加以下内容: 启动调试,若没出现配置的出错提示,并且在网站目录下有文件夹LogFiles,就说明log4net配置成功了。 五,初始化SockIOPool SockIOPool是什么东东?SockIOPool是Memcached客户端提供的一个套接字连接池,通俗讲,就是与Memcached服务器端交换数据的对象。SockIOPool在应用程序启动时初始化一次就可以了,我把这个工作放在 GLOBAL.ASAX.CS的Application_Start方法里 char[] separator = { ',' }; string[] serverlist = ConfigurationManager.AppSettings["Memcached.ServerList"].Split(separator); // initialize the pool for memcache servers try { SockIOPool pool = SockIOPool.GetInstance(); pool.SetServers(serverlist); pool.InitConnections = 3; pool.MinConnections = 3; pool.MaxConnections = 50; pool.SocketConnectTimeout = 1000; pool.SocketTimeout = 3000; pool.MaintenanceSleep = 30; pool.Failover = true; pool.Nagle = false; pool.Initialize(); } catch (Exception err) { //这里就可以用Log4Net记录Error啦! } 注意AppSettings["Memcached.ServerList"]是在WEB.CONFIG里设置的,所以WEB.CONFIG的appSettings的子节点里需要有以下一行 启动调试服务器,若没有出错的日志记录,说明IO连接池已经开辟成功。 六,使用Memcached 终于进入正题了,不过使用之前,我们还需要准备一些数据。 创建一个实体类People,并加上Serializable属性!!! 对应的数据库里,增加一张表,字段对应实体类,插入一些测试数据。持久层和业务层的设计就略过了,他们负责向提供一些数据,返回类型可自定,若ILIST,DATASET。 Memcached使用起来就很简单了,比如后台检索出一组People类型的数据,放在一个叫peopleList的arraylist里,而且这个arraylist要频繁使用,只需要这样 MemcachedClient mc = new MemcachedClient(); mc.EnableCompression = true; mc.Set(key, peopleList); 上面的key是用来访问这个arraylist的键,Memcached里的数据都是保存为键-值对的。 一旦mc.KeyExists(key)为TRUE,就用return mc.Get(key) as ArrayList提取数据,删除时,使用 return mc.Delete(key);等等。可以自己琢磨了。 下面是操作数据库的一个示例: protected void Page_Load(object sender, EventArgs e)   {   string[] serverlist = new string[] { "127.0.0.1:11211" };   string poolName = "MemcacheIOPool";   SockIOPool pool = SockIOPool.GetInstance(poolName);   //设置连接池的初始容量,最小容量,最大容量,Socket 读取超时时间,Socket连接超时时间   pool.SetServers(serverlist);   pool.InitConnections = 1;   pool.MinConnections = 1;   pool.MaxConnections = 500;   pool.SocketConnectTimeout = 1000;   pool.SocketTimeout = 3000;   pool.MaintenanceSleep = 30;   pool.Failover = true;   pool.Nagle = false;   pool.Initialize();//容器初始化   //实例化一个客户端   MemcachedClient mc = new MemcachedClient();   mc.PoolName = poolName;   mc.EnableCompression = false;   string key = "user_info";//key值   object obj = new object();   if (mc.KeyExists(key)) //测试缓存中是否存在key的值   {   obj = mc.Get(key);   User user2 = (User)obj;   Response.Write(" " + user2.Name + "," + user2.Pwd + " ");   }   else {   string conStr = System.Configuration.ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;   SqlConnection conn = new SqlConnection(conStr);   conn.Open();   string sql = "Select * From T_User Where id=1";   SqlCommand cmd = new SqlCommand(sql, conn);   SqlDataReader dr = cmd.ExecuteReader();   User user = new User();   while (dr.Read())   {   user.Name = dr["name"].ToString();   user.Pwd = dr["pwd"].ToString();   }   dr.Close();   conn.Close();   mc.Set(key, user, System.DateTime.Now.AddMinutes(2)); //存储数据到缓存服务器,这里将user这个对象缓存,key 是"user_info1"   Response.Write(" 姓名:" + user.Name + ",密码:" + user.Pwd + " ");   }   }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值