青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

loop_in_codes

低調(diào)做技術(shù)__歡迎移步我的獨(dú)立博客 codemaro.com 微博 kevinlynx

自己實(shí)現(xiàn)memcached客戶(hù)端庫(kù)

Kevin Lynx

7.21.2008

What's memcached ?

memcached是一個(gè)以key-value的形式緩存數(shù)據(jù)的緩存系統(tǒng)。通過(guò)將數(shù)據(jù)緩存到內(nèi)存中,從而提高數(shù)據(jù)的獲取速度。
memcached以key-value的形式來(lái)保存數(shù)據(jù),你可以為你每一段數(shù)據(jù)關(guān)聯(lián)一個(gè)key,然后以后可以通過(guò)這個(gè)key獲取
這段數(shù)據(jù)。

memcached是一個(gè)庫(kù)還是什么?memcached其實(shí)是一個(gè)單獨(dú)的網(wǎng)絡(luò)服務(wù)器程序。它的網(wǎng)絡(luò)底層基于libevent,你可以
將其運(yùn)行在網(wǎng)絡(luò)中的一臺(tái)服務(wù)器上,通過(guò)網(wǎng)絡(luò),在遵循memcached的協(xié)議的基礎(chǔ)上與memcached服務(wù)器進(jìn)行通信。

What do we want to wrap ?

我們需要做什么?我們只需要遵循memcached的協(xié)議(參見(jiàn)該文檔),封裝網(wǎng)絡(luò)層的通信,讓上層可以通過(guò)調(diào)用諸如
add/get之類(lèi)的接口即可實(shí)現(xiàn)往memcached服務(wù)器緩存數(shù)據(jù),以及取數(shù)據(jù)。上層程序員根本不知道這些數(shù)據(jù)在網(wǎng)絡(luò)
上存在過(guò)。

這個(gè)東西,也就是memcached官方所謂的client apis。你可以使用現(xiàn)成的客戶(hù)端庫(kù),但是你也可以將這種重造輪子
的工作當(dāng)作一次網(wǎng)絡(luò)編程的練習(xí)。it's up to you.:D

Where to start ?

很遺憾,對(duì)于windows用戶(hù)而言,memcached官方?jīng)]有給出一個(gè)可以執(zhí)行或者可以直接F7即可得到可執(zhí)行文件的下載
(如果你是vc用戶(hù))。幸運(yùn)的是,已經(jīng)有人做了這個(gè)轉(zhuǎn)換工作。

你可以從http://jehiah.cz/projects/memcached-win32/這里下載到memcached的windows版本,包括可執(zhí)行程序和
源代碼。

我們直接可以運(yùn)行memcached.exe來(lái)安裝/開(kāi)啟memcached服務(wù)器,具體步驟在以上頁(yè)面有所提及:

安裝:memcached.exe -d install,這會(huì)在windows服務(wù)里添加一個(gè)memcached服務(wù)
運(yùn)行:memcached.exe 
-d start,你也可以通過(guò)windows的服務(wù)管理運(yùn)行。

   
然后,你可以在任務(wù)管理器里看到一個(gè)'memcached'的進(jìn)程,很占內(nèi)存,因?yàn)檫@是memcached。

So, here we go ...

通過(guò)以上步驟運(yùn)行的memcached,默認(rèn)在11211端口監(jiān)聽(tīng)(是個(gè)TCP連接,可以通過(guò)netstat查看)。接下來(lái),我們就可
以connect到該端口上,然后send/recv數(shù)據(jù)了。發(fā)送/接收數(shù)據(jù)只要遵循memcached的協(xié)議格式,一切都很簡(jiǎn)單。

使用最簡(jiǎn)單的阻塞socket連接memcached服務(wù)器:

       SOCKET s = socket( AF_INET, SOCK_STREAM, 0 );
        
struct sockaddr_in addr;
        memset( 
&addr, 0sizeof( addr ) );
        addr.sin_family 
= AF_INET;
        addr.sin_port 
= htons( 11211 );
        addr.sin_addr.s_addr 
= inet_addr( "127.0.0.1" ); 

        ret 
