FoundationDB object storage and queue manager for Golang projects
This project aims to help you use FoundationDB in your project by providing high-level interfaces for transactions, tables, indexes and queues.
Current version is probably stable v2.0.*
Feel free to use it for local tests, experiments or startups, but we strongly recommend to use it carefully for production purposes.
- MVCC logical transactions above the standard fdb "physical" transactions
- All data is stored as key-value Pairs in Tables (collections with key prefix)
- Queries is an orm-style set of simple data operators for Table manipulations
- Indexes is a subcollection of Table with value-id rows
- Queues is a special indexes with time-series data and exclusive reads
- You can store objects of (almost) any size: we overcome size limitations!
- Standard fdb values has 100Kb limit, but our Pairs has not
- Standard fdb transaction has 10Mb limit, but our logical transactions has not
- You can process data as long as you need: we overcome time limitations!
- Standard fdb transaction has 5 sec limit, but our logical transactions has not
- You can use transactional queues: synchronize it with your data
- Pub, Ack and Repeat changes are applying at a commit time
- If you cancel a transaction, no tasks would be published or acknowledged
- You can store any data you want: any value is just a byte slice
- Table and Queue interfaces are schemaless
- Indexes are optional and schemaless
- You can use raw data, JSON, XML, FlatBuffers, Protobuf or anything else you want
- Standard fdb serializable isolation level is downgraded to read committed because of MVCC
- You can use
SharedLock
function to avoid concurrent writes - We can support repeateable read in the future, if needed
- You can use
- Big values (over 100Kb data) reads has some overhead, and they are significant when the data is over 100Mb
- Overhead is significant compared with raw file reads
- You can use gzip or smth else to compress data before saving
- Total read/write throughput (objects/sec) are downgraded because of transactions and replication overhead
- It less then other MVCC systems, like PostgreSQL, but we can better scale because of FoundationDB replication
- It less then other key-value systems, like Redis or MongoDB, but we can use a transactions (almost) without a limitations
- Total queue throughput (tasks/sec) are downgraded because of transactions and replication overhead
- It less then other queue managers, like a RabbitMQ or NATS, but we has a transaction-reliable delayable ordered tasks without duplicates
Feel free to create issues and PRs!
You're lucky, it's awesome and there are good overview for it
... and first of all you must install FoundationDB!
Remember that you should make some tests before commit:
> make test
Inspired from Apple's FoundationDB Record Layer
Powered by Apple's FoundationDB Golang bindings
Supercharged by FlatBuffers