使用libmemcached操做memcached

 

首先启动memcached ios

memcached -m 512 -p 11211 -vv数据库

memcached -m 512 -p 11212 -vvapp

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

 

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

 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 -lmemcachedspa

相关文章
相关标签/搜索