= connect( s, (struct sockaddr*&addr, sizeof( addr ) );
        
if( ret == 0 )
        
{
            printf( 
"connect ok\n" );
        }
 

       
About the protocol

簡(jiǎn)單地提一下memcached的協(xié)議。

可以說(shuō),memcached的協(xié)議是基于行的協(xié)議,因?yàn)闊o(wú)論是客戶(hù)端請(qǐng)求還是服務(wù)器端應(yīng)答,都是以"\r\n"作為結(jié)束符。
memcached的協(xié)議將數(shù)據(jù)(send/recv操作的數(shù)據(jù))分為兩種類(lèi)型:命令和用戶(hù)數(shù)據(jù)。

命令用于服務(wù)器和客戶(hù)端進(jìn)行交互;而用戶(hù)數(shù)據(jù),很顯然,就是用戶(hù)想要緩存的數(shù)據(jù)。

關(guān)于用戶(hù)數(shù)據(jù),你只需要將其編碼成字節(jié)流(說(shuō)白了,只要send函數(shù)允許即可),并附帶數(shù)據(jù)結(jié)束標(biāo)志"\r\n"發(fā)送即可。

關(guān)于命令,memcached分為如下幾種命令:存儲(chǔ)數(shù)據(jù)、刪除數(shù)據(jù)、取出數(shù)據(jù)、其他一些獲取信息的命令。其實(shí)你換個(gè)角度
想想,memcached主要就是將數(shù)據(jù)存儲(chǔ)到內(nèi)存里,所以命令也多不了哪去,基本就停留在add/get/del上。

關(guān)于key,memcached用key來(lái)標(biāo)識(shí)數(shù)據(jù),每一個(gè)key都是一個(gè)不超過(guò)255個(gè)字符的字符串。

到這里,你可以發(fā)現(xiàn)memcached對(duì)于數(shù)據(jù)的存儲(chǔ)方式(暴露給上層)多少有點(diǎn)像std::map,如果你愿意,你可以將客戶(hù)端
API封裝成map形式。= =#

具體實(shí)現(xiàn)

接下來(lái)可以看看具體的實(shí)現(xiàn)了。

首先看看存儲(chǔ)數(shù)據(jù)命令,存儲(chǔ)數(shù)據(jù)命令有:add/set/replace/append/prepend/cas。存儲(chǔ)命令的格式為:
<command name> <key> <flags> <exptime> <bytes> [noreply]\r\n
具體字段的含義參看protocol.txt文件,這里我對(duì)set舉例,如下代碼,阻塞發(fā)送即可:

        char cmd[256] ;
        
char data[] = "test data";
        sprintf( cmd, 
"set TestKey 0 0 %d\r\n", strlen( data ) );
        ret 
= send( s, cmd, strlen( cmd ), 0 ); 


注意:noreply選項(xiàng)對(duì)于有些memcached版本并不被支持,例如我們使用的1.2.2版本。注意官方的changelog即可。

當(dāng)你發(fā)送了存儲(chǔ)命令后,memcached會(huì)等待客戶(hù)端發(fā)送數(shù)據(jù)塊。所以我們繼續(xù)發(fā)送數(shù)據(jù)塊:

 

        ret = send( s, data, strlen( data ), 0 );
        ret 
= send( s, "\r\n"20 ); // 數(shù)據(jù)結(jié)束符

 

然后,正常的話(huà),memcached服務(wù)器會(huì)返回應(yīng)答信息給客戶(hù)端。

 

        char reply[256];
        ret 
= recv( s, reply, sizeof( reply ) - 10 );
        reply[ret] 
= 0;
        printf( 
"server reply : %s\n", reply ); 

 

如果存儲(chǔ)成功,服務(wù)器會(huì)返回STORED字符串。memcached所有應(yīng)答信息都是以字符串的形式給出的。所以可以直接printf出來(lái)。

關(guān)于其他的操作,我就不在這里列舉例子了。我提供了我封裝的memcached客戶(hù)端庫(kù)的完整代碼下載,使用的是阻塞socket,
對(duì)應(yīng)著memcached的協(xié)議看,很容易看懂的。

It's a story about a programmer...

最近發(fā)覺(jué)自己有點(diǎn)極端,要么寫(xiě)純C的代碼,要么寫(xiě)滿(mǎn)是template的泛型代碼。

 

相關(guān)代碼下載

