转载请注明来源:https://www.cnblogs.com/hookjc/


  1. #include<stdio.h>
  2. #include <iostream>
  3. #include <string>
  4. #include <map>
  5. #include <libmemcached/memcached.h>
  6. using namespace std;
  7. int main()
  8. {
  9. char szIp[] = "127.0.0.1";
  10. int iPort = 11211;
  11. memcached_st  *pstMCache = memcached_create(NULL);
  12. int iResult = memcached_server_add(pstMCache, szIp, iPort); //支持多台cache的分布式
  13. //使用二进制协议传输
  14. iResult = memcached_behavior_set(pstMCache, MEMCACHED_BEHAVIOR_BINARY_PROTOCOL, 1);
  15. if (iResult != MEMCACHED_SUCCESS)
  16. {
  17. printf("memcached_server_add fail %s:%d", szIp, iPort);
  18. return -1;
  19. }
  20. //使用Consistent hashing算法将key分配到不同机器的不同位置
  21. iResult = memcached_behavior_set(pstMCache, MEMCACHED_BEHAVIOR_KETAMA_WEIGHTED, 1);
  22. if (iResult != MEMCACHED_SUCCESS)
  23. {
  24. printf("[%s]Error:memcached_behavior_set MEMCACHED_BEHAVIOR_KETAMA_WEIGHTED fail", __FUNCTION__);
  25. return -2;
  26. }
  27. //使用NO-BLOCK,防止memcache倒掉时挂死
  28. iResult = memcached_behavior_set(pstMCache,MEMCACHED_BEHAVIOR_NO_BLOCK, 1);
  29. if (iResult != MEMCACHED_SUCCESS)
  30. {
  31. printf("[%s]Error:memcached_behavior_set MEMCACHED_BEHAVIOR_KETAMA_WEIGHTED fail", __FUNCTION__);
  32. return -3;
  33. }
  34. memcached_return rc;
  35. string key = "10000";
  36. string val = "测试内容1";
  37. rc = memcached_set(pstMCache, key.c_str(), key.size(), val.c_str(), val.size(), 0, 0);
  38. if (rc == MEMCACHED_SUCCESS)
  39. {   //set成功,进行get
  40. unsigned int flags = 0;
  41. char *mc_val = NULL;
  42. size_t val_len = 0;
  43. mc_val = memcached_get(pstMCache, key.c_str(), key.size(), &val_len, &flags, &rc);
  44. if (rc == MEMCACHED_SUCCESS)
  45. {
  46. printf("buffer:%s|len:%Zd|cas:%ld\n", mc_val, val_len, pstMCache->result.item_cas);
  47. if ( mc_val != NULL ){
  48. free(mc_val);
  49. mc_val = NULL;
  50. }
  51. }
  52. else
  53. {
  54. if ( mc_val != NULL ){
  55. free(mc_val);
  56. mc_val = NULL;
  57. }
  58. string  err = memcached_strerror(pstMCache, rc);
  59. printf("err:%s\n", err.c_str());
  60. return -4;
  61. }
  62. string val1 = "测试内容2";
  63. //做了并发容错的memcached_cas  写操作,服务器维持了一个cas序列号,每次调用memcached_cas时,会判断之前get出来的cas是否发生了变化,变化了的话,说明已经被其他程序给修改了
  64. rc= memcached_cas(pstMCache, key.c_str(), key.size(), val1.c_str(), val1.size(),0, 0, pstMCache->result.item_cas/*这个值是唯一序列*/);
  65. if (rc == MEMCACHED_SUCCESS)
  66. {
  67. printf("rc:%d\n", rc);
  68. }
  69. else
  70. {
  71. string  err = memcached_strerror(pstMCache, rc);
  72. printf("err:%s\n", err.c_str());
  73. }
  74. mc_val = memcached_get(pstMCache, key.c_str(), key.size(), &val_len, &flags, &rc);
  75. if (rc == MEMCACHED_SUCCESS)
  76. {
  77. printf("buffer:%s|len:%Zd\n", mc_val, val_len);
  78. }
  79. else
  80. {
  81. string  err = memcached_strerror(pstMCache, rc);
  82. printf("err:%s\n", err.c_str());
  83. return -4;
  84. }
  85. }
  86. else
  87. {
  88. string  err = memcached_strerror(pstMCache, rc);
  89. printf("err:%s\n", err.c_str());
  90. return -5;
  91. }
  92. return 0;
  93. }

来源:python脚本自动迁移

