?????Memcached?是一個高性能的分布式內存對象緩存系統,用于動態Web應用以減輕數據庫負載。它通過在內存中緩存數據和對象來減少讀取數據庫的次數,從而提供動態、數據庫驅動網站的速度。Memcached作為緩存技術的解決方案,已經是眾所周知了;現在很多WEB應用都在使用它――包括一些知名的網站。若你還不知道這些,請在閱讀之前先了解一下。 ??????? 在ASP.NET中使用Memcached,有很多文章都有介紹,以下是我個人的使用經驗。 ??????? 一,準備 ??????? 你需要有一下軟件: ?????? VS.NET(05/08) ?????? SQLSERVER ?????? memcached服務器端以及客戶端類庫(開源軟件,下載即可) 其中,客戶端類庫包括以下幾個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節點,添加以下內容 <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" /> 再在configSections節點之外,增加以下內容: <log4net> ??????? <appender name="RollingLogFileAppender" type="log4net.Appender.RollingFileAppender"> ??????????? <param name="File" value="LogFiles/"/> ??????????? <param name="AppendToFile" value="true"/> ??????????? <param name="MaxSizeRollBackups" value="10"/> ??????????? <param name="StaticLogFileName" value="false"/> ??????????? <param name="DatePattern" value="yyyy-MM-dd".txt""/> ??????????? <param name="RollingStyle" value="Date"/> ??????????? <layout type="log4net.Layout.PatternLayout"> ??????????????? <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger %ndc - %message%newline"/> ??????????? </layout> ??????? </appender> ??????? <appender name="ConsoleAppender" type="log4net.Appender.ConsoleAppender"> ??????????? <layout type="log4net.Layout.PatternLayout"> ??????????????? <param name="ConversionPattern" value="%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger %ndc - %message%newline" /> ??????????? </layout> ??????? </appender> ??????? <root> ??????????? <level value="ALL" /> ??????????? <appender-ref ref="RollingLogFileAppender" /> ??????????? <appender-ref ref="ConsoleAppender" /> ??????? </root> ??????? <logger name="Memcached.ClientLibrary"> ??????????? <level value="WARN" /> ??????? </logger> ??? </log4net> 啟動調試,若沒出現配置的出錯提示,并且在網站目錄下有文件夾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的子節點里需要有以下一行 <add key="Memcached.ServerList" value="127.0.0.1:11211"/> 啟動調試服務器,若沒有出錯的日志記錄,說明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);等等??梢宰约鹤聊チ?。 ???????? 以上只是演示,其實數據緩存是一項復雜而繁瑣的工作,不僅需要后臺代碼的分層優化,也需要數據庫對大數據量訪問的策略和調優。 文章來自學IT網:http://www.xueit.com/html/2009-05/21_2027_00.html (責任編輯:admin) |