亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

遍歷memcached緩存對象(C#)

系統 2096 0

STATS命令

出于性能考慮,memcached沒有提供遍歷功能,不過我們可以通過以下兩個stats命令得到所有的緩存對象。

1、stats items

顯示各個slab中item的數目。

2、stats cachedump slab_idlimit_num
顯示某個slab中的前limit_num個key列表,顯示格式:ITEM key_name [ value_length b; expire_time|access_time s]

除了上面兩個,memcached還提供了以下命令:

3、stats
4、 stats reset
5、 stats malloc
6、 stats maps
7、 stats sizes
8、 stats slabs
9、 stats detail [on|off|dump]

命令的用法就不一一說了,請自行google。 關于memcached的數據存儲和內存分配以后有機會再寫。

添加緩存

在本地添加幾個key,如下:

遍歷memcached緩存對象(C#)

程序實現

因為要用c#調用,所以需要客戶端執行 STATS 命令,這個可以直接參考DiscuzNT3.0中的實現。

DiscuzNT下載地址:http://download.comsenz.com/DiscuzNT/src/

下載完程序以后,在Discuz.Cache項目中找到這兩個類:MemCached.cs和MemCachedClient.cs。

我們要用到的方法有:

MemCached.GetStats

代碼
<!-- <br/ /><br/ />Code highlighting produced by Actipro CodeHighlighter (freeware)<br/ />http://www.CodeHighlighter.com/<br/ /><br/ />--> /// <summary>
/// 獲取服務器端緩存的數據信息
/// </summary>
/// <paramname="serverArrayList"> 要訪問的服務列表 </param>
/// <returns> 返回信息 </returns>
public static ArrayListGetStats(ArrayListserverArrayList,StatsstatsCommand, string param)
{
ArrayListstatsArray = new ArrayList();
param = Utils.StrIsNullOrEmpty(param) ? "" :param.Trim().ToLower();

string commandstr = " stats " ;
// 轉換stats命令參數
switch (statsCommand)
{
case Stats.Reset:{commandstr = " statsreset " ; break ;}
case Stats.Malloc:{commandstr = " statsmalloc " ; break ;}
case Stats.Maps:{commandstr = " statsmaps " ; break ;}
case Stats.Sizes:{commandstr = " statssizes " ; break ;}
case Stats.Slabs:{commandstr = " statsslabs " ; break ;}
case Stats.Items:{commandstr = " stats " ; break ;}
case Stats.CachedDump:
{
string []statsparams = Utils.SplitString(param, " " );
if (statsparams.Length == 2 )
if (Utils.IsNumericArray(statsparams))
commandstr = " statscachedump " + param;

break ;
}
case Stats.Detail:
{
if ( string .Equals(param, " on " ) || string .Equals(param, " off " ) || string .Equals(param, " dump " ))
commandstr = " statsdetail " + param.Trim();

break ;
}
default :{commandstr = " stats " ; break ;}
}
// 加載返回值
Hashtablestats = MemCachedManager.CacheClient.Stats(serverArrayList,commandstr);
foreach ( string key in stats.Keys)
{
statsArray.Add(key);
Hashtablevalues = (Hashtable)stats[key];
foreach ( string key2 in values.Keys)
{
statsArray.Add(key2 + " : " + values[key2]);
}
}
return statsArray;
}

MemCachedClient.Stats

代碼
<!-- <br/ /><br/ />Code highlighting produced by Actipro CodeHighlighter (freeware)<br/ />http://www.CodeHighlighter.com/<br/ /><br/ />--> public HashtableStats(ArrayListservers, string command)
{

// getSockIOPoolinstance
SockIOPoolpool = SockIOPool.GetInstance(_poolName);

// returnfalseifunabletogetSockIOobj
if (pool == null )
{
// if(log.IsErrorEnabled)
// {
// log.Error(GetLocalizedString("unabletogetsocketpool"));
// }
return null ;
}

// getallserversanditerateoverthem
if (servers == null )
servers = pool.Servers;

// ifnoservers,thenreturnearly
if (servers == null || servers.Count <= 0 )
{
// if(log.IsErrorEnabled)
// {
// log.Error(GetLocalizedString("statsnoservers"));
// }
return null ;
}

// arrayofstatsHashtables
HashtablestatsMaps = new Hashtable();

for ( int i = 0 ;i < servers.Count;i ++ )
{

SockIOsock = pool.GetConnection(( string )servers[i]);
if (sock == null )
{
// if(log.IsErrorEnabled)
// {
// log.Error(GetLocalizedString("unabletoconnect").Replace("$$Server$$",servers[i].ToString()));
// }
continue ;
}

// buildcommand
command = Discuz.Common.Utils.StrIsNullOrEmpty(command) ? " stats\r\n " :command + " \r\n " ;

try
{
sock.Write(UTF8Encoding.UTF8.GetBytes(command));
sock.Flush();

// maptoholdkeyvaluepairs
Hashtablestats = new Hashtable();

// loopoverresults
while ( true )
{
string line = sock.ReadLine();
// if(log.IsDebugEnabled)
// {
// log.Debug(GetLocalizedString("statsline").Replace("$$Line$$",line));
// }

if (line.StartsWith(STATS))
{
string []info = line.Split( ' ' );
string key = info[ 1 ];
string val = info[ 2 ];

// if(log.IsDebugEnabled)
// {
// log.Debug(GetLocalizedString("statssuccess").Replace("$$Key$$",key).Replace("$$Value$$",val));
// }

stats[key] = val;

}
else if (END == line)
{
// finishwhenwegetendfromserver
// if(log.IsDebugEnabled)
// {
// log.Debug(GetLocalizedString("statsfinished"));
// }
break ;
}

statsMaps[servers[i]] = stats;
}
}
catch // (IOExceptione)
{
// if(log.IsErrorEnabled)
// {
// log.Error(GetLocalizedString("statsIOException"),e);
// }

try
{
sock.TrueClose();
}
catch // (IOException)
{
// if(log.IsErrorEnabled)
// {
// log.Error(GetLocalizedString("failedtoclosesomesocket").Replace("$$Socket$$",sock.ToString()));
// }
}

sock = null ;
}

if (sock != null )
sock.Close();
}

return statsMaps;
}

有了這兩個方法我們就可以得到memcached中的緩存項了。

基本思路是,先得到cache中所有的item(stats items),再通過itemid 取出cachekey和cachevalue(stats cachedump)

程序實現如下:

<!-- <br/ /><br/ />Code highlighting produced by Actipro CodeHighlighter (freeware)<br/ />http://www.CodeHighlighter.com/<br/ /><br/ />--> private void GetItems()
{
ArrayListitemarr = new ArrayList();

ArrayListarrayList = new ArrayList();
StringBuildersb = new StringBuilder();

foreach ( string server in MemCachedManager.ServerList)
{
arrayList.Add(server);
}
ArrayListarr = MemCachedManager.GetStats(arrayList,MemCachedManager.Stats.Items, null );
foreach ( string a in arr)
{
string []tmparr = a.Split( ' : ' );
if (tmparr.Length > 1 )
{
int item_id = 0 ;
int .TryParse(tmparr[ 1 ], out item_id);

bool find = false ;
foreach ( int item in itemarr)
{
if (item == item_id)
find = true ;
}
if ( ! find && item_id > 0 && item_id != 11211 )
itemarr.Add(item_id);
}
}
foreach ( int item in itemarr)
{
sb.Append( " item " + item + " <br/> " );
ArrayListcachearr = MemCachedManager.GetStats(arrayList,MemCachedManager.Stats.CachedDump, "" + item + " 10 " );
foreach ( string cache in cachearr)
{
sb.Append(cache);
sb.Append( " <br/> " );
}
}
Response.Write(sb.ToString());
}

運行程序:

遍歷memcached緩存對象(C#)

為什么沒有輸出緩存項呢?

DiscuzNT3.0中的bug

于是我找啊找,發現是DiscuzNT3.0中的一個bug導致。

在MemCachedClient.Stats中,有這樣的一段代碼:

<!-- <br/ /><br/ />Code highlighting produced by Actipro CodeHighlighter (freeware)<br/ />http://www.CodeHighlighter.com/<br/ /><br/ />--> if (line.StartsWith(STATS))
{
string []info = line.Split( ' ' );
string key = info[ 1 ];
string val = info[ 2 ];
stats[key] = val;

}
else if (END == line)
{
break ;
}

原來是忽略了stats cachedump 的結果是以ITEM開頭的,所以什么都沒有輸出。簡單修改一下:

<!-- <br/ /><br/ />Code highlighting produced by Actipro CodeHighlighter (freeware)<br/ />http://www.CodeHighlighter.com/<br/ /><br/ />--> if (line.StartsWith(STATS))
{
string []info = line.Split( ' ' );
string key = info[ 1 ];
string val = info[ 2 ];
stats[key] = val;

}
else if (line.StartsWith( " ITEM " ))
{
string []info = line.Split( ' [ ' );
string key = info[ 0 ].Split( ' ' )[ 1 ];
string val = " [ " + info[ 1 ];

stats[key] = val;
}
else if (END == line)
{
break ;
}

再看一下輸出結果,顯示正常。

遍歷memcached緩存對象(C#)

遍歷memcached緩存對象(C#)


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 看免费一级毛片 | av在线色 | 天天操天天干天天玩 | 日本欧美一区二区三区在线观看 | 色综合小说天天综合网 | 四虎精品成人免费永久 | 亚洲午夜久久久久中文字幕久 | www.夜夜骑.com | 麻豆一区二区三区四区 | 97国内精品久久久久久久影视 | 久久亚洲国产成人亚 | 91资源在线 | 久久91亚洲精品久久91综合 | 黄色毛片免费 | 97在线人人| 久久国产亚洲观看 | 欧美一级艳片爽快片 | 日日拍夜夜嗷嗷叫狠狠 | 宅男看片午夜大片啪啪mv | 97天天做天天爱夜夜爽 | 国产欧美在线观看精品一区二区 | 狠狠色成人综合网图片区 | 99久久99久久久精品久久 | 国产成人精品免费视频大全办公室 | 亚洲欧美日韩中文在线 | 老司机精品在线播放 | 一级毛片私人影院老司机 | 最新国产精品好看的国产精品 | 中文字幕日韩欧美一区二区三区 | 久久亚洲精品中文字幕第一区 | 国内精品免费 | 香蕉久久夜色精品国产 | 色在线视频 | 国语自产偷拍精品视频偷最新 | 久久免费精品视频在线观看 | 婷婷色人阁 | 亚洲精品中文字幕不卡在线 | 亚洲一二三 | 国产精品原创永久在线观看 | 精品久久久久久中文字幕女 | 狠狠一区|