博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

使用libmemcached操作memcached

Posted on 2013-09-07 10:14  david2303  阅读(540)  评论(0编辑  收藏  举报

 

首先启动memcached 

memcached -m 512 -p 11211 -vv

memcached -m 512 -p 11212 -vv

该例分配给 memcached 的可用内存 512M, 监听 11211 端口, 另外一个监听11212端口, 显示详细的运行信息。

 

使用方法,我将用代码+注释来说明, test.cpp

 1 #include <iostream>
 2 #include <string>
 3 #include <libmemcached/memcached.h>
 4 
 5 using namespace std;
 6 
 7 int main(int argc, char** argv)
 8 {
 9     memcached_st *memc;
10     memcached_return rc;
11     memcached_server_st *servers;
12     time_t expiration = 0;
13     uint32_t  flags;
14     
15     memc = memcached_create(NULL);
16     // 把memcached加入列表, 假如开了两个memcached,如下方法
17     servers = memcached_server_list_append(NULL, "localhost", 11211, &rc);
18     servers = memcached_server_list_append(servers, "localhost", 11212, &rc);
19     rc=memcached_server_push(memc, server);
20     
21     // 使用一致性哈希  http://blog.csdn.net/sparkliang/article/details/5279393
22     // http://stackoverflow.com/questions/16757511/how-to-use-consistent-hashing-in-memcached-c-client/18482345#18482345
23     memcached_return_t rc2 = memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_KETAMA, 1);
24     
25     
26     string key = "keyyy";
27     string value = "123456";
28     size_t value_length = value.length();
29     size_t key_length = key.length();
30     
31     //把数据保存到memcached
32     rc= memcached_set(memc, key.c_str(), key.length(), value.c_str(), value.length(), expiration, flags);
33     
34     
35     //提取数据
36     char* result = memcached_get(memc, key.c_str(), key_length, &value_length, &flags, &rc);
37     if(rc!=MEMCACHED_SUCCESS)
38     {
39         // 如果是结合数据库的话
40         // 此步应该去数据库查询,然后把结果保存一份到memcached
41     }
42     
43     
44     //删除数据
45     rc= memcached_delete(memc,key.c_str(),key_length,expiration);
46     
47     
48     //释放
49     memcached_server_list_free(server);
50     memcached_free(memc);
51     
52     return 0;
53     
54 }

 

g++ test.cpp -lmemcached