linux 安装memcached C/C++使用libmemcached库

memcached是高性能的分布式内存缓存服务器。一般的使用目的是,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web应用的速度、提高可扩展性。,下面就Linux下对memcached的安装与使用进行简单介绍。
安装环境:Ubuntu11.04 + libevent-2.0.18 + memcached-1.4.13 + libmemcached-1.0.4

一、安装libevent
由于memcached用到了libevent这个库中关于Socket的处理,所以安装memcached之前需安装libevent,目前(2012.5.2)最近版本是libevent-2.0.18-stable.tar.gz,安装方法如下:
#tar zxvf libevent-2.0.18-stable.tar.gz
#cd libevent-2.0.18-stable
#./configure –prefix=/usr/local/libevent
#make
#make intsall

二、安装memcached服务器
安装memcached时需要指定libevent的安装路径,目前(2012.5.2)最新版本是memcached-1.4.13.tar.gz,安装方法如下:
#tar zxvf memcached-1.4.13.tar.gz
#cd memcached-1.4.13
#./configure –prefix=/usr/local/memcached –with-libevent=/usr/local/libevent
#make
#make intsall

三、安装libmemcached客户端
libmemcached是一个用C/C++语言编写的客户端开发包,其主要用途是用 来链接到memcached缓存服务器。目前(2012.5.2)最新版本是libmemcached-1.0.7.tar.gz,但笔者在编译安装过程 中,出现找不到event.h的错误,所以采用较早的版本libmemcached-1.0.4.tar.gz,安装方法如下:
#tar zxvf libmemcached-1.0.4.tar.gz
#cd libmemcached-1.0.4
#./configure –prefix=/usr/local/libmemcached
#make
#make intsall

经过上面三个步骤,memcached的服务程序及客户端的安装就算完成了…

四、启动memcached服务器
启动Memcache的服务器端的命令为:
#/usr/local/memcached/bin/memcached -d -m 10 -u root -l 127.0.0.1 -p 12000 -c 256 -P /tmp/memcached.pid
命令选项说明:
-d选项 启动一个守护进程,
-m选项 分配给memcache使用的内存数量,单位是MB,命令中是10MB,
-u选项 运行memcache的用户,命令中是root,
-l选项 监听的服务器IP地址,如果有多个地址的话,命令中指定了服务器的IP地址本地主机127.0.0.1,
-p选项 设置memcache监听的端口,我这里设置了12000,最好是1024以上的端口,
-c选项 最大运行的并发连接数,默认是1024,命令中设置为256,一般按照服务器的负载量来设定,
-P选项 设置保存memcache的pid文件,命令中保存在 /tmp/memcached.pid。
如果想开机自动启动的话,只需在/etc/rc.d/rc.local中加入一行上面命令。
也有人用命令:#/usr/local/memcached/bin/memcached -d -m 10 -u deamon -p 12000
上面命令有些选项可以参考一下:即,ip不指定时,默认为本地主机;用户最好选择为:deamon 或 apache,这样也就是属于哪个用户的服务,由哪个用户来启动。
故我们采用如下命令启动memcached服务器:#/usr/local/memcached/bin/memcached -d -m 10 -u deamon -l 127.0.0.1 -p 12000 -c 256 -P /tmp/memcached.pid

五、简单的例子
测试文件:testmemcached.cc
#include <iostream>
#include <string>
#include <libmemcached/memcached.h>
using namespace std;
int main(int argc,char *argv[])
{
          //connect server
         memcached_st *memc;
         memcached_return rc;
         memcached_server_st *servers;
         time_t expiration = 180;
         uint32_t flags = 0;
         memc = memcached_create(NULL);
         server = memcached_server_list_append(NULL, “localhost”, 12000, &rc);
         rc = memcached_server_push(memc, servers);
         memcached_server_list_free(servers);
         string key = “memory”;
         string value = “libmemcached”;
         size_t value_length = value.length();
         size_t key_length = key.length();
         //Save data
         rc = memcached_set(memc, key.c_str(), key.length(), value.c_str(), value.length(), expiration, flags);
         if(rc == MEMCACHED_SUCCESS)
         {
                   cout<<”Save data: “<<value<<” successful!”<<endl;
         }
        //Get data
        char* result = memcached_get(memc, key.c_str(), key_length, &value_length, &flags, &rc);
        if(rc == MEMCACHED_SUCCESS)
        {
                   cout<<”Get value: “<<result_value<<” by key \”"<<key<<”\” successful!”<<endl;
        }
       //Delete data
       rc = memcached_delete(memc, key.c_str(), key_length, expiration);
       if(rc == MEMCACHED_SUCCESS)
       {
                  cout<<”Delete data: “<<value<<” successful!”<<endl;
       }
      //free
      memcached_free(memc);
      return 0;
}
编译及运行:
#g++ -o testmemcached testmemcached.cc -I/usr/local/libmemcached/include -L/usr/local/libmemcached/lib -lmemcached
#./testmemcached
正确运行结果是:
Save data: libmemcached successful!
Get value: libmemcached by key “memory” successful!
Delete data: libmemcached successful!

几点说明:
1、编译过程中需要引入头文件-I/usr/local/libmemcached/include,否则编译源代码时会报找不到#include <libmemcached/memcached.h>的错误;
2、运行过程中,需要将libmemcached.so文件所在目录加入到变量LD_LIBRARY_PATH中,即export LD_LIBRARY_PATH=/usr/local/libmemcached/lib:$LD_LIBRARY_PATH,否则运行时会提示类似libmemcached.so.9: cannot open shared object file: No such file or directory找不到库的错误。

来源http://www.yongblog.com/archives/386.html

来源://作者:/更新时间:2014-01-27
相关文章

最新文章

新热推荐

文章排行