关键词: Memcached   C++ 客户端

声明:本文并非原创,转自华为云帮助中心的分布式缓存服务(Memcached)的用户指南。客户端连接方法通用,故摘抄过来分享给大家。

C++客户端示例

  • 用户的弹性云服务器已安装好GCC,建议为4.8.4或更高版本。
  • 已获取libmemcached-x.y.z.tar.gz依赖包。
     说明:

    其中x.y.z为依赖包的版本号,建议获取最新版本。

  1. 获取缓存实例的IP地址/域名和端口。
    1. 登录管理控制台
    2. 在管理控制台左上角单击图标,选择区域和项目。
       说明:

      此处请选择与租户的应用服务相同的区域。

    3. 单击页面上方的“服务列表”,选择“数据库 > 分布式缓存服务”,进入分布式缓存服务信息页面。
    4. 单击左侧菜单栏的“缓存管理”,进入缓存实例信息页面。
    5. 单击需要使用的其中一个缓存实例的名称,进入该缓存实例的基本信息页面。查看并获取该分布式缓存实例的IP地址/域名和端口。
  2. 将已获取的libmemcached-x.y.z.tar.gz依赖包上传到已创建的弹性云服务器。
  3. 登录弹性云服务器。
  4. 执行如下命令安装依赖包。

    tar -xzvf libmemcached-x.y.z.tar.gz

    cd libmemcached-x.y.z

    ./configure --enable-sasl

    make

    make install

  5. 新建build.sh文件,将如下代码复制到build.sh文件。
    g++ -o dcs_sample dcs_sample.cpp -lmemcached -std=c++0x -lpthread -lsasl2
     
  6. 新建dcs_sample.cpp文件,将如下C++代码复制到dcs_sample.cpp文件并修改代码。
    • 密码模式代码示例

      其中ip or domain name和port需要修改为1获取的缓存实例IP地址/域名和端口。userName和password需要修改为缓存实例的用户名和密码。

      #include <iostream>
      #include <string>
      #include <libmemcached/memcached.h>
      using namespace std; #define IP "ip or domain name"
      #define PORT port
      #define USERNAME "userName"
      #define PASSWORD "password"
      memcached_return rusult; memcached_st * init()
      {
      memcached_st *memcached = NULL;
      memcached_server_st *cache;
      memcached = memcached_create(NULL);
      cache = memcached_server_list_append(NULL, IP, PORT, &rusult); sasl_client_init(NULL);
      memcached_set_sasl_auth_data(memcached, USERNAME, PASSWORD);
      memcached_behavior_set(memcached,MEMCACHED_BEHAVIOR_BINARY_PROTOCOL,1);
      memcached_server_push(memcached,cache);
      memcached_server_list_free(cache);
      return memcached;
      } int main(int argc, char *argv[])
      {
      memcached_st *memcached=init();
      string key = "memcached";
      string value = "hello world!";
      size_t value_length = value.length();
      int expire_time = 0;
      uint32_t flag = 0; rusult = memcached_set(memcached,key.c_str(),key.length(),value.c_str(),value.length(),expire_time,flag);
      if (rusult != MEMCACHED_SUCCESS){
      cout <<"set data failed: " << rusult << endl;
      return -1;
      }
      cout << "set succesed, key: " << key << ", value: " << value << endl;
      cout << "get key:" << key << endl;
      char* result = memcached_get(memcached,key.c_str(),key.length(),&value_length,&flag,&rusult);
      cout << "value:" << result << endl; memcached_free(memcached);
      return 0;
      }
       
    • 免密模式代码示例

      其中ip or domain name和port需要修改为1获取的缓存实例IP地址/域名和端口。

      #include <iostream>
      #include <string>
      #include <libmemcached/memcached.h>
      using namespace std; #define IP "ip or domain name"
      #define PORT port
      memcached_return rusult; memcached_st * init()
      {
      memcached_st *memcached = NULL;
      memcached_server_st *cache;
      memcached = memcached_create(NULL);
      cache = memcached_server_list_append(NULL, IP, PORT, &rusult);
      memcached_server_push(memcached,cache);
      memcached_server_list_free(cache);
      return memcached;
      } int main(int argc, char *argv[])
      {
      memcached_st *memcached=init();
      string key = "memcached";
      string value = "hello world!";
      size_t value_length = value.length();
      int expire_time = 0;
      uint32_t flag = 0; rusult = memcached_set(memcached,key.c_str(),key.length(),value.c_str(),value.length(),expire_time,flag);
      if (rusult != MEMCACHED_SUCCESS){
      cout <<"set data failed: " << rusult << endl;
      return -1;
      }
      cout << "set succesed, key: " << key << " ,value: " << value << endl;
      cout << "get key:" << key << endl;
      char* result = memcached_get(memcached,key.c_str(),key.length(),&value_length,&flag,&rusult);
      cout << "value:" << result << endl; memcached_free(memcached);
      return 0;
      }
       
  7. 执行如下命令编译源码。

    chmod 700 build.sh

    ./build.sh

    生成dcs_sample二进制文件。

  8. 执行如下命令连接使用缓存实例。
    ./dcs_sample

    set succesed, key: memcached ,value: hello world!
    get key:memcached
    value:hello world!

