84b4a868e3
Migration of cluster layout from v0.8 to v0.9
2023-01-11 17:47:46 +01:00
Jonathan Davies
cb07e6145c
Changed all instances of assignation to assignment.
2023-01-05 11:09:25 +00:00
570e5e5bbb
Merge branch 'main' into next
2023-01-04 11:34:43 +01:00
1fc220886a
Fix Consul & Kubernetes discovery with new way of doing background things
2023-01-03 16:55:59 +01:00
8d5505514f
Make it explicit when using nonversioned encoding
2023-01-03 15:27:36 +01:00
cdb2a591e9
Refactor how things are migrated
2023-01-03 14:44:47 +01:00
939a6d67e8
Merge branch 'main' into internals-rework
2023-01-02 15:07:44 +01:00
6775569525
Bump everything to v0.8.1
2023-01-02 14:15:33 +01:00
e6f14ab5cf
better error message handling
2022-12-14 16:11:19 +01:00
510b620108
Get rid of background::spawn
2022-12-14 16:08:05 +01:00
a19bfef508
Improve error message on rpc connection failure
2022-12-14 12:57:33 +01:00
d56c472712
Refactor background runner and get rid of job worker
2022-12-14 12:51:42 +01:00
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
2c2e65ad8b
Merge commit 'ec12d6c' into next
2022-12-11 18:41:15 +01:00
9d83364ad9
itertools .unique() doesn't require sorted items
2022-12-11 18:30:02 +01:00
280d1be7b1
Refactor health check and add ability to return it in json
2022-12-05 15:28:57 +01:00
54e800ef8d
Tentative fix for issue #414
2022-11-21 17:13:41 +01:00
ec12d6c8dd
Slightly simplify code at places
2022-11-08 16:15:45 +01:00
d75b37b018
Return more info when layout's .check() fails, fix compilation, fix test
2022-11-08 14:58:39 +01:00
73a4ca8b15
Use bytes as capacity units
2022-11-07 21:12:11 +01:00
fd5bc142b5
Ensure .sort() is called before counting unique items
2022-11-07 20:29:25 +01:00
ea5afc2511
Style improvements
2022-11-07 20:11:30 +01:00
28d7a49f63
Merge branch 'main' into optimal-layout
2022-11-07 12:20:59 +01:00
57b5c2c754
Change reqwest rustls features
2022-10-18 22:11:27 +02:00
8bc5caf7aa
Fix issue with 'http(s)://' prefix
2022-10-18 21:17:11 +02:00
2da8786f54
move things around
2022-10-18 19:13:52 +02:00
5d8d393054
Load TLS certificates only once
2022-10-18 19:11:16 +02:00
002b9fc50c
Add TLS support for Consul discovery + refactoring
2022-10-18 18:38:20 +02:00
fcaee3bea0
definitively expunge openssl from dependencies everywhere
2022-10-14 18:10:36 +02:00
bcdd1e0c33
Added some comment
2022-10-11 18:29:21 +02:00
e5664c9822
Improved the statistics displayed in layout show
...
corrected a few bugs
2022-10-11 17:17:13 +02:00
4abab246f1
cargo fmt
2022-10-10 17:21:13 +02:00
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
911eb17bd9
corrected warnings of cargo clippy
2022-10-06 14:53:57 +02:00
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
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
829f815a89
Merge remote-tracking branch 'origin/main' into optimal-layout
2022-10-04 18:14:49 +02:00
99f96b9564
deleted zone_redundancy from System struct
2022-10-04 18:09:24 +02:00
ad917ffd3f
Fix instant substractions that might have panicked
2022-09-29 15:53:54 +02:00
bd842e1388
Correction of a few bugs in the tests, modification of ClusterLayout::check
2022-09-22 19:30:01 +02:00
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
ded444f6c9
Ability to have custom timeouts in request strategy (not used)
2022-09-20 16:01:41 +02:00
56592e1853
RPC performance changes
...
- configurable ping timeout
- single, much higher, configurable RPC timeout
- no more concurrency semaphore
2022-09-19 20:31:00 +02:00
e46dc2a8ef
Allow for hostnames in bootstrap_peers and rpc_public_addr ( fix #353 )
2022-09-14 16:09:38 +02:00
ab722cb40f
Add checks on replication_factor of layouts we use ( fix #363 , fix #364 )
2022-09-13 16:22:23 +02:00
44733474bb
Remove/change println! in server code ( fix #358 )
2022-09-13 16:01:55 +02:00
28a4af73ca
Use netapp 0.5 published from crates.io
2022-09-13 13:11:44 +02:00
7f54706b95
Merge branch 'lx-perf-improvements' into netapp-stream-body
2022-09-08 15:50:56 +02:00
d9d199a6c9
Merge branch 'main' into lx-perf-improvements
2022-09-08 15:49:17 +02:00
db61f41030
Move GIT_VERSION injection later in build chain to reduce build times
2022-09-07 11:59:56 +02:00