感谢支持
我们一直在努力

在Ubuntu上安装memcached和libmemcached

最近想写一些关于C语言的服务器端的程序,所以想在Ubuntu上安装memcached 和libmemcached。


一、安装软件


1  //安装memcached


2  sudo apt-get install memcached


3  //安装libevent-dev


4  sudo apt-get install libevent-dev


5  //这个很重要,不然libmemcached就不能运行


6  sudo ln -s /usr/ local /lib/libmemcached.so.3 /usr/lib/libmemcached.so.3


然后下载libmemcached-0.34 ,安装。


./configure的时候,如果你的Memcached不是默认安装路径的话,会报


configure: error: “could not find memcached binary”


错,如下的类似的命令可以解决这个问题。


./configure –with-memcached=/home/app/memcached/bin/memcached


二、启动软件并测试


运行memcached


1  memcached -d -m 64 -l 127.0.0.1 -p 11211


在当前目录创建测试数据文件,也可以运行


1  echo “test memcached” >data


然后测试


1  //缓存data文件数据


2  memcp data –servers=127.0.0.1:11211


3  //拿到data文件数据


4  memcat data –servers=127.0.0.1:11211


这时控制台上显示


1  test memcached


———————————–


其实用SHELL命令


sudo apt-get install libmemcached-tools


就可以了。

memcached简单的使用教程


这是工程应用性质的文章:memcached是数据快速存取的工具,wikipedia和facebook就用了它提高速度。具体情况可以wiki.


c/c++里面使用memcached本来是很简单的事情,但就是没有人说,非要我去读libmemcache的实例代码才行,manpage也没有说清楚(但还不得不看)。如果要使用memcached,步骤如下:


1 安装memcached
  你可以去官网上下载,也可以sudo apt-get install memcached
2 测试你刚才的安装,
  比如运行 memcached -d -m 64 -l 127.0.0.1 -p 12300
  -d表示后台, -m 64表示使用64MB内存,-l 127.0.0.1 -p 12300 表示监听127.0.0.1:12300端口
  没有任何消息就是运行成功
3 安装libmemcached
  这个就不要apt了,因为没有精确的libmemcached包,乖乖去官网下载吧。这个东西还需要libevent,这个没法apt,libevent安装的时候最好装到/usr/lib里面,不然libmemcached还不能运行。
4 测试libmemcached
  找一个文件比如test,然后运行memcp test –servers=127.0.0.1:12300
  这样就把test拷贝到memcached管理的内存里面了。
  memcat test –servers=127.0.0.1:12300
  看看是不是刚才的那个文件。


该装的全装了,我们可以改代码了。


(以下引自:wikipedia)



将纯粹使用数据库查询的程式码加上memcached支援是很简单的,假设这是原来的程式码:


function get_foo (int userid) {   result = db_select(“SELECT * FROM users WHERE userid = ?”, userid);   return result;}加上memcached的快取机制后:


function get_foo (int userid) {    result = memcached_fetch(“userrow:” + userid);    if (!result) {        result = db_select(“SELECT * FROM users WHERE userid = ?”, userid);        memcached_add(“userrow:” + userid,  result);    }    return result;}(wikipedia 引述完毕)但我们需要初始化,而且需要c/c++的表述形式:
首先修改makefile,在LIBS里面加上-lmemcached,比如原来 gcc test.c,现在 gcc test.c -lmemcached。这个库就是libmemcached提供的。
然后添加#include<libmemcached/memcached.h>,这个文件也是libmemcached提供的。
主函数里面需要添加:
    memcached_st *memc;
    uint32_t  flags;
    memcached_return rc;
    memcached_server_st *servers;
    memc= memcached_create(NULL);


    servers= memcached_servers_parse(“127.0.0.1:12300”);
    memcached_server_push(memc, servers);
    memcached_server_list_free(servers);
    memcached_behavior_set(memc, MEMCACHED_BEHAVIOR_BINARY_PROTOCOL, 0);
   
这就是初始化的全部代码,可以设置很多东西,不过我现在只要一个服务器,就看一句话:
    servers= memcached_servers_parse(“127.0.0.1:12300”);
这就是指明要连接到位于127.0.0.1监听12300端口的memcached程序. 其他都不管。


我最后用一段修改后的代码介绍两个函数,memcached_get和memcached_set,都可以man出来。


        char * result_str; /*这个就是查询的结果*/
        std::string query=”要查询的数据名”;


        result_str= memcached_get(memc, query.c_str(), strlen(query.c_str()),
                &result_str_length, &flags, &rc);


        if (rc == MEMCACHED_SUCCESS)
        {
            printf(“%s”,result_str);
            free(result_str); /*一定要free掉 memcached传回的数据*/


            continue;
        }
        else if (rc == MEMCACHED_NOTFOUND)
        {
            /*读取数据*/
            …
            rc= memcached_set(memc, query.c_str(), strlen(query.c_str()),
                    str_result.c_str(), strlen(str_result.c_str()),
                    0, 0);
        }


这东西设计得还是很好用的,libmemcached好像是面向对象C语言风格的东西,好不好用就让我们拭目以待吧。

赞(0) 打赏
转载请注明出处:服务器评测 » 在Ubuntu上安装memcached和libmemcached
分享到: 更多 (0)

听说打赏我的人,都进福布斯排行榜啦!

支付宝扫一扫打赏

微信扫一扫打赏