设为首页 收藏本站
查看: 1760|回复: 0

[经验分享] Asp.Net使用Memcached以解决Cache的不稳定性

[复制链接]
累计签到:4 天
连续签到:1 天
发表于 2015-8-31 13:31:20 | 显示全部楼层 |阅读模式
  首先具备的条件就是你能够使用Memcached:
  1,你有一台缓存服务器能够配置linux+Memcached。
  2,你需要保存的数据量不是很大单机配置windows版的Memcached。点击下载
  其次你要找一个.net调用Memcached的api类:
  Memcached的主站有推荐,我现在用的是Memcached.ClientLibrary.dll。点击下载
  然后你找篇配置文件配起来就可以测试使用了。
  如果想使用我的类,具体方法参照我以前一篇文章,不过我已经将MyCache类扩展可以使用Memcached。
  自己设计的Cache自控制的简单方法
  配置文件需要增加几个参数
  <add key="default_buffminutes" value="45"/>
  <add key="Memcached" value="true"/>
  <add key="MemServer" value="192.168.1.160:11211"/>
  MyCache.cs是操作类,DelegateLists是委托方法函数,跟你需要的函数来定义。

DSC0000.gif DSC0001.gif MyCache.cs
DSC0002.gif using System;
using System.Web;
using System.Data;
using System.Web.Caching;
using System.Collections;
using Memcached.ClientLibrary;

/**//// <summary>
DSC0003.gif /// 搜集编写者losingrose
/// QQ:303864496
/// MSN:losingrose@21cn.com
/// http://losingrose.cnblogs.com
/// Cache操作类
DSC0004.gif /// </summary>
public static class MyCache
DSC0005.gif {
DSC0006.gif DSC0007.gif     /**//*
        DelegateLists.string_2fill del = new DelegateLists.string_2fill(bll.TopDormCo_Str);
        object[] prams = new object[2];
        prams[0] = "Products.aspx";
        prams[1] = "15";
        dorms.Text = MyCache.Cache_Select("Dorms" + MySecurity.QueryString("coid"), 0, del, prams).ToString();
DSC0008.gif     */
    static Cache cache = HttpContext.Current.Cache;
    public static bool Memcached = bool.Parse(System.Web.Configuration.WebConfigurationManager.AppSettings["Memcached"]);
    static MemcachedClient mc = new MemcachedClient();
    static double default_buffminutes = Convert.ToDouble(System.Web.Configuration.WebConfigurationManager.AppSettings["default_buffminutes"]);
    //static double default_buffminutes = 5;

    static MyCache()
    {
        //判断是否启动Memcached
        if (Memcached)
        {
            string server = System.Web.Configuration.WebConfigurationManager.AppSettings["MemServer"];
            String[] serverlist ={ server };
            // initialize the pool for memcache servers
            SockIOPool pool = SockIOPool.GetInstance("shenghuohui");
            pool.SetServers(serverlist);
            pool.Initialize();

            mc = new MemcachedClient();
            mc.PoolName = "shenghuohui";
            mc.EnableCompression = false;
        }
    }

    /**//// <summary>
    /// 取得目前Cache列表
    /// </summary>
    /// <returns></returns>
    public static string[] Cache_List()
    {
        string[] str = new string[cache.Count];
        int i = 0;
        foreach (DictionaryEntry item in cache)
        {
            str = item.Key.ToString();
            i++;
        }
        return str;
    }
    /**//// <summary>
    /// 添加一个新的Cache对象
    /// </summary>
    /// <param name="key">键名</param>
    /// <param name="value">待保存的值</param>
    /// <param name="buffminutes">缓存时间(按分钟计),为0则读取配置文件设定的时间</param>
    public static void Cache_Insert(string key, object value, double buffminutes)
    {
        if (Memcached)
        {
            if (buffminutes == 0)
                buffminutes = default_buffminutes;
            mc.Set(key, value,DateTime.Now.AddMinutes(buffminutes));
        }
        else
        {
            if (buffminutes == 0)
                buffminutes = default_buffminutes;
            cache.Insert(key, value, null, DateTime.Now.AddMinutes(buffminutes), TimeSpan.Zero);
        }
    }
    /**//// <summary>
    /// 移出一个Cache对象
    /// </summary>
    /// <param name="key">键名</param>
    public static void Cache_Remove(string key)
    {
        if (Memcached)
        {
            mc.Delete(key);
        }
        else
        {
            cache.Remove(key);
        }
    }
    /**//// <summary>
    /// 获取Cache对象,如果对象不存在,则调用相关事件委托填充并返回Cache的值。
    /// </summary>
    /// <param name="key">键名</param>
    /// <param name="buffminutes">缓存时间(按分钟计),为0则读取配置文件设定的时间</param>
    /// <param name="method">填充的方法委托</param>
    /// <param name="parms">方法所需要的参数列表</param>
    /// <returns>返回Cache的值</returns>
    public static object Cache_Select(string key, double buffminutes, Delegate method, params object[] parms)
    {
        object x;
        if (Memcached)
        {
            x=mc.Get(key);
            if(x==null)
            {
                if (buffminutes == 0)
                    buffminutes = default_buffminutes;
                object o = method.DynamicInvoke(parms);
                if (o != null)
                {
                    Cache_Insert(key, o, buffminutes);
                    x = o;
                }
                else
                    return method.DynamicInvoke(parms);
            }
        }
        else
        {
            x = cache.Get(key);
            if (x == null)
            {
                if (buffminutes == 0)
                    buffminutes = default_buffminutes;
                object o = method.DynamicInvoke(parms);
                if (o != null)
                {
                    Cache_Insert(key, o, buffminutes);
                    x = o;
                }
                else
                    return method.DynamicInvoke(parms);
            }
        }
        return x;
    }
    /**//// <summary>
    /// 直接获取Cache
    /// </summary>
    /// <param name="key">键名</param>
    /// <returns></returns>
    public static object Cache_Select(string key)
    {
        if (Memcached)
            return mc.Get(key);
        else
            return cache.Get(key);
    }
    /**//// <summary>
    /// 清楚所有Cache对象
    /// </summary>
    public static void Cache_Clear()
    {
        if (Memcached)
            mc.FlushAll();
        else
        {
            foreach (DictionaryEntry item in cache)
            {
                cache.Remove(item.Key.ToString());
            }
        }
    }
}
  

DelegateLists.cs
using System;
using System.Web;
using System.Data;
using System.Collections;

/**//// <summary>
/// 搜集编写者losingrose
/// QQ:303864496
/// MSN:losingrose@21cn.com
/// http://losingrose.cnblogs.com
/// 委托方法定义
/// </summary>
public class DelegateLists
{
    public delegate DataTable dataset_0fill();
    public delegate DataTable dataset_1fill(string a);
    public delegate DataTable dataset_2fill(string a, string b);
    public delegate DataTable dataset_3fill(string a, string b, string c);
    public delegate DataTable dataset_4fill(string a, string b, string c, string d);
    public delegate string string_0fill();
    public delegate string string_1fill(string a);
    public delegate string string_2fill(string a, string b);
    public delegate string string_3fill(string a, string b, string c);
    public delegate string string_4fill(string a, string b, string c, string d);
    public delegate object alluser(int userType, int userId);
    User Methods#region User Methods
    public delegate UserInfo userinfo(int userid);
    public delegate ShopInfo shopinfo(int shopid);
    #endregion
    Shop Methods#region Shop Methods
    public delegate DataTable GetAllReCommendKind();
    #endregion
}
  

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-106844-1-1.html 上篇帖子: memcached 高级应用 下篇帖子: memcached问题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表