posted on 2008-07-21 15:54 Kevin Lynx 閱讀(6396) 評(píng)論(5)  編輯 收藏 引用 所屬分類(lèi): network

評(píng)論

# re: 自己實(shí)現(xiàn)memcached客戶(hù)端庫(kù) 2008-10-23 16:56 浪跡天涯

學(xué)習(xí)了!
不知博主是否真實(shí)測(cè)試過(guò)采用memcached的服務(wù)器性能有多少提升?  回復(fù)  更多評(píng)論   

# re: 自己實(shí)現(xiàn)memcached客戶(hù)端庫(kù)[未登錄](méi) 2008-10-23 20:44 Kevin Lynx

@浪跡天涯
老實(shí)說(shuō),實(shí)際項(xiàng)目里還沒(méi)用過(guò)memcached。  回復(fù)  更多評(píng)論   

# re: 自己實(shí)現(xiàn)memcached客戶(hù)端庫(kù) 2009-03-26 17:35 阿斯蒂芬

你的代碼在linux上編譯報(bào)出這個(gè)錯(cuò)誤error: storage size of 'addr' isn't known
行號(hào)在sizeof( addr ).也就是獲取結(jié)構(gòu)大小的時(shí)候.  回復(fù)  更多評(píng)論   

# re: 自己實(shí)現(xiàn)memcached客戶(hù)端庫(kù)[未登錄](méi) 2009-03-26 18:05 Kevin Lynx

@阿斯蒂芬
能不能具體點(diǎn)?哪個(gè)文件,哪一行?
我稍微搜索了下代碼,發(fā)現(xiàn)只有在fun_test.txt里才有sizeof( addr ),這個(gè)文件是用于功能測(cè)試的,只要kl_memcached下的源文件編譯得過(guò)你就可以使用。:)  回復(fù)  更多評(píng)論   

# re: 自己實(shí)現(xiàn)memcached客戶(hù)端庫(kù) 2011-06-21 11:23 110

