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

loop_in_codes

低調做技術__歡迎移步我的獨立博客 codemaro.com 微博 kevinlynx

自己實現memcached客戶端庫

Kevin Lynx

7.21.2008

What's memcached ?

memcached是一個以key-value的形式緩存數據的緩存系統。通過將數據緩存到內存中,從而提高數據的獲取速度。
memcached以key-value的形式來保存數據,你可以為你每一段數據關聯一個key,然后以后可以通過這個key獲取
這段數據。

memcached是一個庫還是什么?memcached其實是一個單獨的網絡服務器程序。它的網絡底層基于libevent,你可以
將其運行在網絡中的一臺服務器上,通過網絡,在遵循memcached的協議的基礎上與memcached服務器進行通信。

What do we want to wrap ?

我們需要做什么?我們只需要遵循memcached的協議(參見該文檔),封裝網絡層的通信,讓上層可以通過調用諸如
add/get之類的接口即可實現往memcached服務器緩存數據,以及取數據。上層程序員根本不知道這些數據在網絡
上存在過。

這個東西,也就是memcached官方所謂的client apis。你可以使用現成的客戶端庫,但是你也可以將這種重造輪子
的工作當作一次網絡編程的練習。it's up to you.:D

Where to start ?

很遺憾,對于windows用戶而言,memcached官方沒有給出一個可以執行或者可以直接F7即可得到可執行文件的下載
(如果你是vc用戶)。幸運的是,已經有人做了這個轉換工作。

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

我們直接可以運行memcached.exe來安裝/開啟memcached服務器,具體步驟在以上頁面有所提及:

安裝:memcached.exe -d install,這會在windows服務里添加一個memcached服務
運行:memcached.exe 
-d start,你也可以通過windows的服務管理運行。

   
然后,你可以在任務管理器里看到一個'memcached'的進程,很占內存,因為這是memcached。

So, here we go ...

通過以上步驟運行的memcached,默認在11211端口監聽(是個TCP連接,可以通過netstat查看)。接下來,我們就可
以connect到該端口上,然后send/recv數據了。發送/接收數據只要遵循memcached的協議格式,一切都很簡單。

使用最簡單的阻塞socket連接memcached服務器:

       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

簡單地提一下memcached的協議。

可以說,memcached的協議是基于行的協議,因為無論是客戶端請求還是服務器端應答,都是以"\r\n"作為結束符。
memcached的協議將數據(send/recv操作的數據)分為兩種類型:命令和用戶數據。

命令用于服務器和客戶端進行交互;而用戶數據,很顯然,就是用戶想要緩存的數據。

關于用戶數據,你只需要將其編碼成字節流(說白了,只要send函數允許即可),并附帶數據結束標志"\r\n"發送即可。

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

關于key,memcached用key來標識數據,每一個key都是一個不超過255個字符的字符串。

到這里,你可以發現memcached對于數據的存儲方式(暴露給上層)多少有點像std::map,如果你愿意,你可以將客戶端
API封裝成map形式。= =#

具體實現

接下來可以看看具體的實現了。

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

        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選項對于有些memcached版本并不被支持,例如我們使用的1.2.2版本。注意官方的changelog即可。

當你發送了存儲命令后,memcached會等待客戶端發送數據塊。所以我們繼續發送數據塊:

 

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

 

然后,正常的話,memcached服務器會返回應答信息給客戶端。

 

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

 

如果存儲成功,服務器會返回STORED字符串。memcached所有應答信息都是以字符串的形式給出的。所以可以直接printf出來。

關于其他的操作,我就不在這里列舉例子了。我提供了我封裝的memcached客戶端庫的完整代碼下載,使用的是阻塞socket,
對應著memcached的協議看,很容易看懂的。

It's a story about a programmer...

最近發覺自己有點極端,要么寫純C的代碼,要么寫滿是template的泛型代碼。

 

相關代碼下載

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

評論

# re: 自己實現memcached客戶端庫 2008-10-23 16:56 浪跡天涯

學習了!
不知博主是否真實測試過采用memcached的服務器性能有多少提升?  回復  更多評論   

# re: 自己實現memcached客戶端庫[未登錄] 2008-10-23 20:44 Kevin Lynx

@浪跡天涯
老實說,實際項目里還沒用過memcached。  回復  更多評論   

# re: 自己實現memcached客戶端庫 2009-03-26 17:35 阿斯蒂芬

你的代碼在linux上編譯報出這個錯誤error: storage size of 'addr' isn't known
行號在sizeof( addr ).也就是獲取結構大小的時候.  回復  更多評論   

# re: 自己實現memcached客戶端庫[未登錄] 2009-03-26 18:05 Kevin Lynx

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

# re: 自己實現memcached客戶端庫 2011-06-21 11:23 110

