tarantool-python
tarantool-python copied to clipboard
Python client library for Tarantool
Python driver for Tarantool
.. image:: https://github.com/tarantool/tarantool-python/actions/workflows/testing.yml/badge.svg?branch=master :target: https://github.com/tarantool/tarantool-python/actions/workflows/testing.yml .. image:: https://github.com/tarantool/tarantool-python/actions/workflows/packing.yml/badge.svg?branch=master :target: https://github.com/tarantool/tarantool-python/actions/workflows/packing.yml
This package is a pure-python client library for Tarantool
_.
Documentation
_ | Downloads
_ | PyPI
_ | GitHub
_ | Issue tracker
_
.. _Documentation
: http://tarantool-python.readthedocs.org/en/latest/
.. _Downloads
: http://pypi.python.org/pypi/tarantool#downloads
.. _PyPI
: http://pypi.python.org/pypi/tarantool
.. _GitHub
: https://github.com/tarantool/tarantool-python
.. _Issue tracker
: https://github.com/tarantool/tarantool-python/issues
Download and install
With pip (recommended) ^^^^^^^^^^^^^^^^^^^^^^
The recommended way to install the tarantool
package is using pip
.
.. code-block:: bash
$ pip3 install tarantool
With dnf ^^^^^^^^
You can install python3-tarantool
RPM package if you use Fedora (34, 35, 36).
Add the repository
.. code-block:: bash
$ curl -L https://tarantool.io/OtKysgx/release/2/installer.sh | bash
and then install the package
.. code-block:: bash
$ dnf install -y python3-tarantool
With apt ^^^^^^^^
You can install python3-tarantool
deb package if you use
Debian (10, 11) or Ubuntu (20.04, 22.04).
Add the repository
.. code-block:: bash
$ curl -L https://tarantool.io/OtKysgx/release/2/installer.sh | bash
and then install the package
.. code-block:: bash
$ apt install -y python3-tarantool
ZIP archive ^^^^^^^^^^^
You can also download zip archive, unpack it and run:
.. code-block:: bash
$ make install
Development version ^^^^^^^^^^^^^^^^^^^
You can also install the development version of the package using pip
.
.. code-block:: bash
$ pip3 install git+https://github.com/tarantool/tarantool-python.git@master
What is Tarantool?
Tarantool
_ is an in-memory computing platform originally designed by
VK
_ and released under the terms of BSD license
_.
Features
-
ANSI SQL, including views, joins, referential and check constraints
-
Lua packages for non-blocking I/O, fibers, and HTTP
-
MessagePack data format and MessagePack-based client-server protocol
-
Two data engines:
- memtx – in-memory storage engine with optional persistence
- vinyl – on-disk storage engine to use with larger data sets
-
Secondary key and index iterator support (can be non-unique and composite)
-
Multiple index types: HASH, BITSET, TREE, RTREE
-
Asynchronous master-master replication
-
Authentication and access control
See More ^^^^^^^^
-
Tarantool homepage
_ -
Tarantool on GitHub
_ -
Tarantool documentation
_ -
Client-server protocol specification
_
NOTE ^^^^
This driver is synchronous, so connection mustn't be shared between threads/processes.
If you're looking for an asynchronous Python driver based on asyncio
,
consider using asynctnt
_ . See also the feature comparison table
_.
Run tests ^^^^^^^^^
On Linux:
.. code-block:: bash
$ make test
On Windows:
- Setup a Linux machine with Tarantool installed.
This machine will be referred to as
remote
in this instruction. - (On
remote
) Copytest/suites/lib/tarantool_python_ci.lua
to/etc/tarantool/instances.available
. - (On
remote
) Runtarantoolctl start tarantool_python_ci
. - Set the following environment variables:
-
REMOTE_TARANTOOL_HOST=...
, -
REMOTE_TARANTOOL_CONSOLE_PORT=3302
.
-
- Run
make test
.
Build docs ^^^^^^^^^^
To build documentation, first you must install its build requirements:
.. code-block:: bash
$ pip3 install -r docs/requirements.txt
Then run
.. code-block:: bash
$ make docs
You may host local documentation server with
.. code-block:: bash
$ python3 -m http.server --directory build/sphinx/html
Open localhost:8000
in your browser to read the docs.
.. _Tarantool
:
.. _Tarantool Database
:
.. _Tarantool homepage
: https://tarantool.io
.. _Tarantool on GitHub
: https://github.com/tarantool/tarantool
.. _Tarantool documentation
: https://www.tarantool.io/en/doc/latest/
.. _VK
: https://vk.company
.. _Client-server protocol specification
: https://www.tarantool.io/en/doc/latest/dev_guide/internals/box_protocol/
.. _BSD
:
.. _BSD license
:
.. _BSD-2-Clause
: https://opensource.org/licenses/BSD-2-Clause
.. _asynctnt
: https://github.com/igorcoding/asynctnt
.. _feature comparison table
: https://www.tarantool.io/en/doc/latest/book/connectors/#python-feature-comparison
License ^^^^^^^
BSD-2-Clause. See the LICENSE
file.