Skip to main content

Redis built into a python package

Project description

Redislite

CI/CD Build Status Codestyle Coverage Current Version Supported Python License Documentation

Description

Redislite is a self contained Python interface to the Redis key-value store.

It provides enhanced versions of the Redis-Py Python bindings for Redis. That provide the following added functionality:

  • Easy to use - It provides a built in Redis server that is automatically installed, configured and managed when the Redis bindings are used.
  • Flexible - Create a single server shared by multiple programs or multiple independent servers. All the servers provided by Redislite support all Redis functionality including advanced features such as replication and clustering.
  • Compatible - It provides enhanced versions of the Redis-Py python Redis bindings as well as functions to patch them to allow most existing code that uses them to run with little or no modifications.
  • Secure - It uses a secure default Redis configuraton that is only accessible by the creating user on the computer system it is run on.

Requirements

The redislite module requires Python 3.6 or higher.

Installing requirements on Linux

Make sure Python development headers are available when installing redislite.

On Ubuntu/Debian systems, install them with:

apt-get install python-dev

On Redhat/Fedora systems, install them with:

yum install python-devel

Installing requirements on Mac OSX

Redislite for OSX comes as a wheel package by default that can be installed using current versions of pip.

To install Redislite on MacOSX using the sdist package instead you will need the XCode command line utilities installed. If you do not have xcode installed on recent OSX releases they can be installed by running:

xcode-select --install

Installing requirements on Microsoft Windows

Redislite can be installed on newer releases of Windows 10 under the Bash on Ubuntu shell.

Install it using the instructions at https://msdn.microsoft.com/commandline/wsl/install_guide

Then start the bash shell and install the python-dev package as follows:

apt-get install python-dev

Installation

To install redislite, simply:

$ pip install redislite

or from source:

$ python setup.py install

Getting Started

redislite provides enhanced versions of the redis-py redis.Redis() and redis.StrictRedis() classes that take the same arguments as the corresponding redis classes and take one additional optional argument. Which is the name of the Redis rdb file to use. If the argument is not provided it will create set up a new redis server.

redislite also provides functions to MonkeyPatch the redis.Redis and redis.StrictRedis classes to use redislite, so existing python code that uses Redis can use the redislite version.

Examples

Here are some examples of using the redislite module.

Setting a value

Here we open a Python shell and set a key in our embedded Redis db. Redislite will automatically start the Redis server when the Redis() object is created and shut it down cleanly when the Python interpreter exits.

>>> from redislite import Redis
>>> redis_connection = Redis('/tmp/redis.db')
>>> redis_connection.keys()
[]
>>> redis_connection.set('key', 'value')
True
>>> redis_connection.get('key')
'value'

Persistence

Now we open the same Redis db and access the key we created during the last run. Redislite will automatically start the Redis server using the same configuration as last time, so the value that was set in the previous example is still available.

>>> from redislite import Redis
>>> redis_connection = Redis('/tmp/redis.db')
>>> redis_connection.keys()
['key']
>>> redis_connection.get('key')
'value'

Compatibility

It's possible to MonkeyPatch the normal Redis classes to allow modules that use Redis to use the redislite classes. Here we patch Redis and use the redis_collections module.

>>> import redislite.patch
>>> redislite.patch.patch_redis()
>>> import redis_collections
>>> td = redis_collections.Dict()
>>> td['foo']='bar'
>>> td.keys()
['foo']

Running and using Multiple servers

Redislite will start a new server if the redis rdb fileame isn't specified or is new. In this example we start 10 seperate redis servers and set the value of the key 'servernumber' to a different value in each server.

Then we access the value of 'servernumber' and print it.

>>> import redislite
>>> servers = {}
>>> for redis_server_number in range(10):
...     servers[redis_server_number] = redislite.Redis()
...     servers[redis_server_number].set('servernumber', redis_server_number)
...
True
True
True
True
True
True
True
True
True
True
>>> for redis_server in servers.values():
...     redis_server.get('servernumber')
...
b'0'
b'1'
b'2'
b'3'
b'4'
b'5'
b'6'
b'7'
b'8'
b'9'

Multiple Servers with different configurations in the same script

It's possible to spin up multiple instances with different configuration settings for the Redis server. Here is an example that sets up 2 redis server instances. One instance is configured to listen on port 8002, the second instance is a read-only slave of the first instance.

