`
liuxinglanyue
  • 浏览: 551072 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

MemLink API

阅读更多

Introduction

目前,memlink支持的客户端库,有c,python,php,java这四种。python,php,java客户端实际上是利用c客户端来做成不同语言的模块。因此c以外语言的客户端同样可以达到很高的性能。

Details

C/C++

  • MemLink* memlink_create(char *host, int readport, int writeport, int timeout);

创建MemLink数据结构

host为memlink server的ip,readport为server端的读端口,writeport为server端的写端口,timeout为网络操作的超时时间。单位为秒。

错误返回NULL,否则为成功
  • void memlink_destroy(MemLink *m);

销毁MemLink数据结构,释放资源
  • void memlink_close(MemLink *m);

关闭MemLink中的网络连接
  • int memlink_cmd_dump(MemLink *m);

发送DUMP命令。memlink服务器端执行dump操作。

返回MEMLINK_OK表示执行成功,否则出错
  • int memlink_cmd_clean(MemLink *m, char *key);

发送CLEAN命令。memlink会对该key下的列表进行重新排列,以去除已真实删除的数据空洞。
  • int memlink_cmd_stat(MemLink *m, char *key, MemLinkStat *stat);

发送STAT命令。获取对应key的一些统计信息,结果存储到传入的参数stat中。 MemLinkStat的结构如下:

  typedef struct _memlink_stat
  {
      unsigned char   valuesize;
      unsigned char   masksize;
      unsigned int    blocks; // all blocks
      unsigned int    data;   // all alloc data item
      unsigned int    data_used; // all data item used
      unsigned int    mem;       // all alloc mem
      unsigned int    mem_used;  // all used mem
  }MemLinkStat; 
其中valuesize为value长度的字节数,masksize为mask长度的字节数。blocks为该key下有多少个大的数据块(这里称为block),data为这些所有block中可以容纳的value数,data_used为实际存储了多少个value值。mem为所有block一共占用的内存字节数,mem_used对应data_used所占用的内存字节数。
  • int memlink_cmd_create(MemLink *m, char *key, int valuelen, char *maskstr);

发送CREATE命令,创建一个key。参数valuelen表示该key下的value的长度,maskstr为value的属性格式。该属性格式由问号分隔的数字组成。这些数字表示对应属性项所占用的空间的bit数。比如4:3:1表示有三个属性,这三个属性分别占用4bit,3bit,1bit。
  • int memlink_cmd_del(MemLink *m, char *key, char *value, int valuelen);

发送DEL命令。删除一个指定key下的对应value。
  • int memlink_cmd_insert(MemLink *m, char *key, char *value, int valuelen,char *maskstr, unsigned int pos);

发送insert命令,在指定的key下插入一个value,且此value要插入到一个指定位置。maskstr为该value的熟悉信息。格式和创建key时指定的属性格式对应。比如创建时属性格式为4:3:1,那么这里的maskstr也只能设置三项,比如maskstr可以为8:3:1。pos表示value要插入到列表中的哪个位置,0是列表头部,-1是列表尾部。注意,如果pos超出了列表的范围,也会被插入到尾部。
  • int memlink_cmd_update(MemLink *m, char *key, char *value, int valuelen, unsigned int pos);

发送UPDATE命令,更新一个value的位置。pos为此value的新位置。
  • int memlink_cmd_mask(MemLink *m, char *key, char *value, int valuelen, char *maskstr);

发送MASK命令,修改一个value的属性值。这里的maskstr的格式和INSERT命令的格式一样。
  • int memlink_cmd_tag(MemLink *m, char *key, char *value, int valuelen, int tag);

发送TAG命令,对一个value进行标记删除或者恢复。标记删除的value不会被真实删除,只是该数据不再显示。tag值为MEMLINK_TAG_DEL表示标记删除,为MEMLINK_TAG_RESTOR表示恢复。
  • int memlink_cmd_range(MemLink *m, char *key, char *maskstr,unsigned int frompos, unsigned int len,MemLinkResult *result);

发送RANGE命令,获取指定key下的某个范围的value。frompos是获取的开始位置,从0开始,len为要获取的长度。结果将写入到result中。 MemLinkResult的结构定义如下:
  typedef struct _memlink_result
  {
      int          count;
      int          valuesize;
      int          masksize;
      MemLinkItem  *root;
  }MemLinkResult;
其中count为返回的结果的条数,valuesize为value的长度(字节数),masksize为mask的长度(字节数)。root为返回结果的链表。 MemLinkItem的结构定义如下:
  typedef struct _memlink_item
  {
      struct _memlink_item    *next;
      char                    value[256];
      char                    mask[256];
  }MemLinkItem;
其中的next是链表的下一个节点指针,value和mask就是对应的结果值。
  • int memlink_cmd_rmkey(MemLink *m, char *key);

发送RMKEY命令,删除一个key,以及该key下的所有value。
  • int memlink_cmd_count(MemLink *m, char *key, char *maskstr, MemLinkCount *count); 

发送COUNT命令,以maskstr为条件,统计一个key下所有可见的value,以及被标记删除的value的数量。结果写入到count中。MemLinkCount结构定义如下:
  typedef struct _memlink_count
  {
     unsigned int    visible_count;
     unsigned int    tagdel_count;
  }MemLinkCount;
visible_count为可见value的数量。tagdel_count为标记删除的value的数量。
  • void memlink_result_free(MemLinkResult *result);

释放MemLinkResult结构中的root项的内存。

PHP

  • class MemLinkClient
memlink客户端类。
  • construct($host, $readport, $writeport, $timeout)
同c版memlink_create。
  • close()
同c版memlink_close
  • destroy()
同c版memlink_destroy
  • create($key, $valuesize, $maskformat)
同c版memlink_cmd_create。返回值为整型,正常返回MEMLNK_OK。
  • dump()
同c版memlink_dump。返回值为整型,正常返回MEMLNK_OK。
  • clean($key)
同c版memlink_cmd_clean。返回值为整型,正常返回MEMLNK_OK。
  • stat($key)
同c版memlink_cmd_stat。返回MemLinkStat对象,失败返回null。
  • stat2($key, $mstat)
同c版memlink_cmd_stat。和上一个stat方法的区别是,需要传一个MemLinkStat对象作为第二个参数,返回值为整型,正常返回MEMLNK_OK。
  • delete($key, $value, $valuelen)
同c版memlink_cmd_del。返回值为整型,正常返回MEMLNK_OK。
  • insert($key, $value, $valuelen, $maskstr, $pos)
同c版memlink_cmd_insert。返回值为整型,正常返回MEMLNK_OK。
  • update($key, $value, $valuelen, $pos)
同c版memlink_cmd_update。返回值为整型,正常返回MEMLNK_OK。
  • mask($key, $value, $valulen, $maskstr)
同c版memlink_cmd_mask。返回值为整型,正常返回MEMLNK_OK。
  • tag($key, $value, $valuelen, $tag)
同c版memlink_cmd_tag。返回值为整型,正常返回MEMLNK_OK。
  • range($key, $maskstr, $frompos, $len)
同c版memlink_cmd_range。返回MemLinkResult对象,失败返回null。
  • range2($key, $maskstr, $frompos, $len, $result)
同c版memlink_cmd_range。和上一个range方法的区别是,需要传一个MemLinkResult对象作为第二个参数,返回值为整型,正常返回MEMLNK_OK。
  • rmkey($key)
同c版memlink_cmd_rmkey。返回值为整型,正常返回MEMLNK_OK。
  • count($key, $maskstr)
同c版memlink_cmd_count。返回MemLinkCount对象,失败返回null。
  • count2($key, $maskstr, $count)
同c版memlink_cmd_count2。和上一个count方法的区别是,需要传一个MemLinkCount对象作为第二个参数,返回值为整型,正常返回MEMLNK_OK。

 

PYTHON

  • class MemLinkClient
memlink客户端类
  • init(self, host, readport, writeport, timeout)
同c版memlink_create。
  • close(self)
同c版memlink_close
  • destroy(self)
同c版memlink_destroy
  • dump(self)
同c版memlink_dump。返回值为整型,正常返回MEMLNK_OK。
  • clean(self, key)
同c版memlink_cmd_clean。返回值为整型,正常返回MEMLNK_OK。
  • create(self, key, valuesize, maskstr)
同c版memlink_cmd_create。返回值为整型,正常返回MEMLNK_OK。
  • stat(self, key)
同c版memlink_cmd_stat。返回值为tuple,共两个成员。其中第一项为整形返回值,为MEMLINK_OK表示正常。第二项为MemLinkStat对象。
  • delete(self, key, value)
同c版memlink_cmd_delete。返回值为整型,正常返回MEMLNK_OK。
  • insert(self, key, value, maskstr, pos)
同c版memlink_cmd_insert。返回值为整型,正常返回MEMLNK_OK。
  • update(self, key, value, pos)
同c版memlink_cmd_update。返回值为整型,正常返回MEMLNK_OK。
  • mask(self, key, value, maskstr)
同c版memlink_cmd_mask。返回值为整型,正常返回MEMLNK_OK。
  • tag(self, key, value, tag)
同c版memlink_cmd_tag。返回值为整型,正常返回MEMLNK_OK。
  • range(self, key, maskstr, frompos, len)
同c版memlink_cmd_range。返回值为tuple,共两个成员。其中第一项为整形返回值,为MEMLINK_OK表示正常。第二项为MemLinkResult对象。
  • rmkey(self, key)
同c版memlink_cmd_rmkey。返回值为整型,正常返回MEMLNK_OK。
  • count(self, key, maskstr)
同c版memlink_cmd_count。返回值为tuple,共两个成员。其中第一项为整形返回值,为MEMLINK_OK表示正常。第二项为MemLinkCount对象。

Java

  • public class MemLinkClient
memlink客户端类。说明和php版本类似。
  • public MemLinkClient (String host, int readport, int writeport, int timeout)
  • public void close()
  • public void destroy()
  • public int create(String key, int valuesize, String maskstr)
  • public int dump()
  • public int clean(String key)
  • public MemLinkStat stat(String key)
  • public int stat2(String key, MemLinkStat stat)
  • public int delete(String key, String value)
  • public int insert(String key, String value, String maskstr, int pos)
  • public int update(String key, String value, int pos)
  • public int mask(String key, String value, String maskstr)
  • public int tag(String key, String value, int tag)
  • public MemLinkResult range(String key, String maskstr, int frompos, int len)
  • public int range2(String key, String maskstr, int frompos, int len, MemLinkResult mresult)
  • public int rmkey(String key)
  • public MemLinkCount count(String key, String maskstr)
  • public int count2(String key, String maskstr, MemLinkCount mcount)

 

分享到:
评论

相关推荐

    Memlink是一个高性能、持久化、分布式的Key=>List/Queue数据引擎

    memlink函数,nosql数据库,天涯论坛数据库,海量数据快速存取,内存数据库 天涯社区最近开发了一款数据引擎——Memlink,并将其开源。对于为什么会出现这样一款开源项目、它的能力和市面上的其他款同类型项目相比有...

    天涯社区开源的NoSQL数据库 Memlink.zip

    Memlink是天涯社区开发的一个高性能、持久化、分布式的Key-list/queue数据引擎。正如名称中的memlink所示,所有数据都 建构在内存中,保证了系统的高性能 (大约是redis几倍),同时使用了redo-log技术保证数据的持久...

    memLink.rar

    Memlink是天涯社区开发的一个高性能、持久化、分布式的Key-list/queue数据引擎。正如名称中的memlink所示,所有数据都建构在内存中,保证了系统的高性能 (大约是redis几倍),同时使用了redo-log技术保证数据的持久化...

    安全隐患台账(模版).xls

    安全隐患台账(模版).xls

    基于 Java+Mysql 实现的小型仓库管理系统-课程设计(含课设文档+源码)

    【作品名称】:基于 Java+Mysql 实现的小型仓库管理系统-课程设计(含课设文档+源码) 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【项目介绍】:项目说明 1、项目结构:maven+mvc(M模型用的是mybatis技术) 2、项目模式:C/S(客户机/服务器)模式 3、编辑器:IDEA 2019.3.1 4、mysql版本号:5.1.38

    基于VHDL的倒车雷达项目(免费提供全部源码)

    项目简介: 本项目实现了一个基于VHDL(VHSIC硬件描述语言)的倒车雷达系统。倒车雷达用于检测车辆后方障碍物的距离,以辅助驾驶员安全倒车。系统通过超声波传感器检测距离,并使用LED显示或蜂鸣器提示障碍物的接近程度。 项目模块: 传感器接口模块: 处理超声波传感器的信号。 发送触发信号,接收回波信号。 计算回波时间,进而计算距离。 距离计算模块: 根据传感器回波时间计算距离。 处理和转换距离数据,准备用于显示和警报。 警报显示模块: 基于计算出的距离提供视觉和听觉警报。 使用LED显示不同的距离范围。 使用蜂鸣器发出不同频率的警报声。 控制模块: 控制各模块的协调工作。 管理超声波传感器的触发和数据采集周期。

    试验检测仪器设备(参考标准、有证标准物质)一览表.doc

    试验检测仪器设备(参考标准、有证标准物质)一览表.doc

    vuInhub靶场实战系列-Kioptrix Level #1

    vuInhub靶场实战系列-Kioptrix Level #1

    野火的ESP8266配套例程

    本资源是配套作者博客【stm32、ESP8266、华为云 搭建一个简单的物联网系统】

    GPU:计算机图显核心,计算场景应用崛起

    GPU:计算机图显核心,计算场景应用崛起

    Web3.0初探:一个基于区块链技术、用户主导、去中心化的网络生态

    Web3.0:致力打造一个基于区块链技术、用户主导、去中心化的网络生态。在Web3.0中,用户为满足自身需求进行交互操作,并在交互中利用区块链技术,从而实现价值的创造、分配与流通。这样的整个用户交互、价值流通的过程就形成了Web3.0生态。相比Web2.0的平台中心化特征,Web3.0致力于实现用户所有、用户共建的“去中心化”网络生态。

    2024年亲子旅游行业分析报告.pptx

    行业报告

    MQD企业大学建设思路与年度工作重点.pptx

    MQD企业大学建设思路与年度工作重点.pptx

    Java语言基础入门教程 Java实训教程 4.类构造函数-this-静态属性方法-instanceof运算符共55页.pptx

    Java语言基础入门教程 Java实训教程 4.类构造函数-this-静态属性方法-instanceof运算符共55页.pptx

    openssh-9.7p1-1.el6.x86-64.tgz

    centos 6 redhat 6 x86架构的openssh 9.7版本二进制rpm包 安全更新、升级安装新版本openssh 9.7版本,当前最新版本,修复安全漏洞。 2024年6月8日制作,内含ssh-copy-id命令

    风传花信,雨濯春尘-中国人身险产品变迁史与未来展望

    风传花信,雨濯春尘——中国人身险产品变迁史与未来展望 按照不同分类方法,人身险可以分为以下种类: 1)按保障责任划分:人寿保险、健康保险、意外伤害保险、年金保险; 2)按设计类型划分:普通型、分红型、投资连结型、万能型。 40 年间中国人身险产品历经多次变迁,从单一死亡风险保障到多元风险覆盖+兼备理财储蓄功能。

    C08-我的笔记02.md

    C08-我的笔记02.md

    公司项目试验仪器设备台账.docx

    公司项目试验仪器设备台账.docx

    transformer灵魂21问

    transformer灵魂21问

    YOLOv10的改进技术点.pdf

    YOLOv10的改进技术点主要体现在以下几个方面: 1.一致双分配策略(Consistent Dual Assignments): 1.YOLOv10采用了一致双分配策略,通过双重标签分配和匹配指标的一致性,实现了无需NMS(非最大抑制)的后处理训练。这既保证了训练阶段的丰富监督信息,又实现了高效的无NMS预测,提升了性能和速度。 2.在训练过程中,一对一头部与传统的一对多头部合并,两者共享相同的优化目标,但使用不同的匹配策略。一对多头部提供了丰富的监控信号,而一对一头部在推理过程中确保了高效、无NMS的预测。 2.整体效率和精度驱动的模型设计: 1.YOLOv10采用了整体效率和精度驱动的模型设计策略,从效率和精度两个角度对各种YOLO组件进行优化。 2.效率驱动型模型设计:通过使用深度可分离卷积的简化架构来减少计算开销,分离空间减少和信道增加减少计算成本并保留信息。同时,使用内在秩分析来识别和减少模型阶段的冗余,用更有效的结构代替复杂的块。 3.精度驱动的模型设计:通过增加深度阶、引入大型核卷积和部分自注意力模块来增强模型能力,提高性能。 3.性能与效率的提升: 1.YOLOv10

Global site tag (gtag.js) - Google Analytics