Alex
6e44369cbc
Merge pull request 'Optimal layout assignation algorithm' ( #296 ) from optimal-layout into next
...
Reviewed-on: Deuxfleurs/garage#296
2022-12-11 17:41:53 +00:00
Alex
2c2e65ad8b
Merge commit 'ec12d6c' into next
2022-12-11 18:41:15 +01:00
Alex
9d83364ad9
itertools .unique() doesn't require sorted items
2022-12-11 18:30:02 +01:00
Alex
533afcf4e1
simplify
2022-12-11 18:17:08 +01:00
Alex
5ea5fd2130
Always return 200 OK on /v0/health, reinstate admin api doc as draft and complete it
2022-12-11 18:11:28 +01:00
Alex
d7868c48a4
Separate /health (simple text answer) and /v0/health (full json answer, authenticated)
2022-12-05 15:38:32 +01:00
Alex
280d1be7b1
Refactor health check and add ability to return it in json
2022-12-05 15:28:57 +01:00
Alex
2065f011ca
Implement /health admin API endpoint to check node health
2022-12-05 14:59:15 +01:00
Alex
26121bb619
Fix logs appearing twice
2022-11-29 22:23:27 +01:00
Alex
54e800ef8d
Tentative fix for issue #414
2022-11-21 17:13:41 +01:00
Alex
c1fb65194c
Add sled default in garage_model also
2022-11-21 14:25:54 +01:00
Alex
67941000ee
put sled as default feature in garage_db
2022-11-21 14:08:21 +01:00
Quentin
dc50fa3b34
Fix typo in admin API on BucketInfo
2022-11-11 16:56:56 +01:00
Alex
ec12d6c8dd
Slightly simplify code at places
2022-11-08 16:15:45 +01:00
Alex
217abdca18
Fix HTTP return code
2022-11-08 15:38:53 +01:00
Alex
fc2729cd81
Fix integration test
2022-11-08 15:19:46 +01:00
Alex
d75b37b018
Return more info when layout's .check() fails, fix compilation, fix test
2022-11-08 14:58:39 +01:00
Alex
73a4ca8b15
Use bytes as capacity units
2022-11-07 21:12:11 +01:00
Alex
fd5bc142b5
Ensure .sort() is called before counting unique items
2022-11-07 20:29:25 +01:00
Alex
ea5afc2511
Style improvements
2022-11-07 20:11:30 +01:00
Alex
28d7a49f63
Merge branch 'main' into optimal-layout
2022-11-07 12:20:59 +01:00
Alex
e03d9062f7
Show a nice message and a backtrace when Garage panics
2022-11-04 16:39:02 +01:00
Alex
8d3bbf5703
Clearer error messsages
2022-11-04 16:07:33 +01:00
Alex
5b18fd8201
Add garage bucket cleanup-incomplete-uploads command
2022-11-04 11:55:59 +01:00
Alex
57b5c2c754
Change reqwest rustls features
2022-10-18 22:11:27 +02:00
Alex
8bc5caf7aa
Fix issue with 'http(s)://' prefix
2022-10-18 21:17:11 +02:00
Alex
2da8786f54
move things around
2022-10-18 19:13:52 +02:00
Alex
5d8d393054
Load TLS certificates only once
2022-10-18 19:11:16 +02:00
Alex
002b9fc50c
Add TLS support for Consul discovery + refactoring
2022-10-18 18:38:20 +02:00
Alex
5670599372
Merge pull request 'Use status code 204 No Content for empty responses' ( #403 ) from tobikris/garage:http-no-content into main
...
Reviewed-on: Deuxfleurs/garage#403
2022-10-18 14:20:44 +00:00
Tobias Krischer
7865003323
Use status code 204 No Content for empty responses
2022-10-17 10:55:26 +02:00
Alex
c050a59fd0
Fix conditional testing in garage_db
2022-10-14 18:27:18 +02:00
Alex
fcaee3bea0
definitively expunge openssl from dependencies everywhere
2022-10-14 18:10:36 +02:00
Alex
8d04ae7014
cargo2nix unstable (patched), rust 1.63.0, nixpkgs 22.05 (32-bit builds are broken)
2022-10-14 14:30:48 +02:00
Mendes
bcdd1e0c33
Added some comment
2022-10-11 18:29:21 +02:00
Mendes
e5664c9822
Improved the statistics displayed in layout show
...
corrected a few bugs
2022-10-11 17:17:13 +02:00
Mendes
4abab246f1
cargo fmt
2022-10-10 17:21:13 +02:00
Mendes
fcf9ac674a
Tests written in layout.rs
...
added staged_parameters to ClusterLayout
removed the serde(default) -> will need a migration function
2022-10-10 17:19:25 +02:00
Mendes
911eb17bd9
corrected warnings of cargo clippy
2022-10-06 14:53:57 +02:00
Mendes
9407df60cc
Corrected two bugs:
...
- self.node_id_vec was not properly updated when the previous ring was empty
- ClusterLayout::merge was not considering changes in the layout parameters
2022-10-06 12:54:51 +02:00
Mendes
a951b6c452
Added a CLI command to update the parameters for the layout computation (for now, only the zone redundancy)
2022-10-05 16:04:19 +02:00
Mendes
ceac3713d6
modifications in several files to :
...
- have consistent error return types
- store the zone redundancy in a Lww
- print the error and message in the CLI (TODO: for the server Api, should msg be returned in the body response?)
2022-10-05 15:29:48 +02:00
Mendes
829f815a89
Merge remote-tracking branch 'origin/main' into optimal-layout
2022-10-04 18:14:49 +02:00
Mendes
99f96b9564
deleted zone_redundancy from System struct
2022-10-04 18:09:24 +02:00
Alex
ad917ffd3f
Fix instant substractions that might have panicked
2022-09-29 15:53:54 +02:00
Alex
1f97ce37e6
Shutdown properly on SIGTERM/SIGHUP and on Windows signals
2022-09-28 10:41:59 +02:00
Alex
1778e4b318
Fix span name for api server requests
2022-09-26 16:21:30 +02:00
Mendes
bd842e1388
Correction of a few bugs in the tests, modification of ClusterLayout::check
2022-09-22 19:30:01 +02:00
Mendes
7f3249a237
New version of the algorithm that calculate the layout.
...
It takes as paramters the replication factor and the zone redundancy, computes the
largest partition size reachable with these constraints, and among the possible
assignation with this partition size, it computes the one that moves the least number
of partitions compared to the previous assignation.
This computation uses graph algorithms defined in graph_algo.rs
2022-09-21 14:39:59 +02:00
Alex
782630fc27
Initialize metrics exporter earlier ( fix #389 )
2022-09-20 17:50:22 +02:00