Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/neo4j/neo4j-python-driver-rust-ext
Optional Rust Extensions to Speed Up the Python Driver
https://github.com/neo4j/neo4j-python-driver-rust-ext
binary-protocol cypher database-driver driver graph-database neo4j protocol python python3 query-language rust
Last synced: 4 months ago
JSON representation
Optional Rust Extensions to Speed Up the Python Driver
- Host: GitHub
- URL: https://github.com/neo4j/neo4j-python-driver-rust-ext
- Owner: neo4j
- License: apache-2.0
- Created: 2023-10-24T09:33:33.000Z (about 1 year ago)
- Default Branch: 5.0
- Last Pushed: 2024-07-30T14:22:23.000Z (6 months ago)
- Last Synced: 2024-07-30T18:00:26.809Z (6 months ago)
- Topics: binary-protocol, cypher, database-driver, driver, graph-database, neo4j, protocol, python, python3, query-language, rust
- Language: Python
- Homepage:
- Size: 101 KB
- Stars: 7
- Watchers: 49
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Rust Extensions for a Faster Neo4j Bolt Driver for Python
This project contains Rust extensions to speed up the [official Python driver for Neo4j](https://github.com/neo4j/neo4j-python-driver).
The exact speedup depends on the use-case but has been measured to be up to 10x faster.
Use-cases moving only few but big records out of the DBMS tend to benefit the most.## Installation
Adjust your dependencies (`requirements.txt`, `pyproject.toml` or similar) like so:
```
# remove:
# neo4j == X.Y.Z # needs to be at least 5.14.1 for a matching Rust extension to exist
# add:
neo4j-rust-ext == X.Y.Z.*
```I.e., install the same version of `neo4j-rust-ext` as you would install of `neo4j` (except for the last segment which is used for patches of this library).
That's it!
You don't have to change your code but can use the driver as you normally would.
This package will install the driver as its dependency and then inject itself in a place where the driver can find it and pick it up.N.B., since the driver is a simple Python dependency of this package, you can also manually install/specify both packages at the same time without issues.
However, make sure the versions match if you do so or leave the version of one of the two unspecified to let the package manager pick a compatible version for you (resolution might be slow, however).If you experience issues with the driver, consider troubleshooting without the Rust extension first.
For that, simply make sure you haven't installed `neo4j-rust-ext` but *only* `neo4j`.## Requirements
For many operating systems and architectures, the pre-built wheels will work out of the box.
If they don't, pip (or any other Python packaging front-end) will try to build the extension from source.
Here's what you'll need for this:
* Rust 1.67.0 or later:
https://www.rust-lang.org/tools/install
* Further build tools (depending on the platform).
E.g., `gcc` on Ubuntu: `sudo apt install gcc`