Commit message (Collapse) | Author | Age | Files | Lines | |
---|---|---|---|---|---|
* | Update rmp-serde | Alex Auvolat | 2022-06-03 | 1 | -2/+2 |
| | |||||
* | whoops | Alex Auvolat | 2022-06-03 | 1 | -2/+16 |
| | |||||
* | Slightly prettier code | Alex Auvolat | 2022-06-03 | 1 | -50/+18 |
| | |||||
* | Fix most clippy lints | Alex Auvolat | 2022-06-03 | 1 | -2/+5 |
| | |||||
* | Change value type to be a dyn thing | Alex Auvolat | 2022-06-03 | 1 | -2/+2 |
| | |||||
* | Sqlite iter with unsafe code | Alex Auvolat | 2022-06-02 | 1 | -20/+37 |
| | |||||
* | Adapt Garage to use new DB abstraction | Alex Auvolat | 2022-06-02 | 1 | -4/+18 |
| | |||||
* | First implementation of K2V (#293) | Alex | 2022-05-10 | 1 | -3/+3 |
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | **Specification:** View spec at [this URL](https://git.deuxfleurs.fr/Deuxfleurs/garage/src/branch/k2v/doc/drafts/k2v-spec.md) - [x] Specify the structure of K2V triples - [x] Specify the DVVS format used for causality detection - [x] Specify the K2V index (just a counter of number of values per partition key) - [x] Specify single-item endpoints: ReadItem, InsertItem, DeleteItem - [x] Specify index endpoint: ReadIndex - [x] Specify multi-item endpoints: InsertBatch, ReadBatch, DeleteBatch - [x] Move to JSON objects instead of tuples - [x] Specify endpoints for polling for updates on single values (PollItem) **Implementation:** - [x] Table for K2V items, causal contexts - [x] Indexing mechanism and table for K2V index - [x] Make API handlers a bit more generic - [x] K2V API endpoint - [x] K2V API router - [x] ReadItem - [x] InsertItem - [x] DeleteItem - [x] PollItem - [x] ReadIndex - [x] InsertBatch - [x] ReadBatch - [x] DeleteBatch **Testing:** - [x] Just a simple Python script that does some requests to check visually that things are going right (does not contain parsing of results or assertions on returned values) - [x] Actual tests: - [x] Adapt testing framework - [x] Simple test with InsertItem + ReadItem - [x] Test with several Insert/Read/DeleteItem + ReadIndex - [x] Test all combinations of return formats for ReadItem - [x] Test with ReadBatch, InsertBatch, DeleteBatch - [x] Test with PollItem - [x] Test error codes - [ ] Fix most broken stuff - [x] test PollItem broken randomly - [x] when invalid causality tokens are given, errors should be 4xx not 5xx **Improvements:** - [x] Descending range queries - [x] Specify - [x] Implement - [x] Add test - [x] Batch updates to index counter - [x] Put K2V behind `k2v` feature flag Co-authored-by: Alex Auvolat <alex@adnab.me> Reviewed-on: https://git.deuxfleurs.fr/Deuxfleurs/garage/pulls/293 Co-authored-by: Alex <alex@adnab.me> Co-committed-by: Alex <alex@adnab.me> | ||||
* | New model for buckets | Alex Auvolat | 2022-01-04 | 1 | -2/+2 |
| | |||||
* | Add tranquilizer mechanism to improve on token bucket mechanismtranquility | Alex Auvolat | 2021-11-04 | 1 | -2/+2 |
| | |||||
* | Refactoring on repair commandscli-verify-integrity | Alex Auvolat | 2021-10-27 | 1 | -49/+31 |
| | |||||
* | add cli parameter to verify local bloc integrity | Trinity Pointard | 2021-10-27 | 1 | -0/+8 |
| | | | | | reuse code for listing local blocks add disk i/o speed limit on integrity check | ||||
* | Some improvements in background worker but we terminate late | Alex Auvolat | 2021-03-15 | 1 | -5/+1 |
| | |||||
* | Refactor block resync loop; make workers infaillible | Alex Auvolat | 2021-03-15 | 1 | -0/+10 |
| | |||||
* | Fix race condition | Alex Auvolat | 2021-03-15 | 1 | -17/+3 |
| | |||||
* | (not well tested) use merkle tree for sync | Alex Auvolat | 2021-03-11 | 1 | -22/+11 |
| | |||||
* | WIP big refactoring | Alex Auvolat | 2021-03-11 | 1 | -22/+7 |
| | |||||
* | Refactor model stuff, including cleaner CRDTs | Alex Auvolat | 2021-03-10 | 1 | -5/+4 |
| | |||||
* | Rename garage_core to garage_model | Alex Auvolat | 2020-07-07 | 1 | -4/+4 |
| | |||||
* | Repair: do not mark deleted when upstream object is not found | Alex Auvolat | 2020-05-04 | 1 | -4/+4 |
| | | | | | | | | | | With the previous behaviour, repairing could see some data as absent and decide that the object or version was deleted, thus going on to delete the version and blocks. In the case where read_quorum + write_quorum <= replication_factor however, entries may not yet be returned by the get, thus data would have been deleted that should hot have been. The new behavior is more cautious and just skips the entry when the warning is emitted. | ||||
* | Fix deletion propagation | Alex Auvolat | 2020-04-26 | 1 | -1/+5 |
| | |||||
* | Add key table to repair procedure | Alex Auvolat | 2020-04-26 | 1 | -0/+7 |
| | |||||
* | Split code for modular compilation | Alex Auvolat | 2020-04-24 | 1 | -0/+183 |