@阿斯蒂芬
這是windows下的代碼,姐  回復  更多評論   

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲国产精品成人久久综合一区| 一本色道久久综合狠狠躁的推荐| 亚洲精品中文字幕在线| 亚洲女女女同性video| 亚洲视频1区| 一区二区三区久久精品| 中文日韩电影网站| 亚洲综合色噜噜狠狠| 欧美亚洲视频在线观看| 久久久久久91香蕉国产| 欧美不卡高清| 欧美亚州一区二区三区| 国产精自产拍久久久久久| 国产视频亚洲精品| **欧美日韩vr在线| 一区二区欧美视频| 久久av最新网址| 欧美福利精品| 夜夜夜精品看看| 久久黄金**| 欧美精品一区二区久久婷婷| 欧美三级午夜理伦三级中文幕| 国产精品久久久久久久久借妻 | 亚洲蜜桃精久久久久久久| 亚洲毛片在线| 欧美在线一区二区三区| 欧美连裤袜在线视频| 国产女人精品视频| 亚洲精品乱码| 欧美一级二区| 亚洲精品一区二区三区在线观看| 亚洲欧美日韩精品一区二区 | 男人插女人欧美| 亚洲另类黄色| 久久久午夜电影| 国产精品毛片在线| 99pao成人国产永久免费视频| 午夜精品国产更新| 亚洲欧洲一区二区三区| 欧美成人免费在线| 亚洲国产精品ⅴa在线观看 | 久热精品视频在线免费观看 | 欧美成人一区二区三区片免费| 性欧美长视频| 亚洲精品无人区| 欧美va亚洲va香蕉在线| 国产精品视频免费一区| 99国产精品久久久久久久| 亚洲无毛电影| 91久久夜色精品国产网站| 久久精品在这里| 日韩天堂在线视频| 久久美女性网| 午夜精品www| 夜夜狂射影院欧美极品| 香港久久久电影| 久久精品人人做人人爽| 亚洲欧洲精品一区二区三区不卡| 午夜亚洲影视| 欧美xxxx在线观看| 亚洲免费在线看| 欧美成va人片在线观看| 国产视频久久网| 亚洲综合色在线| 99精品视频免费在线观看| 久久亚洲影院| 国产精品一区二区三区四区五区| 国产有码一区二区| 性欧美xxxx大乳国产app| 亚洲免费综合| 最新亚洲视频| 欧美激情国产精品| 亚洲国产成人精品女人久久久| 亚洲国产精品v| 午夜精品在线看| 亚洲国产精彩中文乱码av在线播放| 欧美色播在线播放| 91久久精品国产91性色| 亚洲永久免费| 亚洲一区3d动漫同人无遮挡| 欧美三区不卡| 亚洲专区免费| 欧美一区二区三区四区在线观看| 国产精品亚洲美女av网站| 欧美有码在线视频| 久久精品99无色码中文字幕| 亚洲第一天堂无码专区| 欧美韩日一区二区| 欧美日韩在线不卡| 久久av资源网站| 久久亚洲一区二区三区四区| 亚洲精品美女在线| 日韩视频中文字幕| 国产精品亚洲欧美| 欧美www视频| 欧美日韩国产综合视频在线观看中文| 一区二区三区日韩欧美| 亚洲欧美国产日韩中文字幕| 国产一区二区三区黄视频| 欧美大片一区二区三区| 欧美日韩精品在线视频| 久久久777| 欧美电影电视剧在线观看| 这里只有精品在线播放| 欧美一区二区高清| 日韩视频在线观看| 欧美在线视频一区| 99国内精品久久久久久久软件| 亚洲少妇自拍| 亚洲黄色性网站| 亚洲视频在线观看三级| 在线观看欧美精品| 亚洲欧美日韩国产一区二区三区 | 亚洲电影视频在线| 99视频精品全部免费在线| 国语自产在线不卡| 亚洲激情第一页| 国产午夜精品一区二区三区视频 | 亚洲影视在线播放| 夜夜爽av福利精品导航| 免费一级欧美片在线播放| 亚洲欧美综合网| 欧美午夜一区二区三区免费大片| 欧美成人在线影院| 尤物精品国产第一福利三区 | 亚洲高清在线观看一区| 欧美国产日韩精品免费观看| 麻豆9191精品国产| 一区二区免费在线播放| 国产精品剧情在线亚洲| 亚洲性人人天天夜夜摸| 久久狠狠一本精品综合网| 国产精品二区在线观看| 亚洲视频欧美视频| 亚洲一区二区三区在线观看视频 | 久久久成人网| 免费欧美高清视频| 欧美自拍偷拍午夜视频| 好吊日精品视频| 亚洲影院高清在线| 欧美 亚欧 日韩视频在线| 久久久久久久一区二区| 久久久亚洲综合| 午夜免费在线观看精品视频| 欧美精品一区二区三区久久久竹菊| 久久亚洲精品伦理| 国产麻豆日韩欧美久久| 91久久综合亚洲鲁鲁五月天| 国产美女精品一区二区三区| 久久综合久久综合久久综合| 99在线热播精品免费99热| 欧美一区精品| 久久久亚洲精品一区二区三区 | 伊人久久婷婷| 欧美黑人一区二区三区| 亚洲欧美日韩精品久久亚洲区 | 亚洲在线观看视频网站| 久久精品国产综合精品| 亚洲影院高清在线| 亚洲免费视频在线观看| 香蕉久久一区二区不卡无毒影院 | 久久久久久久综合日本| 黄色亚洲免费| 国产精品一卡| 亚洲免费影视| 亚洲图片在线观看| 国产精品美女一区二区在线观看| 玖玖综合伊人| 亚洲欧美激情在线视频| 亚洲精品国产欧美| 亚洲毛片在线看| 蜜桃av噜噜一区二区三区| 老牛国产精品一区的观看方式| 国产日韩亚洲欧美| 美女精品在线| 一级日韩一区在线观看| 亚洲欧美在线免费观看| 国产一区日韩欧美| 欧美福利小视频| 午夜在线观看免费一区| 欧美高清不卡| 欧美一二区视频| 亚洲激情在线视频| 久久国产精彩视频| 欧美日韩另类字幕中文| 合欧美一区二区三区| 欧美一区二区三区免费在线看| 久久er99精品| 欧美一区二区三区四区在线| 久久亚洲精品一区| 国内精品视频666| 亚洲欧美资源在线| 精品99一区二区三区| 欧美国产免费| 午夜精品久久| 9i看片成人免费高清| 久久久www成人免费精品| 久久一区二区三区四区五区| 欧美人在线视频| 欧美一区2区视频在线观看 |