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

[经验分享] 【转】LoadRunner使用Libmemcached与Memcached通讯

[复制链接]

尚未签到

发表于 2015-9-1 12:26:30 | 显示全部楼层 |阅读模式

  在一包含业务的大数据量测试过程中,需要使用快速、大容量的数据库。
  可考虑的有关系型数据库或键值缓存数据库,建立集群。 LoadRunner操作Mysql实例:C语言篇已完成。
  今日来尝试在LoadRunner里操作Memcached,使用Libmemcached。
  首先下载源码:‍http://svn.coderepos.org/share/lang/c/libmemcached-win32
  然后按照说明进行编译,源码里还有测试代码和示例代码。编译方法有三种:
  一、使用‍mingw32进行编译,打开‍ Visual Studio Command Prompt:
  


‍    ‍    cd libmemcached-latest\libmemcached
‍    ‍    mingw32-make -f Makefile.w32

‍    ‍    cd ..\cilents
‍    ‍    mingw32-make -f Makefile.w32

‍    ‍    cd ..\..\example
‍    ‍    mingw32-make -f Makefile.w32

    二、使用Visual Studio 2005或更高版本执行编译:
‍    ‍    libmemcached-latest\visualc\libmemcached.sln

    三、使用nmake进行编译,‍打开‍ Visual Studio Command Prompt:


‍    ‍    cd libmemcached-latest\libmemcached
‍    ‍    nmake -f Makefile.msc

‍‍    ‍    cd ..\cilents
‍    ‍    nmake -f Makefile.msc

‍    ‍    cd ..\..\example
‍‍    ‍    nmake -f Makefile.msc
    编译过程将生成memcached.dll,供LoadRunner扩展调用。如下图:
‍‍  
  
  源码:
  


#define SERVER_NAME "192.168.223.106"
#define SERVER_PORT 11211
Action(){ //先加载libmemcached.dll
    int memc;
    int rc;
    int value_length=0;
    intf lags=0;
    int result;
    long int num;
    char* key="name";
    char* value="higkoo";
    char* discription="Performance";

    memc=memcached_create(NULL);
    rc=memcached_server_add(memc,SERVER_NAME,SERVER_PORT);
    lr_output_message("server add: %s\n",memcached_strerror(memc,rc));

     rc=memcached_set(memc,key,strlen(key),value,strlen(value),0,0);
     lr_output_message("set '%s' to '%s': %s\n",key,value,memcached_strerror(memc,rc));

    result=memcached_get(memc,key,strlen(key),&value_length,&flags,&rc);
    lr_output_message("get '%s': %s\n",key,memcached_strerror(memc,rc));
    lr_output_message("%s = %s\n",key,result);

    rc=memcached_behavior_set(memc,0,1);
    lr_output_message("behavior set to non-block: %s\n",memcached_strerror(memc,rc));

    result=memcached_get(memc,key,strlen(key),&value_length,&flags,&rc);
    lr_output_message("get '%s': %s\n",key,memcached_strerror(memc,rc));
    lr_output_message("%s = %s\n",key,value);

    rc=memcached_set(memc,key,strlen(key),discription,strlen(discription),0,0);
    lr_output_message("set '%s' to '%s': %s\n",key,discription,memcached_strerror(memc,rc));

    rc=memcached_increment(memc,key,strlen(key),1,&num);
    lr_output_message("incr '%s': %s\n",key,memcached_strerror(memc,rc));
    rc=memcached_increment(memc,key,strlen(key),1,&num);
    lr_output_message("incr '%s': %s\n",key,memcached_strerror(memc,rc));
    rc=memcached_increment(memc,key,strlen(key),1,&num);
    lr_output_message("incr '%s': %s\n",key,memcached_strerror(memc,rc));
    rc=memcached_decrement(memc,key,strlen(key),1,&num);
    lr_output_message("decr '%s': %s\n",key,memcached_strerror(memc,rc));

    result=memcached_get(memc,key,strlen(key),&value_length,&flags,&rc);
    lr_output_message("get '%s': %s\n",key,memcached_strerror(memc,rc));
    lr_output_message("test = %s\n",value);

    rc=memcached_delete(memc,key,strlen(key),0);
    lr_output_message("delete '%s': %s\n",key,memcached_strerror(memc,rc));

    result=memcached_get(memc,key,strlen(key),&value_length,&flags,&rc);
    lr_output_message("get(was deleted) '%s': %s\n",key,memcached_strerror(memc,rc));

    memcached_free(memc);
}  
  ...


运维网声明 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-108351-1-1.html 上篇帖子: linux下memcached服务器端安装 下篇帖子: 分布式内存对象缓存系统Memcached-概述
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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