Alex Auvolat
575726358c
Tune Sled configuration
...
- Make sled cache size and flush interval configurable
- Set less agressive default values:
- cache size 128MB instead of 1GB
- Flush interval 2 seconds instead of .5 seconds
2021-05-03 17:27:43 +02:00
Alex Auvolat
dcfc32cf85
Many S3 compatibility improvements:
...
- return XML errors
- implement AuthorizationHeaderMalformed error to redirect clients to
correct location (used by minio client)
- implement GetBucketLocation
- fix DeleteObjects XML parsing and response
2021-04-28 01:05:40 +02:00
Alex Auvolat
642186c530
Fix #59 (& issue)
2021-04-27 23:10:43 +02:00
Alex Auvolat
119217f9f6
change a few comments
2021-04-27 16:53:47 +02:00
Trinity Pointard
2812a027ea
change some more comments and revert changes on TableSchema
2021-04-27 16:49:07 +02:00
Trinity Pointard
74373aebcf
make most requested changes
2021-04-27 16:47:08 +02:00
Alex Auvolat
16300bbd89
remove useless comment
2021-04-27 16:44:01 +02:00
Trinity Pointard
5c4b2cec3c
document garage crate
2021-04-27 16:37:10 +02:00
Trinity Pointard
1e3df189d0
document api crate
2021-04-27 16:37:10 +02:00
Trinity Pointard
a2e1617d84
document web crate
2021-04-27 16:37:10 +02:00
Trinity Pointard
67585a4ffa
attempt at documenting model crate
2021-04-27 16:37:10 +02:00
Trinity Pointard
b437610812
attempt at documenting table crate
2021-04-27 16:37:10 +02:00
Trinity Pointard
f871689571
run cargo fmt on util and make missing doc warning
2021-04-27 16:37:10 +02:00
Trinity Pointard
8e0524ae15
document rpc crate
2021-04-27 16:37:10 +02:00
Trinity Pointard
f9bd2d8fb7
document util crate
2021-04-27 16:37:10 +02:00
Alex Auvolat
6b2b400292
small simplify
2021-04-27 16:37:09 +02:00
Alex Auvolat
8c33d565d6
Merge discovery loop with consul
2021-04-27 16:37:09 +02:00
Alex Auvolat
948e44a3f6
cargo fmt
2021-04-27 16:37:09 +02:00
Alex Auvolat
3e2e38c830
Print stats
2021-04-27 16:37:09 +02:00
Alex Auvolat
2e53e31cdd
Cargo fmt
2021-04-27 16:37:09 +02:00
Alex Auvolat
64b91c2645
Keep old data
2021-04-27 16:37:09 +02:00
Alex Auvolat
e16077f40a
Persist directly and not in background
2021-04-27 16:37:09 +02:00
Alex Auvolat
9ced9f78dc
Improve bootstraping: do it regularly; persist peer list
2021-04-27 16:37:08 +02:00
Alex Auvolat
f859d15062
update to v0.2.1
2021-03-19 13:39:18 +01:00
Alex Auvolat
fd8f4caa81
Support old CPUs
2021-03-19 12:19:40 +01:00
Alex Auvolat
4c26a0b9c1
Update Cargo.toml files with AGPL license info
2021-03-18 21:59:17 +01:00
Alex Auvolat
a1014224d3
garage node configure --replace <old_node_id> <new_node_id>
2021-03-18 21:49:12 +01:00
Trinity Pointard
f17cb6c969
resolve domain to multiple addresses
...
And warn instead of failling when a domain can't be resolved
2021-03-18 21:04:30 +01:00
Trinity Pointard
c8a7ce5cdf
remove domain resolution for *_bind_addr
2021-03-18 19:47:51 +01:00
Trinity Pointard
81e9db783f
simplify addresse deserialialiser and limit allocations
2021-03-18 19:47:51 +01:00
Trinity Pointard
ae3b7029a9
add support for using domain name in configuration
2021-03-18 19:47:51 +01:00
Alex Auvolat
6edbc65847
Add trinity's comment in the code
2021-03-18 19:46:43 +01:00
Alex
bfa0ff8f82
Merge pull request 'add support for caching headers' ( #49 ) from trinity-1686a/garage:cache-headers into master
...
Reviewed-on: https://git.deuxfleurs.fr/Deuxfleurs/garage/pulls/49
2021-03-18 19:45:02 +01:00
Alex Auvolat
dead945c8f
Prepare for release 0.2
2021-03-18 19:33:15 +01:00
Alex Auvolat
4eb16e8863
Allow to import keys from previous Garage instance
2021-03-18 19:24:59 +01:00
Trinity Pointard
b4c903371c
add support for caching headers
2021-03-18 15:46:33 +01:00
Alex Auvolat
390ab02f41
Todo make a test for the Merkle updater
2021-03-16 20:13:07 +01:00
Alex Auvolat
7b10245dfb
Leader-based GC
2021-03-16 18:42:33 +01:00
Alex Auvolat
08bcd51956
GC object table in a specific case
2021-03-16 16:51:15 +01:00
Alex Auvolat
3fadc5cbbd
Small changes
2021-03-16 16:35:10 +01:00
Alex Auvolat
f4346cc5f4
Update dependencies
2021-03-16 15:58:40 +01:00
Alex Auvolat
2a41b82384
Simpler Merkle & sync
2021-03-16 12:18:03 +01:00
Alex Auvolat
0aad2f2e06
some reordering
2021-03-16 11:47:39 +01:00
Alex Auvolat
515029d026
Refactor code
2021-03-16 11:43:58 +01:00
Alex Auvolat
1d9961e411
Simplify replication logic
2021-03-16 11:14:27 +01:00
Alex Auvolat
6a8439fd13
Some improvements in background worker but we terminate late
2021-03-15 23:14:12 +01:00
Alex Auvolat
0cd5b2ae19
WIP migrate to tokio 1
2021-03-15 22:36:41 +01:00
Alex Auvolat
4d4117f2b4
Refactor block resync loop; make workers infaillible
2021-03-15 20:09:44 +01:00
Alex Auvolat
667e4e72a8
Small fixes
2021-03-15 19:51:16 +01:00
Alex Auvolat
642bed601f
Make it case-insensitive
2021-03-15 19:16:42 +01:00
Alex Auvolat
5ee1d956b6
Allow manipulation of keys by their shorthand in the CLI
2021-03-15 19:14:26 +01:00
Alex Auvolat
537f652fec
Tiny things
2021-03-15 18:40:27 +01:00
Alex Auvolat
0290afe1f8
Make block rc code more understandable
2021-03-15 18:27:26 +01:00
Alex Auvolat
3bf2df622a
Time and metadata improvements
2021-03-15 16:21:41 +01:00
Alex Auvolat
097c339d98
Fix race condition
2021-03-15 15:26:29 +01:00
Alex Auvolat
bdcbdd1cd8
Fix list API bug
2021-03-15 14:46:37 +01:00
Alex Auvolat
9b118160a8
Optim & refactor
2021-03-12 22:06:56 +01:00
Alex Auvolat
831eb35763
cargo fmt
2021-03-12 21:52:19 +01:00
Alex Auvolat
c475471e7a
Implement table gc, currently for block_ref and version only
2021-03-12 19:57:37 +01:00
Alex Auvolat
f4aad8fe6e
cargo fmt
2021-03-12 18:16:03 +01:00
Alex Auvolat
5ab33fddac
Refactor CLI and prettify CLI outpu
2021-03-12 18:12:31 +01:00
Alex Auvolat
a1442f072a
Implement garage stats to get info on node contents
2021-03-12 15:40:54 +01:00
Alex Auvolat
cbe7e1a66a
Move table rpc client out of tableaux
2021-03-12 15:07:23 +01:00
Alex Auvolat
8860aa19b8
Make syncer have its own rpc client/server
2021-03-12 15:05:26 +01:00
Alex Auvolat
1fea257291
Don't sync at beginning
2021-03-12 14:51:17 +01:00
Alex Auvolat
7fdaf7aef0
Fix merkle updater not being notified; improved logging
2021-03-12 14:37:46 +01:00
Alex Auvolat
1ec49980ec
whoops
2021-03-11 19:30:24 +01:00
Alex Auvolat
3f7a496355
More security: don't delete stuff too easily
2021-03-11 19:06:27 +01:00
Alex Auvolat
f7c2cd1cd7
Add comment, and also whoops, this wasn't doing what we expected
2021-03-11 18:56:18 +01:00
Alex Auvolat
fae5104a2c
Add a nice warning
2021-03-11 18:50:32 +01:00
Alex Auvolat
db7a9d4948
Tiny changes
2021-03-11 18:45:26 +01:00
Alex Auvolat
046b649bcc
(not well tested) use merkle tree for sync
2021-03-11 18:28:27 +01:00
Alex Auvolat
94f3d28774
WIP big refactoring
2021-03-11 16:54:15 +01:00
Alex Auvolat
8d63738cb0
Checkpoint: add merkle tree in data table
2021-03-11 13:47:21 +01:00
Alex Auvolat
3214dd52dd
Very minor changes
2021-03-10 21:50:09 +01:00
Alex Auvolat
af7600f989
Correctly implement CompleteMultipartUpload with etag check of parts
2021-03-10 17:01:05 +01:00
Alex Auvolat
445912dc6a
Remove migration paths from 0.1 branch
2021-03-10 16:38:31 +01:00
Alex Auvolat
0fd7df8fa0
Switch to blake2 sum for identifying blocks by their data
2021-03-10 16:33:31 +01:00
Alex Auvolat
2afd2c81ba
Change hash function to blake2 for partition keys based on strings
2021-03-10 16:23:57 +01:00
Alex Auvolat
f319a7d374
Refactor model stuff, including cleaner CRDTs
2021-03-10 16:21:56 +01:00
Alex Auvolat
6a3dcf3974
Rename n_tokens into capacity
2021-03-10 14:52:03 +01:00
Alex Auvolat
7cda917b6b
update condition
2021-03-05 17:08:03 +01:00
Alex Auvolat
d7e005251d
Not fully tested: new multi-dc MagLev
2021-03-05 16:22:29 +01:00
Alex Auvolat
3882d5ba36
Remove epidemic propagation for fully replicated stuff: write directly to all nodes
2021-03-05 15:09:18 +01:00
Alex Auvolat
49c25a1509
Simulate stuff moving around
2021-02-25 10:53:33 +01:00
Alex Auvolat
5fe95ebae7
fix tracing
2021-02-24 12:18:01 +01:00
Alex Auvolat
13e2eda0c2
Arrange block manager
2021-02-24 11:58:03 +01:00
Alex Auvolat
09fd6ea7f0
I was tired yesterday
2021-02-24 11:05:59 +01:00
Alex Auvolat
a52ab69640
fix misuse of sled transactions
2021-02-23 22:45:36 +01:00
Alex Auvolat
20e6e9fa20
Update sled & try to debug deadlock (but its in sled...)
2021-02-23 21:27:28 +01:00
Alex Auvolat
bf25c95fe2
Make updated() be a sync function that doesn't fail
2021-02-23 20:25:15 +01:00
Alex Auvolat
28bc967c83
Handle correctly deletion dues to offloading
2021-02-23 19:59:43 +01:00
Alex Auvolat
55156cca9d
Several changes in table_sync:
...
- separate path for case of offloading a partition we don't store
- use sync::Mutex instead of tokio::Mutex, make less fn's async
2021-02-23 19:11:02 +01:00
Alex Auvolat
40763fd749
Cargo fmt
2021-02-23 18:46:25 +01:00
Alex Auvolat
6e6f7e8555
Replace some checksums where it makes sense
2021-02-23 18:14:37 +01:00
Alex Auvolat
e8e4418ca7
Add blake2 and xxhash hash functions
2021-02-23 17:52:28 +01:00
Alex Auvolat
b1b640ae8b
rename hash() to sha256sum(), we might want to change it at some places
2021-02-21 15:24:30 +01:00
Alex Auvolat
80892df8cc
Some refactoring
2021-02-21 13:11:10 +01:00
Alex Auvolat
3bcbbe1e31
More precise logging (warn only when returning a 500)
2021-02-20 00:30:39 +01:00
Alex Auvolat
10b983b8e7
Add verification of part numbers in CompleteMultipartUpload (WIP #30 )
2021-02-20 00:13:07 +01:00