/rlite

self-contained, serverless, zero-configuration, transactional redis-compatible database engine. rlite is to Redis what SQLite is to SQL.

Primary LanguageCBSD 2-Clause "Simplified" LicenseBSD-2-Clause

rlite

Build Status

self-contained, serverless, zero-configuration, transactional Redis-compatible database engine. rlite is to Redis what SQLite is to SQL.

Example

require('redis')
require('hirlite/connection')
redis = Redis.new(:host => ":memory:", :driver => Rlite::Connection::Hirlite)
redis.set 'key', 'value'
p redis.get 'key' # value

Ruby bindings example. See node.js, Python and Objective-C

Use Cases

This is a list of possible use cases where you might want to use rlite.

  • Mobile. If you are used to Redis data structure, and it is better suited for your mobile application than sqlite, you can use rlite as a database.

  • Replace Redis in development stack. By being embedded, rlite does not need a separate database process, and since it is compatible with Redis you can use it while developing, even if you use Redis instead in production.

  • Replace Redis in tests. The test stack can use rlite instead of Redis if you use the latter in production. It can simplify the CI stack, and the distribution of fixtures by being in binary form, and it will not require to load completely in memory to run each test.

  • Slave of Redis. You can run rlite-server as a slave of a master Redis instance. It works as third alternative to Redis's snapshot and append-only file.

  • Store client-side application data. Alternatively to a propetary format or sqlite, command line or simple applications can store its data using rlite.

Current Status and Roadmap

  • string (set, get...)
  • list (lpush, lpop...)
  • set (sadd, sismember...)
  • zset (zadd, zrank...)
  • hash (hset, hdel...)
  • key management (del, exists...)
  • transactions (multi, exec...)
  • lua scripting (eval, evalsha, ...)
  • rlite-server pass all Redis tests
    • unit/scan
    • integration/replication
    • unit/scripting
    • unit/introspection
  • pubsub
  • brpop/brpoplpush
  • multi process safe
  • multi thread safe
  • write ahead log
  • python bindings
  • ruby bindings
  • objective-c bindings
  • Node.js bindings

Installation

rlite has no dependencies, just run make all.

Bindings

License

Copyright (c) 2014, Sebastian Waisbrot All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

  • Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.

  • Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.