>>> import redislite
>>> master=redislite.Redis(serverconfig={'port': '8002'})
>>> slave=redislite.Redis(serverconfig={'slaveof': "127.0.0.1 8002"})
>>> slave.keys()
[]
>>> master.set('key', 'value')
True
>>> master.keys()
['key']
>>> slave.keys()
['key']
>>>

More Information

There is more detailed information on the redislite documentation page at http://redislite.readthedocs.org/en/latest/

Redislite is Free software under the New BSD license, see LICENSE.txt for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

redislite-6.2.805324.tar.gz (2.5 MB view details)

Uploaded Source

Built Distributions

redislite-6.2.805324-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (6.1 MB view details)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

redislite-6.2.805324-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (6.1 MB view details)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

redislite-6.2.805324-pp38-pypy38_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (5.9 MB view details)

Uploaded PyPy manylinux: glibc 2.12+ x86-64

redislite-6.2.805324-pp37-pypy37_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (6.1 MB view details)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

redislite-6.2.805324-pp37-pypy37_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (5.9 MB view details)

Uploaded PyPy manylinux: glibc 2.12+ x86-64

redislite-6.2.805324-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (6.1 MB view details)

Uploaded CPython 3.11 manylinux: glibc 2.17+ x86-64

redislite-6.2.805324-cp311-cp311-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (5.9 MB view details)

Uploaded CPython 3.11 manylinux: glibc 2.12+ x86-64

redislite-6.2.805324-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (6.1 MB view details)

Uploaded CPython 3.10 manylinux: glibc 2.17+ x86-64

redislite-6.2.805324-cp310-cp310-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (5.9 MB view details)

Uploaded CPython 3.10 manylinux: glibc 2.12+ x86-64

redislite-6.2.805324-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (6.1 MB view details)

Uploaded CPython 3.9 manylinux: glibc 2.17+ x86-64

redislite-6.2.805324-cp39-cp39-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (5.9 MB view details)

Uploaded CPython 3.9 manylinux: glibc 2.12+ x86-64

redislite-6.2.805324-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (6.1 MB view details)

Uploaded CPython 3.8 manylinux: glibc 2.17+ x86-64

redislite-6.2.805324-cp38-cp38-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (5.9 MB view details)

Uploaded CPython 3.8 manylinux: glibc 2.12+ x86-64

redislite-6.2.805324-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (6.1 MB view details)

Uploaded CPython 3.7m manylinux: glibc 2.17+ x86-64

redislite-6.2.805324-cp37-cp37m-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (5.9 MB view details)

Uploaded CPython 3.7m manylinux: glibc 2.12+ x86-64

File details

Details for the file redislite-6.2.805324.tar.gz.

File metadata

  • Download URL: redislite-6.2.805324.tar.gz
  • Upload date:
  • Size: 2.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.1 CPython/3.7.13

File hashes

