Reveldb NoSQL 数据服务器

程序名称:Reveldb

授权协议: LGPL

操作系统: Linux

开发语言: C/C++

Reveldb 介绍

reveldb 一个基于 google leveldb 的 NoSQL
数据服务器,网络连接采用了 libevent 的 HTTP 接口,因此 reveldb 天生就适合处理 HTTP 请求。但更确切地说,reveldb
并没有直接采用 libevent 的 HTTP 接口,而是使用了另外一个基于 libevent 的网络连接库
libevhtp(https://github.com/ellzey/libevhtp),并对它做了适当的修改,使之成为
reveldb 的底层组件
evhttpx(https://github.com/forhappy/reveldb/tree/master/src/evhttpx),
evhttpx 为 reveldb 提供了 HTTP 和 HTTPS 支持,因此,reveldb 除了能够处理 HTTP 请求外,也能够处理 HTTPS
请求,这一特性是 Kyoto Tycoon 没有的。

Reveldb 定位于 Kyoto Tycoon 类似,也是一个数据库网络层的服务,具体一点就是 Leveldb 的网络层接口(因为 leveldb
本身只是一个程序库,并没有服务器/客户端的概念),reveldb 封装了 leveldb 的绝大部分操作,如 Snapshot, Writebatch,
Iterator 等等,并且在此基础之上扩展了很多命令,比如 string 的 append, prepend, insert,Key-Value 的
mset, mget, mdel, seize, mseize,此外还有 range query, 基于编辑距离的查找,正则式 regex
匹配查找;同时还提供了一些数据库管理的命令,如compact, repair, destroy 等;Ling外,reveldb
支持打开多个数据库,底层使用了红黑树缓存各个客户端已经打开的 leveldb 实例。

HTTP RPC 示例:

/rpc/echo

  • Description: Echo back the input data as the output data, as well as HTTP headers, just for testing.

  • input: (optional): arbitrary records.

  • output: (optional): corresponding records to the input data.

  • status code: 200.

  • sample request:

    http://127.0.0.1:8088/rpc/echo?db=default&key=hello&value=world
    
  • sample response:

    {
    "code": 200,
    "status": "OK",
    "message": "Reveldb echoed the HTTP headers and query arguments of your request.",
    "date": "Mon, 17 Dec 2012 12:50:22 GMT",
    "request": {
        "headers": {
            "Host": "127.0.0.1:8088",
            "User-Agent": "Mozilla/5.0 (X11; Ubuntu; Linux i686; rv:17.0) Gecko/20100101 Firefox/17.0",
            "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8",
            "Accept-Language": "en-US,en;q=0.5",
            "Accept-Encoding": "gzip, deflate",
            "Connection": "keep-alive"
        },
        "arguments": {
            "db": "default",
            "key": "hello",
            "value": "world"
        }
    }
    

    }

/rpc/set

  • Description:

  • input: db: the database identifier.

  • input: key: key to be added.

  • input: value: value along with the key to be added.

  • status code: 200.

  • sample request:

    http://127.0.0.1:8088/rpc/set?db=hello&key=hello&value=world
    
  • sample response:

    {
    "code": 200,
    "status": "OK",
    "message": "Set key-value pair done.",
    "date": "Thu, 27 Dec 2012 09:11:26 GMT"
    

    }

/rpc/get

  • Description:

  • input: db: the database identifier.

  • input: key: which key to get.

  • status code: 200.

  • sample request:

    http://127.0.0.1:8088/rpc/get&db=hello&key=hello
    
  • sample response:

  • {
    “code”: 200,
    “status”: “OK”,
    “message”: “Get key-value pair done.”,
    “date”: “Thu, 27 Dec 2012 09:19:05 GMT”,
    “kv”: {
    “hello”: “worldworld”
    }
    }

Reveldb 官网

https://github.com/forhappy/reveldb

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


SchemaCrawler提供一组用于增强标准JDBC Metadata的API.SchemaCrawler还包含一个命令行工具能够将数据库结构和数据以一种易读的形式输出.
ER Master 是一个用于设计ER模型图的Eclipse插件。提供的功能包括:从数据库导入关系生成ER图,导出设计图,导出DDL数据定义语句等。目前完整支持的数据库包括
Eclipse下用于画数据库ER图的插件,主要特性如下: 图形化编辑ER图 从数据库结构中导入ER图
PowerDesigner 是Sybase的企业建模和设计解决方案,采用模型驱动方法,将业务与IT结合起来,可帮助部署有效的企业体系架构,并为研发生命周期管理提供强大的分析与设计技术。PowerDesigner
Mogwai ERDesigner NG是一个实体关系建模工具类似于ERWin。它设计成让数据库建模变得尽可能简易并为整个开发过程提供支持,从数据库设计到模式
Power*Architect 是一个数据建模工具,主要用在数据仓库和数据集市的模型设计。
MySQL Workbench是一款专为MySQL设计的ER/数据库建模工具。它是著名的数据库设计工具DBDesigner4的继任者。你可以用MySQL
DbWrench 是一个数据库设计和同步软件,为数据库开发人员提升生产率,可轻松的创建和修改数据库。
是一个采用Python开发的使用ER图的数据库建模工具
CA公司的数据库建模工具 (非开源) ,为你提供一个易于使用的用户界面(UI)环境,简化数据库设计过程,并将许多令人疲惫的任务自动化,如创建高性能事务和数据仓库数据库。这是一款可以和PowerDesigner并驾齐驱的
Altova MapForce® 2008是您首选的数据综合和网络服务器实现工具。它可以通过映射数据源到WSDLO操作的方法,实现多种文件之间的转化,包括XML文件, 数据库文件,
一个用Java开发的可视化数据库设计工具,支持JDBC 2.0的数据库
一个图形化的数据库模型浏览工具,SchemaSpy analyzes database metadata to reverse engineer
从事软件开发多年,感觉数据库在整个软件开发过程中扮演一个不可或缺的角色。一旦一个业务项目进入立项阶段,需要支持哪些数据库平台,如何使用该种数据库平台都将成为架构师需要考虑的内容,对于一般的开发人员,
Middlegen一个免费数据库驱动(database-driven)的代码生成引擎。它基于JDBC,Velocity,Ant和XDoclet.
Ermodeller是一个用于数据建模的CASE工具。该工具支持概念建模和逻辑建模,并在最后生成特定数据库的物理模型。支持的数据库包括:MySQL、PotgreSQL、Oracle、Pointbase,对其它数据库的支持需要通过XML文件自定义
GMOD is the G eneric M odel O rganism D atabase project, a collection of open source software tools for creating and managing genome-
pgDesigner 是一个为PostgreSQL数据库设计的建模工具
Enterprise Architect是一款计算机辅助软件工程(CASE)工具,用于设计和构建软件系统、业务流程建模及更多通用的建模。
mybatis 通用 basedao,含自动生成通用 XMLMapper。 可通过此工具自动生成 Mybatis XML 文件和 dao 的 class 类