设为首页 收藏本站
查看: 1996|回复: 0

[经验分享] linux 安装memcached C/C++使用libmemcached库

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-7-8 10:38:32 | 显示全部楼层 |阅读模式
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找不到库的错误。


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-21787-1-1.html 上篇帖子: memcached 主要启动流程笔记 下篇帖子: linux 安装memcached C/C++使用libmemcached库(续) linux
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表