Hashes for redislite-6.2.805324.tar.gz
Algorithm Hash digest
SHA256 603b28bcdfdbe45edfe0046dc99b0fcbe3d5c533d1b7e5d9c3ff6208a656e7f1
MD5 8eb49924827eacc4e9ceff69b47604f4
BLAKE2b-256 9dd067411c3d854e67f67be981d83f8e065e387e6f764d76dd6e9dfd1c5d2089

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 7723317952715b7fa5e21d14ef3cf4d5a18f43f828e04b39712fa8d13d2274ff
MD5 9cbc9a42c121a3b5788a1e24496b7a69
BLAKE2b-256 503e1f3c5afad39577479c27b816b9f9390a2be57e744a7644fca02ac7870763

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 4e86ef58c491a6dc0c04fad86c286bb43edc128b26006ef90b2b49ed1d38e089
MD5 659016bdb913e16a538f861fe0ef970b
BLAKE2b-256 e5c7919966963519da98870c57b6b6d56f4b37b07d0f714449ffef506c267dc1

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-pp38-pypy38_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-pp38-pypy38_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm Hash digest
SHA256 4640ed4533c176b3b1fab4592af39d3fab6423843c7634b6b5aba980dfc5d578
MD5 fadb5bb90ed6af1d2726c8fa155b9875
BLAKE2b-256 2c0f847a285c76af91277dc194e0b3049791491cc88fd06b712525d65aa6fe92

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-pp37-pypy37_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-pp37-pypy37_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 731b6d239f67f8fc9e3d801dca26269291b94be772c37bc2b65a884c9d79138e
MD5 943e2e1d9a596ef4ad5bc31bed43d5e0
BLAKE2b-256 41334c5eb247d09ffdbecc46ee61d2f452dd0f28c04f004ffa1341f832cc1d06

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-pp37-pypy37_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-pp37-pypy37_pp73-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm Hash digest
SHA256 79f4540aa4c5f6cd85370a504b6610ef6995775307389559ad4001f61949c229
MD5 17cc4daa8dd6fd305860ad151d8e8448
BLAKE2b-256 506f00a6062034e50872e1967db0c2dc9f44500805a324192dffa8975c601d39

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 a704fdfb74b4b1711f86b98deeb0627ed7bbdf21653e48146d9369cda2fc40c4
MD5 5316c7e3c68be3b0add98ae2a4973982
BLAKE2b-256 bf3894bd935e3e4c01959dc3e17ba30d5e9757ed462f13387e155c4859f3abe4

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-cp311-cp311-manylinux_2_12_x86_64.manylinux2010_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-cp311-cp311-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm Hash digest
SHA256 0b3f202cee43bda332f97615ecf4a7c3b2b91c9ab28abf0494a21f6829d19101
MD5 a6a22bcb8fb01e56dda3733d2ea3dbe2
BLAKE2b-256 107026c522f45e4ffc1554e41c42161bc67a7c55610aa0a8b1bc8f097e369f16

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 c6abef5810940eca315b8c90f45b0ebda8e76c0a0ea6e9f606b8166f01a082b1
MD5 0ed74d7d2ed6878361b662cbc4cc0fa8
BLAKE2b-256 334ed2196e03940f811aa94186b4fca44e5e327a96881bc47323e7a1d96664ea

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-cp310-cp310-manylinux_2_12_x86_64.manylinux2010_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-cp310-cp310-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm Hash digest
SHA256 0f0642a5a6b79d086260e2ce42a95744dc5e5339f571ac149705730de8f68be9
MD5 02fe9ca1db2ab8de087f7c2d42c24495
BLAKE2b-256 359dcefe5c2c1347320e79223a00257f61185b6dc482fa16dd5cf8e87c3a26a1

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 9fbb1433b4a2d88889b550bd08c6885a58446d204c6ee031a5a2fdee83620f46
MD5 30883934e215f556adae8f359301dfb5
BLAKE2b-256 1ab08e2ae6dcbdfcb7e8236320028f2d874891574fff8ce19386a82fb0dda95e

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-cp39-cp39-manylinux_2_12_x86_64.manylinux2010_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-cp39-cp39-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm Hash digest
SHA256 bdd673e51b42d515b273518c4670d2d94d54542baa67b2d4c8951e47e05cd349
MD5 3059a971f750b64ed0bbb98cfcab4bed
BLAKE2b-256 72aa3b1a1101e53b9176612089d58351f6d60ac7bb7c3e890593282f50c7e62b

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 4904fe27211637c17dd98b4547cc6de4cacf231b394b5174d7acca38409db5c4
MD5 120e12a1e1708eccfb3b3935e6bdc843
BLAKE2b-256 d3245c629a4f4d78e7b47a373bc83b0699a63eb558ae682635cce467bc0d5c58

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-cp38-cp38-manylinux_2_12_x86_64.manylinux2010_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-cp38-cp38-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm Hash digest
SHA256 ba35f7600d119a1db1cbae77c0591b8e0feb351689117c68c23bc5f34d3442af
MD5 a25b6d5bbaf7107f644042504a05de8a
BLAKE2b-256 371e0ee263c8b6277baa180ed5e044b4eab3f8df50a331d3dde8298556b5bfa8

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 8ad793d9b45d2e77d36753b695391c1a9e77a84b1782f7ea5d42fb5af3bbe86a
MD5 cc89ff6246ade49fc3ec013081f75845
BLAKE2b-256 b95f912727e9af9e4ebb3eca4c08223400261a42db420e628bd29bbacfd15f91

See more details on using hashes here.

File details

Details for the file redislite-6.2.805324-cp37-cp37m-manylinux_2_12_x86_64.manylinux2010_x86_64.whl.

File metadata

File hashes

Hashes for redislite-6.2.805324-cp37-cp37m-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm Hash digest
SHA256 09989c29788e2a4ab0c946869582451f6a46b4099a17482560d990250ffad696
MD5 1b3c24509988481f1ddf265148f970dd
BLAKE2b-256 43c896c0d4179d60f7e116aff5c9d54501ebe6b2c14339137216cd2fdc58983f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page