日韩天天综合网_野战两个奶头被亲到高潮_亚洲日韩欧美精品综合_av女人天堂污污污_视频一区**字幕无弹窗_国产亚洲欧美小视频_国内性爱精品在线免费视频_国产一级电影在线播放_日韩欧美内地福利_亚洲一二三不卡片区

實(shí)例解析.NET版分布式緩存Memcached_.Net教程

編輯Tag賺U幣
教程Tag:暫無(wú)Tag,歡迎添加,賺取U幣!

推薦:試析ASP.NET的IIS映射
ASP.NET默認(rèn)擴(kuò)展名為.aspx,可是我們看到許多網(wǎng)站的擴(kuò)展名很特別,比如校內(nèi)的do。個(gè)性之余還可以實(shí)現(xiàn)簡(jiǎn)單的偽靜態(tài)(即把后綴改為html)不過(guò)相對(duì)URLRewriter來(lái)說(shuō),是有點(diǎn)簡(jiǎn)陋(只能改掉連接中的.aspx),不過(guò)不失為一種方法。下面我們就來(lái)實(shí)現(xiàn)他! 先來(lái)說(shuō)一下

下面測(cè)試下分布式緩存Memcached軟件,一直在學(xué)習(xí)關(guān)注大訪問(wèn)量網(wǎng)站的緩存是如何實(shí)現(xiàn),之前看過(guò)Memcached的資料,忙于沒(méi)有時(shí)間來(lái)真正測(cè)試一下,本文測(cè)試分布式緩存Memcached的環(huán)境如下:(兩臺(tái)電腦作為服務(wù)器)

第一臺(tái):

CPU:Inter(R) Pentium(R) 4 CPU 2.8G

內(nèi)存:1G

系統(tǒng):windows 7

IIS: IIS 7

IP:172.10.1.97

環(huán)境:本地

安裝:memcached 1.2.1 for Win32

第二臺(tái):

CPU:Inter(R) Pentium(R) 4 CPU 3.0G

內(nèi)存:2G

系統(tǒng):windows Server 2003

IIS: IIS 6

IP:172.10.1.236

環(huán)境:遠(yuǎn)程

安裝:memcached 1.2.1 for Win32

測(cè)試程序部署到本地環(huán)境(172.10.1.97),開(kāi)發(fā)工具VS2008 .NET3.5

本文使用到memcached 1.2.1 for Win32下載地址:

http://jehiah.cz/projects/memcached-win32/

更多memcached版本大全請(qǐng)進(jìn)入

http://www.xueit.com/html/2009-11-12/32-1550931594781.html

好了,下面我們按步驟來(lái)測(cè)試:

第一、首先到把下載好的memcached 1.2.1解壓到C:\memcached目錄,分別復(fù)制到兩臺(tái)服務(wù)器中。

第二、安裝memcached服務(wù),在命令提示符輸入CD c:\memcached進(jìn)入到memcached目錄,如下圖:

之后輸入memcached -h 回車,看幫助說(shuō)明,接下來(lái)輸入memcached -d install 回車即可自動(dòng)安裝memcached服務(wù)了,如下圖:

安裝memcached服務(wù)圖

安裝好安裝memcached服務(wù)后,輸入memcached -d start 回車啟動(dòng)memcached服務(wù),如下圖:

啟動(dòng)memcached服務(wù)圖

在172.10.1.97與172.10.1.236兩臺(tái)電腦都按以上操作來(lái)安裝啟動(dòng)memcached。

第三、下載.NET版memcached客戶端API組件來(lái)寫測(cè)試程序。

本文使用memcacheddotnet,下載地址如下:

http://sourceforge.net/projects/memcacheddotnet/

下載好之后把這些文件Commons.dll,ICSharpCode.SharpZipLib.dll,log4net.dll,Memcached.ClientLibrary.dll放到bin目錄(少一個(gè)都不行),之后再到測(cè)試項(xiàng)目開(kāi)發(fā)環(huán)境引用Memcached.ClientLibrary.dll,如下圖

引用Memcached.ClientLibrary.dll圖

第四、測(cè)試程序:

以下為引用的內(nèi)容:
using System;
using System.Collections;
using System.Text;

// 須引用Memcached
using Memcached.ClientLibrary;

