分布式緩存Memcached---開篇的話


         大數據、高並發這是最近一段時間內被IT行業提的最為火熱的概念,看過《大數據時代》的同學應該不會陌生大數據的概念,尤其是對於互聯網行業來說,大數據是每天都要接觸的問題,簡單通俗地說,每天得大數據,就給系統的性能帶來了新的要求---高並發,有了這樣一個技術應用的實際背景,對技術人員就提出了要求,隨着java環境下的Hadoop,PHP的Memcached,包括Redis的產生和技術的擴散,我們就開始接觸這些應用與大數據高並發領域的架構理念,Memcached基於C語言編寫,天生的跨平台,讓這個技術很容易產生了Windows平台的版本,.NET環境對Memcached玩轉就顯得讓人興奮不已了。

我的環境:

     Thinkpad T430  I5/2.8GHZ  8G/DDR3

     Windows 8 Enterprise X64

首先,下載Memecached服務端安裝包,據我所知官方不提供windows版本的安裝包,需要自己編譯,不過在github上有MSI安裝包可以下載。

服務端:http://code.jellycan.com/memcached/

客戶端:http://sourceforge.net/projects/memcacheddotnet/    

當然還存在一些其它較好的客戶端,這里我實現一個分布式緩存實現單點登錄的功能,就使用了這個客戶端。下載完成后,含exe安裝包文件夾解壓copy到自定義目錄。我的環境中,我把它放到了E盤根目錄。命令行安裝

完成安裝后,使用start命令來啟動memcached,這樣memcached就會作為一個windows服務進程在運行

服務端運行完成后,可以基本了解一下這個版本的Memcahced在windows平台下的一些基本特性:

Memcached默認使用端口是11211

默認最大連接數是1024個

默認最大使用內存是64M

默認每個鍵值對,值存儲空間為1M
服務端准備工作完成后,我們需要支持進行memcached編程的客戶端,對於net技術來說,就是需要支持的DLL,當然,如果對Memcached特別有研究的同學,可以自己寫Dll,Memecahed服務端會暴露相應的API供客戶端調用,使用Sockt連接來進行數據交互。我使用的是Memcacheddotnetclient_1.1.5的客戶端 。

所有的准備工作完成之后,就要進入我們的代碼階段了。打開visual studio新建一個項目(控制台、web、win都可以),然后項目引入客戶端DLL就可以進行編程了。為了方便單點登錄的Session數據共享的功能,我新建的是Web MVC程序。

程序目錄結構:

實現單點登錄毫無疑問,首先使用MVC框架建立Login頁面

View Login前端

一個密碼輸入框,一個用戶名輸入框,簡單模擬登錄。當用戶輸入用戶名密碼之后,進行校驗,校驗通過將生成SessionID,通過Respons寫入客戶端,並將用戶登錄信息存入Memecached,在下次用戶直接請求Index頁面的時候,首先通過Cookie存入的SessionId查找Memecached,如果查找到並且驗證合格則直接跳轉到Index,否則繼續進入Login要求用戶信息驗證。

HomeControll代碼如下:

        [HttpPost]
        public ActionResult LoginAction(FormCollection values)
        {
            string name = values["txtName"];
            string password = values["txtPass"];

            if (name == myname && password == mypassword)
            {
                string sessionId = Guid.NewGuid().ToString();
                MemcachHelper.Set(sessionId, name + "$" + password, DateTime.Now.AddDays(1));
                Response.Cookies["SessionId"].Value = sessionId;
                return View("Index");
            }

            return View("Login");
        }

使用POST方式提交用戶頁面信息進行驗證,我這里放了2個靜態變量,真實的環境中,這個數據應該是從數據庫中查詢到的。

 當用戶直接請求非身份驗證的頁面的時候,我們首先是查找Cookie中是否有我們在登錄的時候寫入的SessionID,存在SessionId則直接去Memecached拉取前次登錄的信息。

代碼實現如下:

        public ActionResult Index()
        {
            if (Request.Cookies["SessionId"] == null || string.IsNullOrEmpty(Request.Cookies["SessionId"].ToString()))
            {
                return View("Login");
            }
            else
            {
                string key = Request.Cookies["SessionId"].Value.ToString();
                string[] arrUserInfo = MemcachHelper.Get(key).ToString().Split('$');
                if (arrUserInfo.Length >= 2)
                {
                    if (arrUserInfo[0] == myname && arrUserInfo[1] == mypassword)
                    {
                        return View("Index");
                    }
                    return View("Login");
                }
            }
            return View("Login");
        }

實現起來的業務邏輯並不復雜了,這里兩次操作了Memecached,所以在Model中加入了一個操作Memecached的幫助類,類代碼如下:

    public class MemcachHelper
    {
        private static MemcachedClient mclient;

        static MemcachHelper()
        {
            string[] serverList = new string[] { "127.0.0.1:11211" };

            SockIOPool pool = SockIOPool.GetInstance("First");
            pool.SetServers(serverList);
            pool.Initialize();
            mclient = new MemcachedClient();
            mclient.PoolName = "test";
            mclient.EnableCompression = false;
        }

        public static bool Set(string key, object value, DateTime expiry)
        {
            return mclient.Set(key, value, expiry);
        }

        public static object Get(string key)
        {
            return mclient.Get(key);
        }
    }

干脆利索的三個功能,由於使用的是靜態類的靜態方法,所以構造函數中對Memcached進行來了初始化,在類進行靜態方法調用的時候,第一次回調用靜態構造函數,將Memecached需要進行初始化的信息進行寫入。其次,定義了Get和Set兩個方法,一個讀取,一個寫入數據。操作Memecached就這么簡單。

這里稍微解釋一下靜態構造函數中的代碼:serverList實際上就是我們說的服務器集群列表,這個列表直接告訴了我們那台服務器,通過那個端口,加入這個memecached集群。建立SockIOPool連接,初始化連接池,並設置相應的過期時間。

 

拋磚引玉,歡迎吐槽學習!貼上我的源代碼:http://files.cnblogs.com/aspnetdream/MemcachedMVC.rar


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM