Ajgu Graph Database
Ajgu is graph database backed by Oracle Berkeley Database key/value store aka. bsddb. It's meant to be an easy to use, just works persistent graph for people that want to experiment with graph databases. Somekind of SQLite for graph databases in Python.
The other purpose of Ajgu is to be able to create meta-graph or graph-proxy where some part of the graph are computed on the fly and cached in the database. This can be done at the application level, but not so much when you want your application data to be always fresh. If the data is required by several other applications, it leads to complicated problems that could be solved directly in the graph. This part is not written yet.
State of the project
- Indexing is not done yet. You can create index on you own using another database.
- Client/Server is in the work. Right now, prefork doesn't work. You can have only one ajgu process accessing the database if you use the server. If you roll your own server/expert system you can have several processus accessing the same database if you respect bsddb3 rules regarding environment and transaction sharing.
- Querying in Client/Server is done with the API for embedded mode with a few changes. Have a lookt at ajgu/client.py and ajgu/server.py via ajgu/uzelmumu.py.
Development happens @ https://bitbucket.org/amirouche/ajgu-graphdb/
15.06.xx (next release)
- Several API changes
- Transaction support was fully broken, please upgrade if you require transactions.
- move to unittest.TestCase
- use uuid4 for identifier generation
- move Element, Vertex and Edge class to elements.py module
- rework to implement Storage based backend to make future work on multiple backends easier
- rework Element.properties() now it's Element.properties and Element.props with new API (with tests)
- implement Transaction.edge & Transaction.vertex API via manager classes (cf. manager.py). Same API as before but element specific. Now you create a vertex with txn.vertex.create('software'), and retrieve an edge with txn.edge.get(ajgu_depends_bsddb).
- add txn.*.slice
- index elements by labels to speed up txn.*.label queries.
- several cleanups, removed old index/query code (uzelmumu module still works)
- add example app
- better error when magic keys is used but fails
- fix bug where edge and vertex weren't not saved
- fix import error in tests
bsddb3 must be installed on you system. Dependending on the distribution it's called db or bdb. If you have a python3-bsddb3 package use that one.
You can use python setup.py develop or pip install ajgu but you will need python 3 and bsddb headers.
- example directory on bitbucket: https://bitbucket.org/amirouche/ajgu-graphdb/
- documentation directory
A few pointers:
- from ajgu import Storage
- from ajgu import GraphDatabase
- Everything happens in a transaction
- So storage.Transaction is very important. Mind the fact that you never instanciate it directly. Instead, use with GraphDatabase.transaction() as txn.
- Use txn.vertex.create and txn.edge.create to create elements.Vertex and elements.Edge objects.
- Use Vertex.outgoings and Vertex.incomings to jump to edges
- Edge.start() and Edge.end() to jump to vertices
- Properties can be get and set using the dict syntax over Element.props
- Magic properties work, so that you can access an element property with my_vertex.props.key instead of my_vertex.props['key']
- For client/server have a look at ajgu/client.py and server.py.
- They are a few tests in ajgu/database.py file
- They are a others tests in ajgu/* files, they are not supposed to work :)
Feel free to contact me at email@example.com if you need suppport or want to discuss matters related to graph databases.
What ajgu means?
ajgu is a beam used in house construction in amazigh language.
Why not use SQLite instead of bsddb3?
I prefer data to be safe than software fast.
Where can I find a graph server with multi *thread* and *python querying*?
GraphitiDB I never used it for the real. It's relying on old version of Tinkerpop.
Are GraphDBs useful beyond prototyping?
You tell me!
GraphDBs are awesome, where can I learn more?