namespace test
{
   
public partial class _Default : System.Web.UI.Page
    {
       
protected void Page_Load(object sender, EventArgs e)
        {
           
if (!IsPostBack)
            {
               
if (Request["action"] == "clear")
                   
this.clear();
               
else
                   
this.test();
            }
        }

       
/// <summary>
       
/// 清空緩存
       
/// </summary>
        public void clear()
        {
           
string[] servers = { "172.10.1.97:11211", "172.10.1.236:11211" };

           
//初始化池
            SockIOPool pool = SockIOPool.GetInstance();
            pool.SetServers(servers);
            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();
            MemcachedClient mc
= new Memcached.ClientLibrary.MemcachedClient();
            mc.EnableCompression
= false;
            mc.Delete(
"cache");
            mc.Delete(
"endCache");
            Response.Write(
"清空緩存成功");
        }

       
/// <summary>
       
/// 測(cè)試緩存
       
/// </summary>
        public void test()
        {
           
//分布Memcachedf服務(wù)IP 端口
            string[] servers = { "172.10.1.97:11211","172.10.1.236:11211" };

           
//初始化池
            SockIOPool pool = SockIOPool.GetInstance();
            pool.SetServers(servers);
            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();
           
//客戶端實(shí)例
            MemcachedClient mc = new Memcached.ClientLibrary.MemcachedClient();
            mc.EnableCompression
= false;
            StringBuilder sb
= new StringBuilder();
           
//寫入緩存
            sb.AppendLine("寫入緩存測(cè)試:");
            sb.AppendLine(
"<br>_______________________________________<br>");
           
if (mc.KeyExists("cache"))
            {
                sb.AppendLine(
"緩存cache已存在");
            }
           
else
            {
                mc.Set(
"cache", "寫入緩存時(shí)間:"   DateTime.Now.ToString());
                sb.AppendLine(
"緩存已成功寫入到cache");
            }
            sb.AppendLine(
"<br>_______________________________________<br>");
            sb.AppendLine(
"讀取緩存內(nèi)容如下:<br>");
            sb.AppendLine(mc.Get(
"cache").ToString());

           
//測(cè)試緩存過(guò)期
            sb.AppendLine("<br>_______________________________________<br>");
           
if (mc.KeyExists("endCache"))
            {
                sb.AppendLine(
"緩存endCache已存在,過(guò)期時(shí)間為:"   mc.Get("endCache").ToString());
            }
           
else
            {
                mc.Set(
"endCache", DateTime.Now.AddMinutes(1).ToString(), DateTime.Now.AddMinutes(1));
                sb.AppendLine(
"緩存已更新寫入到endCache,寫入時(shí)間:"   DateTime.Now.ToString()   " 過(guò)期時(shí)間:"   DateTime.Now.AddMinutes(1).ToString());
            }

           
//分析緩存狀態(tài)
            Hashtable ht = mc.Stats();
            sb.AppendLine(
"<br>_______________________________________<br>");
            sb.AppendLine(
"Memcached Stats:");
            sb.AppendLine(
"<br>_______________________________________<br>");
           
foreach (DictionaryEntry de in ht)
            {
                Hashtable info
= (Hashtable)de.Value;
               
foreach (DictionaryEntry de2 in info)
                {
                    sb.AppendLine(de2.Key.ToString()  
":&nbsp;&nbsp;&nbsp;&nbsp;"   de2.Value.ToString()   "<br>");
                }
            }
            Response.Write(sb.ToString());
        }
    }

第五、 運(yùn)行看效果:

緩存效果圖我在本地172.10.1.97運(yùn)行memcached -d

stop來(lái)停止memcached服務(wù),運(yùn)行上面程序,一樣正確,說(shuō)明緩存也同樣保存到遠(yuǎn)程172.10.1.236這臺(tái)服務(wù)器了。這樣簡(jiǎn)單就可以實(shí)現(xiàn)分布式緩存,使用緩存又多了一個(gè)選擇,不必使用.NET自帶的Application與cache了,訪問(wèn)量大的網(wǎng)站實(shí)現(xiàn)分布式緩存有很多好處。

分享:淺談ASP.NET的PHP執(zhí)行速度
上星期我在InfoQ發(fā)表了一篇新聞,對(duì)Joe Stagner在博客上發(fā)表的三篇關(guān)于ASP.NET與PHP性能對(duì)比的文章進(jìn)行了總結(jié)。寫新聞其實(shí)挺不爽的,因?yàn)椴荒軍A雜個(gè)人的看法,只能平鋪直敘陳述事實(shí)。當(dāng)然,如果像某些新聞那樣換一種說(shuō)法是可以騙過(guò)一些不明真相的群眾,但是

來(lái)源:模板無(wú)憂//所屬分類:.Net教程/更新時(shí)間:2009-11-17
相關(guān).Net教程