memcached 测试代码的更多相关文章

  1. .NET单元测试的艺术-3.测试代码

    开篇:上一篇我们学习单元测试和核心技术:存根.模拟对象和隔离框架,它们是我们进行高质量单元测试的技术基础.本篇会集中在管理和组织单元测试的技术,以及如何确保在真实项目中进行高质量的单元测试. 系列目录 ...

  2. mysql锁 实战测试代码

    存储引擎 支持的锁定 MyISAM 表级锁 MEMORY 表级锁 InnoDB 行级锁 BDB 页面锁 表级锁:开销小,加锁快:不会出现死锁:锁定粒度大,发生锁冲突的概率最高,并发度最低.行级锁:开销 ...

  3. 使用Microsoft Fakes隔离测试代码

    在单元测试(Unit Test)中我们遇到的问题之一是:假如被测试组件(类或项目)为A,组件A依赖于组件B,那么在组件A的单元测试ATest中测试A时,也需要依赖于B,在B发生改动后,就可能影响到A的 ...

  4. iOS开发:XCTest单元测试(附上一个单例的测试代码)

    测试驱动开发并不是一个很新鲜的概念了.在我最开始学习程序编写时,最喜欢干的事情就是编写一段代码,然后运行观察结果是否正确.我所学习第一门语言是c语言,用的最多的是在算法设计上,那时候最常做的事情就是编 ...

  5. 在内核中异步请求设备固件firmware的测试代码

    在内核中异步请求设备固件firmware的测试代码 static void ghost_load_firmware_callback(const struct firmware *fw, void * ...

  6. x264测试代码

    建立一个工程,将头文件,库文件加载到工程,测试代码如下:#include <iostream>#include <string>#include "stdint.h& ...

  7. Android网络传输中必用的两个加密算法:MD5 和 RSA (附java完成测试代码)

    MD5和RSA是网络传输中最常用的两个算法,了解这两个算法原理后就能大致知道加密是怎么一回事了.但这两种算法使用环境有差异,刚好互补. 一.MD5算法 首先MD5是不可逆的,只能加密而不能解密.比如明 ...

  8. Git合并开发代码分支到测试代码分支

    ——转载请注明出自天外归云的博客园 用TortoiseGit下载代码到本地 首先需要在本机安装好TortoiseGit.然后在随便哪个路径下比如D盘,右键“Git Clone”: 然后URL处选择项目 ...

  9. mvn编写主代码与测试代码

    maven编写主代码与测试代码 3.2 编写主代码 项目主代码和测试代码不同,项目的主代码会被打包到最终的构件中(比如jar),而测试代码只在运行测试时用到,不会被打包.默认情况下,Maven假设项目 ...

随机推荐

  1. [opencv]二维码识别开发流程及问题复盘总结

    项目复盘总结 开发需求: 在桌面机器人(向下俯视)摄像头拍摄到的图像中做条形码识别与二维码识别. 条形码在图像固定位置,二维码做成卡片的形式在固定区域内随意摆放. 开发环境及相关库:ubuntu 18 ...

  2. CS5211替代PS8625|设计DP转LVDS转接板|替代PS8625方案

    1.CS5211与PS8625功能概述 CS5211是一个eDP到LVDS转换器,配置灵活,适用于低成本显示系统.CS5211与eDP 1.2兼容,支持1通道和2通道模式,每通道速度为1.62Gbps ...

  3. CS5210|低成本HDMI转VGA方案|CS5210参数说明

    Capstone最新推出的一款HDMI转VGA音视频转接线或者转换器方案芯片CS5210. 其设计的优势在于内置晶振,外围电路器件较少设计简单,芯片封装集成度较高,方案BOM成本低,相比其他方案产品更 ...

  4. Java实习生常规技术面试题每日十题Java基础(三)

    目录 1.是否可以从一个static方法内部发出对非static方法的调用? 2.Integer与int的区别? 3.Overload和Override的区别.参数列表相同,返回值不同的方法,是否是重 ...

  5. Java高级程序设计笔记 • 【第5章 XML解析】

    全部章节   >>>> 本章目录 5.1 XML 文档概述 5.1.1 XML文档结构 5.1.1 XML结构说明 5.1.1 XML文档元素 5.1.2 XML文档语法规范 ...

  6. Oracle之增、删、改、查

    结构化查询语言 (Structured Query Language, SQL) SQL的组成: 数据操作语言(DML) 对数据进行查询.插入.删除和修改等操作,例如SELECT.INSERT.UPD ...

  7. 『无为则无心』Python函数 — 32、递归

    目录 1.什么叫递归函数 2.递归的应用场景 3.递归的特点 4.应用:3以内数字累加和 5.应用:阶乘 6.总结 1.什么叫递归函数 Python中,在函数内部,可以调用其他函数.如果一个函数在内部 ...

  8. 为EasySharding.EFCore提供Dapper相关查询扩展

    承接上一篇博文中的中间件基本都是写入性的操作,但对于查询操作实际上是比较鸡肋的,如果单纯的查询,没有分表的情况下基本还能适应,这里为了Dapper提供了扩展 Dapper的扩展查询是需要写表名称的,所 ...

  9. windows环境jdk8下载安装与配置环境变量

    1)jdk8官网下载地址 Java Downloads | Oracle 下载前需登录Oracle账号,没有的话可以用邮箱注册一个,登录之后即可进行下载. 2)jdk8安装 ①下载完成之后双击运行文件 ...

  10. RabbitMQ --- 直连交换机 【 无回调方法,不能获取消费结果 】

    1.前言 消息队列除了kafka 外,还有许多种,比如RabbitMQ .ActiveMQ.ZeroMQ.JMQ等. 老牌的ActiveMQ ,底层使用Java写的,资源消耗大,速度也慢,但是适合 J ...