<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        MVC使用Memcache+Cookie解決分布式系統共享登錄狀態學習筆記6

        來源:懂視網 責編:小采 時間:2020-11-27 22:36:29
        文檔

        MVC使用Memcache+Cookie解決分布式系統共享登錄狀態學習筆記6

        MVC使用Memcache+Cookie解決分布式系統共享登錄狀態學習筆記6: 為了解決單機處理的瓶頸,增強軟件的可用性,我們需要將軟件部署在多臺服務器上啟用多個二級子域名以頻道化的方式,根據業務功能將網站分布部署在獨立的服務器上,或通過負載均衡技術(如:DNS輪詢、Radware、F5、LVS等)讓多個頻道共享一組服務器。當我們將
        推薦度:
        導讀MVC使用Memcache+Cookie解決分布式系統共享登錄狀態學習筆記6: 為了解決單機處理的瓶頸,增強軟件的可用性,我們需要將軟件部署在多臺服務器上啟用多個二級子域名以頻道化的方式,根據業務功能將網站分布部署在獨立的服務器上,或通過負載均衡技術(如:DNS輪詢、Radware、F5、LVS等)讓多個頻道共享一組服務器。當我們將

              為了解決單機處理的瓶頸,增強軟件的可用性,我們需要將軟件部署在多臺服務器上啟用多個二級子域名以頻道化的方式,根據業務功能將網站分布部署在獨立的服務器上,或通過負載均衡技術(如:DNS輪詢、Radware、F5、LVS等)讓多個頻道共享一組服務器。當我們將網站程序分部到多臺服務器上后,由于Session受實現原理的局限,無法跨服務器同步更新Session,使得登錄狀態難以通過Session共享。

              我們使用MemCache+Cookie方案來解決分布式系統共享登錄狀態的問題。

              Memcache服務器本身就是一個Socket服務端,內部數據采用鍵值對的形式存儲在服務器的內存中,本質就是一個大型的哈希表。數據的刪除采用惰性刪除機制。雖然Memcache并沒有提供集群功能,但是通過客戶端的驅動程序很容易就可以實現Memcache的集群配置。

             先簡單介紹一下Memcache的用法

        1. 下載安裝Memcache(Windows平臺)

            (1)將程序解壓到磁盤任意位置

            (2)進入cmd窗口,運行Memcached.exe -d install安裝服務,安裝后打開服務窗口查看服務是否安裝成功。

            (3)直接在服務管理中啟動服務,或者使用cmd命令 net start "Memcache Server"

            (4)使用Telnet連接到Memcache控制臺,驗證服務是否正常 telnet 127.0.0.1 11211

                    使用stats指令查看當前Memcache服務器狀態

        2. 程序中的用法

            (1)在程序中添加 Memcached.ClientLibrary.dll 的引用

            (2)C#中操作Memcache的代碼示例

        String[] serverlist = { "192.168.1.100:11211",
        "192.168.1.101:11211" };
        // initialize the pool for memcache servers
        SockIOPool pool = SockIOPool.GetInstance("test");
        pool.SetServers(serverlist);
        pool.Initialize();
        mc = new MemcacheClient();
        mc.PoolName = "test";
        mc.EnableCompression = false;
        pool.Shutdown();//關閉連接池
        

        下面我們做方案的具體實現

        1. 首先在Common層中引入Memcached.ClientLibrary.dll,并封裝Memcache的幫助類,MemcacheHelper

        using Memcached.ClientLibrary;
        using System;
        
        namespace PMS.Common
        {
         public class MemcacheHelper
         {
         private static readonly MemcachedClient Mc = null;
        
         static MemcacheHelper()
         {
         //最好放在配置文件中
         string[] serverlist = { "127.0.0.1:11211", "10.0.0.132:11211" };
        
         //初始化池
         var 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();
        
         // 獲得客戶端實例
         Mc = new MemcachedClient {EnableCompression = false};
         }
         /// <summary>
         /// 存儲數據
         /// </summary>
         /// <param name="key"></param>
         /// <param name="value"></param>
         /// <returns></returns>
         public static bool Set(string key,object value)
         {
         return Mc.Set(key, value);
         }
         public static bool Set(string key, object value,DateTime time)
         {
         return Mc.Set(key, value,time);
         }
         /// <summary>
         /// 獲取數據
         /// </summary>
         /// <param name="key"></param>
         /// <returns></returns>
         public static object Get(string key)
         {
         return Mc.Get(key);
         }
         /// <summary>
         /// 刪除
         /// </summary>
         /// <param name="key"></param>
         /// <returns></returns>
         public static bool Delete(string key)
         {
         return Mc.KeyExists(key) && Mc.Delete(key);
         }
         }
        }
        
        

        2. 改變用戶登錄方法UserLogin,用戶登錄成功后生成GUID,將此GUID存入Cookie并以GUID為鍵將登錄用戶信息序列化存入Memcache服務器。

        public ActionResult UserLogin()
        {
         #region 驗證碼校驗
         var validateCode = Session["validateCode"] != null ? Session["validateCode"].ToString() : string.Empty;
         if (string.IsNullOrEmpty(validateCode))
         return Content("no:驗證碼錯誤!!");
         Session["validateCode"] = null;
         var txtCode = Request["ValidateCode"];
         if (!validateCode.Equals(txtCode, StringComparison.InvariantCultureIgnoreCase))
         return Content("no:驗證碼錯誤!!");
         #endregion
        
         var userName = Request["UserName"];
         var userPwd = Request["PassWord"];
         //查詢用戶是否存在
         var user = UserService.LoadEntities(u => u.UserName == userName && u.PassWord == userPwd).FirstOrDefault();
         if (user == null) return Content("no:登錄失敗");
        
         //產生一個GUID值作為Memache的鍵.
         var sessionId = Guid.NewGuid().ToString();
         //將登錄用戶信息存儲到Memcache中。
         MemcacheHelper.Set(sessionId, SerializeHelper.SerializeToString(user), DateTime.Now.AddMinutes(20));
         //將Memcache的key以Cookie的形式返回給瀏覽器。
         Response.Cookies["sessionId"].Value = sessionId;
         return Content("ok:登錄成功");
        }
        
        

        3. 改變登錄校驗控制器FilterController的OnActionExecuting方法,使其校驗方式改為從Memcache服務器中讀取Cookie中值為鍵的對象:

        protected override void OnActionExecuting(ActionExecutingContext filterContext)
        {
         base.OnActionExecuting(filterContext);
         //if (Session["user"] == null)
         if (Request.Cookies["sessionId"] != null)
         {
         var sessionId = Request.Cookies["sessionId"].Value;
         //根據該值查Memcache.
         var obj = MemcacheHelper.Get(sessionId);
         if (obj == null)
         {
         filterContext.Result = Redirect("/Login/Index");
         return;
         }
         var user = SerializeHelper.DeserializeToObject<User>(obj.ToString());
         LoginUser = user;
         //模擬出滑動過期時間.
         MemcacheHelper.Set(sessionId, obj, DateTime.Now.AddMinutes(20)); 
         }
         else
         filterContext.Result = Redirect("/Login/Index");
        }
        

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        MVC使用Memcache+Cookie解決分布式系統共享登錄狀態學習筆記6

        MVC使用Memcache+Cookie解決分布式系統共享登錄狀態學習筆記6: 為了解決單機處理的瓶頸,增強軟件的可用性,我們需要將軟件部署在多臺服務器上啟用多個二級子域名以頻道化的方式,根據業務功能將網站分布部署在獨立的服務器上,或通過負載均衡技術(如:DNS輪詢、Radware、F5、LVS等)讓多個頻道共享一組服務器。當我們將
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲欧美不卡高清在线| 亚洲色av性色在线观无码| 亚洲熟妇少妇任你躁在线观看| 成年女人色毛片免费看| 亚洲国产日韩女人aaaaaa毛片在线 | 91天堂素人精品系列全集亚洲| 四虎国产精品免费永久在线| 中文字幕第一页亚洲| 一级做a爰性色毛片免费| 亚洲精品久久久www| 一区二区三区在线免费 | 50岁老女人的毛片免费观看| 亚洲视频在线免费看| 免费专区丝袜脚调教视频| 亚洲人妖女同在线播放| 最近最新的免费中文字幕| 亚洲AV无码国产剧情| 亚洲成片观看四虎永久| 国产日韩AV免费无码一区二区三区 | 久久大香伊焦在人线免费| 久久亚洲美女精品国产精品| 老司机在线免费视频| 亚洲AV日韩AV无码污污网站| 亚洲人成无码www久久久| 免费国产成人α片| 激情五月亚洲色图| 亚洲AV伊人久久青青草原| 国产一级在线免费观看| 亚洲福利视频一区二区三区| 成人免费毛片观看| 一个人看的www视频免费在线观看 一个人看的免费观看日本视频www | 91人人区免费区人人| 亚洲中文字幕乱码一区| 亚洲国产电影av在线网址| 免费成人在线视频观看| 亚洲高清中文字幕免费| 国产亚洲av片在线观看18女人 | 成年人免费视频观看| 一级毛片在播放免费| 亚洲春色另类小说| 免费成人在线观看|