大數據、高併發這是最近一段時間內被IT行業提的最爲火熱的概念,看過《大數據時代》的同窗應該不會陌生大數據的概念,尤爲是對於互聯網行業來講,大數據是天天都要接觸的問題,簡單通俗地說,天天得大數據,就給系統的性能帶來了新的要求---高併發,有了這樣一個技術應用的實際背景,對技術人員就提出了要求,隨着java環境下的Hadoop,PHP的Memcached,包括Redis的產生和技術的擴散,咱們就開始接觸這些應用與大數據高併發領域的架構理念,Memcached基於C語言編寫,天生的跨平臺,讓這個技術很容易產生了Windows平臺的版本,.NET環境對Memcached玩轉就顯得讓人興奮不已了。前端
個人環境:java
Thinkpad T430 I5/2.8GHZ 8G/DDR3git
Windows 8 Enterprise X64github
首先,下載Memecached服務端安裝包,據我所知官方不提供windows版本的安裝包,須要本身編譯,不過在github上有MSI安裝包能夠下載。web
服務端:http://code.jellycan.com/memcached/數據庫
客戶端:http://sourceforge.net/projects/memcacheddotnet/ 編程
固然還存在一些其它較好的客戶端,這裏我實現一個分佈式緩存實現單點登陸的功能,就使用了這個客戶端。下載完成後,含exe安裝包文件夾解壓copy到自定義目錄。個人環境中,我把它放到了E盤根目錄。命令行安裝windows
完成安裝後,使用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