Memcache的客户端连接系列(三) C++的更多相关文章

  1. Memcache的客户端连接系列(四) PHP

    关键词: Memcached   PHP 客户端 声明:本文并非原创,转自华为云帮助中心的分布式缓存服务(Memcached)的用户指南.客户端连接方法通用,故摘抄过来分享给大家. PHP客户端 Re ...

  2. Memcache的客户端连接系列(二) Python

    关键词: Memcached   Python 客户端 声明:本文并非原创,转自华为云帮助中心的分布式缓存服务(Memcached)的用户指南.客户端连接方法通用,故摘抄过来分享给大家. Python ...

  3. Memcache的客户端连接系列(一) Java

    声明:本文并非原创,转自华为云帮助中心的分布式缓存服务(Memcached)的用户指南. 关键词: Memcached  客户端 Java Java连接池 Java客户端示例 用户的弹性云服务器已安装 ...

  4. Redis客户端连接以及持久化数据(三)

    0.Redis目录结构 1)Redis介绍及部署在CentOS7上(一) 2)Redis指令与数据结构(二) 3)Redis客户端连接以及持久化数据(三) 4)Redis高可用之主从复制实践(四) 5 ...

  5. Android高效率编码-第三方SDK详解系列(三)——JPush推送牵扯出来的江湖恩怨,XMPP实现推送,自定义客户端推送

    Android高效率编码-第三方SDK详解系列(三)--JPush推送牵扯出来的江湖恩怨,XMPP实现推送,自定义客户端推送 很久没有更新第三方SDK这个系列了,所以更新一下这几天工作中使用到的推送, ...

  6. redis客户端连接异常

    本文参考:http://mdba.cn/2015/04/02/redistwemproxy-%e5%ae%a2%e6%88%b7%e7%ab%af%e8%bf%9e%e6%8e%a5%e5%bc%82 ...

  7. Redis基础知识之————如何处理客户端连接

    redis 连接建立 Redis Redis 通过监听一个 TCP 端口或者 Unix socket 的方式来接收来自客户端的连接,当一个连接建立后,Redis 内部会进行以下一些操作: 首先,客户端 ...

  8. 配置ORACLE 客户端连接到数据库

    --================================= -- 配置ORACLE 客户端连接到数据库 --================================= Oracle ...

  9. Oracle RAC 客户端连接负载均衡(Load Balance)

    实现负载均衡(Load Balance)是Oracle RAC最重要的特性之一,主要是把负载平均分配到集群中的各个节点,以提高系统的整体吞吐能力.通常情况下有两种方式来实现负载均衡,一个是基于客户端连 ...

随机推荐

  1. Parallel.ForEach使用示例

    新建一个.NET Core控制台程序,代码如下: using System; using System.Collections.Generic; using System.Threading; usi ...

  2. PHP实现数组递归转义的方法

    本文以实例形式讲述了PHP实现数组递归转义的方法,分享给大家供大家参考之用.具体方法如下: 主要功能代码如下: $arr = array('a"aa',array("c'd&quo ...

  3. Google Performance工具,你还不会用?Git走起。

    2018俄罗斯世界杯如火如荼的进行中,第一轮各种冷门,让大家的确大跌眼界,尤其是那些买球的同志们,慌得一笔,还敢继续买吗?话说来,看球归看球,学习还是不能落下,我们来学习Chrome Devtool ...

  4. js取整、四舍五入等数学函数

    js只保留整数,向上取整,四舍五入,向下取整等函数1.丢弃小数部分,保留整数部分parseInt(5/2) 2.向上取整,有小数就整数部分加1 Math.ceil(5/2) 3,四舍五入. Math. ...

  5. vector 定义的二维数组的遍历

    之前我们分享了STL的一些容器,再介绍vector中只介绍了二维的vector的定义并没有说二维的vector怎么遍历,那么我们今天就来看下二维的vector怎么遍历 看下面的代码吧. #includ ...

  6. 模板——最小生成树prim算法&&向前星理解

    通过最小生成树(prim)和最短路径优化引出的向前星存图,时至今日才彻底明白了.. head[i]存储的是父节点为i引出的最后一条边的编号, next负责把head[i]也就是i作为父节点的所有边连接 ...

  7. vscode调试html文件

    1. vscode调试html文件 1.1. 使用Debugger for Chrome进行调试 1.1.1. 基于本地file配置方式调试 1.1.2. 基于服务端配置方式调试 1.1.2.1. 启 ...

  8. 解决微信小程序用 SpringMVC 处理http post时请求报415错误

    解决微信小程序用 SpringMVC 处理http post时请求返回415错误 写微信小程序时遇到的问题,这个坑硬是让我整了半天 wx.request请求跟ajax类似处理方法一致 小程序端请求代码 ...

  9. Jquery之倒计时计算

      setInterval(); function setDate(setTime){ var date = new Date();//获取系统当前时间 )+)+"-"+date. ...

  10. 了解jQuery并掌握jQuery对象和DOM对象的区别

    jQuery的优势: 开源--开放源代码 轻量级 强大的选择器 出色的DOM操作(对DOM元素的一个增删改查) 完善的Ajax,出色的浏览器兼容性,丰富的插件支持,完善的文档(说明书) 链式操作方式, ...