@阿斯蒂芬
這是windows下的代碼,姐  回復(fù)  更多評(píng)論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲图片欧洲图片日韩av| 性亚洲最疯狂xxxx高清| 欧美日韩在线播放一区| 欧美 日韩 国产 一区| 久久久久国色av免费观看性色| 久久成人国产精品| 久久嫩草精品久久久精品一| 免费观看成人| 欧美视频手机在线| 国产女人精品视频| 激情综合电影网| 亚洲精品视频在线观看网站| 一本色道久久综合一区| 欧美色大人视频| 欧美色视频在线| 国产日韩av高清| 在线免费观看日韩欧美| 亚洲精品国产精品国产自| 中文国产一区| 久久精品99无色码中文字幕| 欧美激情亚洲国产| 一区二区三区 在线观看视频| 欧美一级免费视频| 欧美成黄导航| 国产日韩欧美高清| 99在线精品观看| 久久精品欧洲| 亚洲日韩第九十九页| 亚洲精品中文字幕女同| 亚洲字幕一区二区| 美女啪啪无遮挡免费久久网站| 国产精品美女主播| 亚洲国产欧美一区二区三区久久| 亚洲欧美高清| 亚洲人成毛片在线播放女女| 欧美一区亚洲一区| 欧美色偷偷大香| 亚洲精品影院| 久久爱www久久做| 亚洲精品国久久99热| 久久久综合激的五月天| 国产精品影音先锋| 一本到高清视频免费精品| 狂野欧美一区| 亚洲宅男天堂在线观看无病毒| 欧美福利在线观看| 一色屋精品视频在线看| 亚洲欧美日韩一区| 亚洲国产另类久久精品| 久久精品国产精品亚洲综合| 国产精品日韩精品| 亚洲欧美国产三级| 日韩视频免费观看高清在线视频| 免费亚洲视频| 亚洲激情不卡| 亚洲国产免费| 欧美激情一区二区三区蜜桃视频| 91久久精品国产91性色tv| 久久婷婷综合激情| 欧美一级电影久久| 国产精品―色哟哟| 午夜免费日韩视频| 亚洲小说春色综合另类电影| 国产精品二区三区四区| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲欧洲精品一区| 欧美日本在线播放| 夜夜嗨av一区二区三区四季av| 亚洲国产一区二区a毛片| 欧美福利电影网| 99综合在线| 日韩亚洲欧美高清| 欧美午夜一区| 国产精品久久国产精品99gif | 在线欧美亚洲| 蜜臀久久99精品久久久久久9| 久久成人av少妇免费| 在线视频成人| 亚洲国产精品久久| 欧美日韩亚洲在线| 亚洲欧美日韩国产一区| 亚洲综合日本| 极品少妇一区二区三区| 免费在线观看成人av| 免费日韩av| 亚洲主播在线播放| 久久福利毛片| 亚洲精品中文在线| 日韩视频免费在线| 国产私拍一区| 欧美成人精品在线视频| 欧美激情亚洲激情| 欧美亚洲色图校园春色| 久久久久免费观看| 一级成人国产| 久久精品亚洲一区二区| 一区二区三区 在线观看视频| 亚洲字幕一区二区| 亚洲精品一区二区三区婷婷月| 在线视频欧美日韩精品| 韩曰欧美视频免费观看| 亚洲日本电影| 国外成人在线视频网站| 日韩天堂av| 有码中文亚洲精品| 在线综合+亚洲+欧美中文字幕| 一区在线免费| 亚洲综合另类| 中国亚洲黄色| 免费视频亚洲| 久久尤物视频| 国产精品美女诱惑| 亚洲激情一区| 在线看片欧美| 亚洲宅男天堂在线观看无病毒| 日韩视频一区二区在线观看| 久久福利毛片| 久久国产精彩视频| 欧美日韩一区二区三| 欧美刺激性大交免费视频| 国产女同一区二区| 亚洲视频二区| 亚洲一区国产精品| 欧美久久久久久蜜桃| 欧美成人四级电影| 136国产福利精品导航网址| 亚洲综合视频1区| 亚洲一区二区高清| 欧美伦理在线观看| 欧美激情一区二区三区| 亚洲大片在线| 久久免费视频一区| 老司机免费视频一区二区| 国语自产精品视频在线看| 午夜精品久久久久久久久久久久| 国产精品国产三级欧美二区| 亚洲国产三级网| 亚洲国产一区视频| 久久综合九色欧美综合狠狠| 美女精品网站| 亚洲承认在线| 欧美大片在线看免费观看| 欧美激情在线| 一区二区冒白浆视频| 欧美日韩在线高清| 一区二区三区视频免费在线观看| 亚洲精品乱码久久久久久按摩观 | 校园激情久久| 久久久99久久精品女同性| 国产免费亚洲高清| 性欧美超级视频| 另类酷文…触手系列精品集v1小说| 国产午夜精品理论片a级大结局| 午夜精品久久久久久久久久久| 久久成人一区| 伊人久久亚洲热| 欧美电影免费观看高清完整版| 91久久精品一区二区别| 一本一本久久| 国产精品久久久久9999吃药| 亚洲免费在线观看| 毛片精品免费在线观看| 最新成人av网站| 欧美午夜精品久久久久久孕妇| 午夜久久久久久| 欧美本精品男人aⅴ天堂| 亚洲免费观看高清在线观看 | 亚洲一区观看| 国产视频一区欧美| 欧美a级一区二区| 一区二区三区精品国产| 久久精品av麻豆的观看方式 | 日韩午夜中文字幕| 国产精品久久久一区麻豆最新章节| 欧美一区二区三区的| 欧美激情亚洲| 欧美一区二区在线看| 最新国产の精品合集bt伙计| 国产精品久久久999| 免费视频最近日韩| 午夜精彩国产免费不卡不顿大片| 欧美国产成人精品| 午夜精品久久久久久| 亚洲国产视频a| 国产欧美亚洲日本| 欧美日韩xxxxx| 免费日韩av电影| 午夜在线视频观看日韩17c| 亚洲激情国产精品| 久久中文字幕导航| 午夜免费日韩视频| 夜夜嗨av一区二区三区网站四季av| 好看的日韩av电影| 国产欧美69| 欧美性大战久久久久久久| 欧美不卡视频一区| 久久久久久一区二区| 欧美一级午夜免费电影| 夜夜嗨av一区二区三区| 在线综合亚洲欧美在线视频|