Alex 4f38cadf6e Background task manager (#332)
- [x] New background worker trait
- [x] Adapt all current workers to use new API
- [x] Command to list currently running workers, and whether they are active, idle, or dead
- [x] Error reporting
- Optimizations
  - [x] Merkle updater: several items per iteration
  - [ ] Use `tokio::task::spawn_blocking` where appropriate so that CPU-intensive tasks don't block other things going on
- scrub:
  - [x] have only one worker with a channel to start/pause/cancel
  - [x] automatic scrub
  - [x] ability to view and change tranquility from CLI
  - [x] persistence of a few info
- [ ] Testing

Co-authored-by: Alex Auvolat <alex@adnab.me>
Reviewed-on: https://git.deuxfleurs.fr/Deuxfleurs/garage/pulls/332
Co-authored-by: Alex <alex@adnab.me>
Co-committed-by: Alex <alex@adnab.me>
2022-07-08 13:30:26 +02:00
2022-06-29 11:50:51 +02:00
2022-03-17 12:17:38 +01:00
2022-04-07 16:12:35 +02:00
2022-07-08 13:30:26 +02:00
2020-06-30 17:18:42 +02:00
2022-02-10 17:55:50 +01:00
2020-04-28 10:18:14 +00:00
2022-07-08 13:30:26 +02:00
2022-07-08 13:30:26 +02:00
2021-10-29 11:34:01 +02:00
2022-05-10 13:16:57 +02:00
2021-03-16 16:35:46 +01:00
2022-07-08 13:30:26 +02:00
2020-04-10 22:01:48 +02:00

Garage Build Status

Garage logo

[ Website and documentation | Binary releases | Git repository | Matrix channel ]

Garage is a lightweight S3-compatible distributed object store, with the following goals:

  • As self-contained as possible
  • Easy to set up
  • Highly resilient to network failures, network latency, disk failures, sysadmin failures
  • Relatively simple
  • Made for multi-datacenter deployments

Non-goals include:

  • Extremely high performance
  • Complete implementation of the S3 API
  • Erasure coding (our replication model is simply to copy the data as is on several nodes, in different datacenters if possible)

Our main use case is to provide a distributed storage layer for small-scale self hosted services such as Deuxfleurs.

Description
No description provided
Readme AGPL-3.0 43 MiB
Languages
Rust 94.2%
Clojure 1.8%
Shell 1.8%
Nix 1.2%
Python 0.7%
Other 0.2%