0bbb6673e7
Model changes
2022-01-04 12:45:52 +01:00
5b1117e582
New model for buckets
2022-01-04 12:45:46 +01:00
1eb972b1ac
Add compression using zstd ( #173 )
...
fix #27
Co-authored-by: Trinity Pointard <trinity.pointard@gmail.com>
Reviewed-on: Deuxfleurs/garage#173
Co-authored-by: trinity-1686a <trinity.pointard@gmail.com>
Co-committed-by: trinity-1686a <trinity.pointard@gmail.com>
2021-12-15 11:26:43 +01:00
c94406f428
Improve how node roles are assigned in Garage
...
- change the terminology: the network configuration becomes the role
table, the configuration of a nodes becomes a node's role
- the modification of the role table takes place in two steps: first,
changes are staged in a CRDT data structure. Then, once the user is
happy with the changes, they can commit them all at once (or revert
them).
- update documentation
- fix tests
- implement smarter partition assignation algorithm
This patch breaks the format of the network configuration: when
migrating, the cluster will be in a state where no roles are assigned.
All roles must be re-assigned and commited at once. This migration
should not pose an issue.
2021-11-16 16:05:53 +01:00
9c58ec28d3
add support for vhost-style s3 bucket
2021-11-16 15:41:41 +01:00
43e13a501d
Use published netapp crate instead of git repo
2021-10-26 10:36:57 +02:00
de4276202a
Improve CLI, adapt tests, update documentation
2021-10-25 14:21:48 +02:00
1b450c4b49
Improvements to CLI and various fixes for netapp version
...
Discovery via consul, persist peer list to file
2021-10-22 16:55:24 +02:00
4067797d01
First port of Garage to Netapp
2021-10-22 15:55:18 +02:00
b9127dd6f8
Prepare for v0.3.0 and add migration path from v0.2.1.x
2021-05-28 15:29:58 +02:00
631c36b3ff
S3 API: support ListBuckets
2021-05-03 21:55:30 +02:00
f859d15062
update to v0.2.1
2021-03-19 13:39:18 +01:00
fd8f4caa81
Support old CPUs
2021-03-19 12:19:40 +01:00
dead945c8f
Prepare for release 0.2
2021-03-18 19:33:15 +01:00
f4346cc5f4
Update dependencies
2021-03-16 15:58:40 +01:00
0cd5b2ae19
WIP migrate to tokio 1
2021-03-15 22:36:41 +01:00
3bf2df622a
Time and metadata improvements
2021-03-15 16:21:41 +01:00
a1442f072a
Implement garage stats to get info on node contents
2021-03-12 15:40:54 +01:00
94f3d28774
WIP big refactoring
2021-03-11 16:54:15 +01:00
445912dc6a
Remove migration paths from 0.1 branch
2021-03-10 16:38:31 +01:00
20e6e9fa20
Update sled & try to debug deadlock (but its in sled...)
2021-02-23 21:27:28 +01:00
e8e4418ca7
Add blake2 and xxhash hash functions
2021-02-23 17:52:28 +01:00
6a5add3386
Fix build
2021-01-15 19:12:08 +01:00
e818f51073
Forgot a bump
2021-01-15 18:36:51 +01:00
1d1d497e2b
Bump everything to 0.1.1
2021-01-15 17:54:48 +01:00
c441a358cd
Remove unused dependencies
2021-01-15 16:16:32 +01:00
e8c12072ce
Merge branch 'master' into feature/website
2020-12-10 20:12:56 +01:00
4a5bbbb810
Propose ETag fix
2020-12-05 19:23:46 +01:00
aa320aa04a
Merge branch 'master' into feature/website
2020-11-22 19:54:47 +01:00
435d5f9205
Fix base64/hex checksum comparison
2020-11-22 11:04:33 +01:00
28efe341cb
Merge branch 'master' into feature/website
2020-11-21 18:01:50 +01:00
a88fd49f71
Use handle_get
2020-11-21 17:50:19 +01:00
0f33231ee6
We are able to serve a file
2020-11-21 15:15:25 +01:00
a8b3c8fd58
data hexdump in warning
2020-11-20 23:53:54 +01:00
5b363626f4
Support punnycode
2020-11-20 21:23:32 +01:00
04f455ff7f
Make it compile again
2020-11-19 14:56:00 +01:00
4093833ae8
Extract bucket
2020-11-10 09:57:07 +01:00
54166d2a09
Update cargo.lock
2020-11-08 15:05:28 +01:00
0d3bc169ee
It compiles!
2020-11-03 12:37:16 +01:00
cea871d944
Skeleton to the new web API
2020-11-02 15:48:39 +01:00
6c7f9704ea
Implement correct ETag for objects created with PutObject
2020-07-13 16:51:30 +02:00
86bf4dedac
Add support for model migrations
2020-07-08 16:10:53 +02:00
f22ecb60a8
Update to Hyper 0.13.6 that accepts non-Sync streams in wrap_stream.
...
Simplifies code and makes it possible to publish on crates.io
2020-07-07 17:15:53 +02:00
bec26a1312
Rename garage_core to garage_model
2020-07-07 13:59:22 +02:00
fbe8fe81f2
Add automatic peer discovery from Consul
2020-06-30 18:33:14 +02:00
b46a7788d1
Implement HTTP ranges in get
2020-05-04 13:09:23 +00:00
d867bbcfb5
Implement DeleteObjects
2020-05-01 15:52:35 +00:00
3324971701
Slightly improved S3 compatibility
...
- ListBucket does not require any of the parameters (delimiter,
prefix, max-keys, etc)
- URLs are properly percent_decoded
- PutObject and DeleteObject calls now answer correctly
(empty body, version id in the x-amz-version-id: header)
2020-05-01 14:30:50 +00:00
f2e05986c4
Starting to be S3 compatible
2020-04-24 17:46:52 +00:00
d8f5e643bc
Split code for modular compilation
2020-04-24 10:10:01 +00:00
e8214cb180
Better concurrency:
...
Use Notify instead of stupid sleep in background worker
Use Semaphore to limit concurrent requests in rpc_client
Make more background tasks cancellable
2020-04-22 16:51:52 +00:00
c0335ac690
Remove a few features in dependencies
2020-04-21 20:37:02 +00:00
cc4f2f1cfb
Pretty logging
2020-04-21 12:54:55 +00:00
e325c7f47a
Add hostname to node info
2020-04-19 19:08:48 +02:00
69f1d8fef2
WIP
...
TODOs:
- ensure sync goes both way
- finish sending blocks to other nodes when they need them before deleting
2020-04-17 17:09:57 +02:00
d2814b5c33
TLS works \o/
...
So, the issues were:
- webpki does not support IP addresses as DNS names in URLs,
so I hacked the HttpsConnector to always provide a fixed string
as the DNS name for server certificate validation
- the certificate requied a SAN section which was complicated to build
but eventually the solution is there in genkeys.sh
2020-04-12 19:00:30 +02:00
d1e8f78b2c
Trying to do TLS
2020-04-12 15:51:19 +02:00
1d786c2c66
Something works
2020-04-09 18:43:53 +02:00
cc580da0ae
Some work
2020-04-08 23:01:49 +02:00
bacc76a057
Some work in actually storing things
2020-04-08 22:00:41 +02:00
90cdffb425
custom data type for hashes and identifiers
2020-04-07 18:10:20 +02:00
3c36b449a3
Some work
2020-04-06 21:02:15 +02:00
1a5e6e39af
Some more basic work
2020-04-06 19:55:39 +02:00
7102db1d54
First commit: skeleton for something great
2020-04-05 23:33:42 +02:00