在linux C中使用memcache

memcached是高性能的分布式内存缓存服务器。一般的使用目的是,通过缓存数据库查询结果,减少数据库访问次数,以提高动态Web应用的速度、提高可扩展性。

一、安装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 1024 -u root -l 127.0.0.1 -p 11211 -c 1024 -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中加入一行上面命令。


程序示例:

#include <stdio.h>
#include <stdlib.h>
#include <libmemcached/memcached.h>

/*
 * 测试 memcached 的使用
 */
int main(int argc, char* argv[]) {
    // connect server
    memcached_st* memc;
    memcached_return rc;
    memcached_server_st* mems;
    time_t expir = 0;
    uint32_t flag = 0;
    const char* res;
    const char* key = "hello";
    size_t klen = strlen(key), vlen;

    // 开始测试, 可以不用添加检测代码, 这里只为了知道有这个api
    memc = memcached_create(NULL);
    mems = memcached_server_list_append(NULL, "127.0.0.1", 11211, &rc);//若本机也可以 mems = memcached_server_list_append(NULL, "localhost", 11211, &rc);
    if(!memcached_success(rc)){
        fprintf(stderr, "添加服务器列表失败!\n");
        exit(EXIT_FAILURE);
    }
    // 这东西目前唯一资料就是libmemcached源码
    rc = memcached_server_push(memc, mems);
    if(!memcached_success(rc)) {
        fprintf(stderr, "添加服务器列表向客户端失败!");
        exit(EXIT_FAILURE);
    }
    memcached_server_list_free(mems);

    // 开始设置数据
    rc = memcached_set(memc, key, klen, "world", 5 , expir, flag);
    if(rc == MEMCACHED_SUCCESS)
        printf("Set data<hello, world> => %d\n", rc);

    // 这里得到数据
    res = memcached_get(memc, key, klen, &vlen, &flag, &rc);
    if(rc == MEMCACHED_SUCCESS) 
        printf("get value:%s, len:%ld, flag:%d\n", res, vlen, flag);
    
    // 删除数据
    rc = memcached_delete(memc, key, klen, expir);
    if(rc == MEMCACHED_SUCCESS)
        printf("%s 删除成功!\n", key);
    else
        puts("删除失败!");
    
    // free
    memcached_free(memc);

    return 0;    
}
编译:gcc test.c -o test -I /usr/local/libmemcached/include -L /usr/local/libmemcached/lib -lmemcached

转载地址:http://www.jsjtt.com/xitongyingyong/linux/58.html

完!!

阅读更多
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页