aboutsummaryrefslogtreecommitdiff
path: root/src
Commit message (Collapse)AuthorAgeFilesLines
* Simplify+improve async hasher by using bounded channellx-perf-improvementsAlex Auvolat2022-09-121-8/+5
|
* Merge branch 'main' into lx-perf-improvementsAlex Auvolat2022-09-0837-425/+953
|\
| * Move version back into utilimprove-depsAlex Auvolat2022-09-079-11/+12
| |
| * Inject GIT_VERSION even laterAlex Auvolat2022-09-072-8/+18
| |
| * Fix mergeAlex Auvolat2022-09-071-4/+4
| |
| * Merge branch 'main' into improve-depsAlex Auvolat2022-09-078-527/+724
| |\
| * | Fix build errorAlex Auvolat2022-09-071-1/+1
| | |
| * | Add warnings when features are not included in buildAlex Auvolat2022-09-072-0/+8
| | |
| * | Error messages when system-libs XOR bundled-libs != 1Alex Auvolat2022-09-071-0/+6
| | |
| * | Make all HTTP services optionnalAlex Auvolat2022-09-077-275/+301
| | |
| * | Report build features in garage --helpAlex Auvolat2022-09-075-4/+56
| | |
| * | Move GIT_VERSION injection later in build chain to reduce build timesAlex Auvolat2022-09-0710-66/+63
| | |
| * | cargo fmtAlex Auvolat2022-09-062-2/+0
| | |
| * | Include code from v0.5.1 directly to remove dependenciesAlex Auvolat2022-09-0612-5/+355
| | |
| * | Disable k2v tests when feature is disabledAlex Auvolat2022-09-061-0/+1
| | |
| * | Remove opentelemetry-otlp dep in api/Alex Auvolat2022-09-062-3/+1
| | |
| * | Make all DB engines optional build featuresAlex Auvolat2022-09-065-7/+50
| | |
| * | Bump versions to 0.8.0 (compatibility is broken already)Alex Auvolat2022-09-069-35/+35
| | |
| * | Fix clippyAlex Auvolat2022-09-061-2/+2
| | |
| * | Allow building without Prometheus exporter (/metrics endpoint)Jakub Jirutka2022-09-063-27/+41
| | | | | | | | | | | | | | | | | | prometheus and opentelemetry-prometheus add 7 extra dependencies in total and increases the size of the garage binary by ~7 % (with fat LTO).
| * | Make OTLP exporter optional via feature "telemetry-otlp"Jakub Jirutka2022-09-064-3/+13
| | | | | | | | | | | | | | | opentelemetry-otlp add 48 (!) extra dependencies and increases the size of the garage binary by ~11 % (with fat LTO).
| * | Remove Heed default featuresAlex Auvolat2022-09-051-1/+1
| | |
| * | Allow linking against system-provided libsqliteJakub Jirutka2022-09-032-1/+10
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Unfortunately, rusqlite uses the opposite logic for enabling/disabling bundled libraries to others (libsodium-sys, zstd-sys). Cargo features are very limited and doesn't allow to enable feature A in a dependency iff feature B is disabled. Note, lmdb-rkv-sys doesn't need any special treatment because it automatically links against system liblmdb if found via pkgconf. Linux distros should build garage with `--no-default-features --features system-libs` to disable bundled-libs and enable system-libs.
| * | Add feature "system-libs" to enable linking against system librariesJakub Jirutka2022-09-033-0/+6
| | | | | | | | | | | | | | | | | | | | | | | | If this feature is enabled, libsodium-sys and zstd-sys will link dynamically against system-provided libraries instead of building and linking statically the bundled (possibly outdated and vulnerable) copies of them. This feature is intended mainly for linux package maintainers.
* | | Merge branch 'main' into lx-perf-improvementsAlex Auvolat2022-09-058-521/+725
|\ \ \ | | |/ | |/|
| * | fix clippyresync-ajustable-speedAlex Auvolat2022-09-021-2/+2
| | |
| * | Ability to have up to 4 concurrently working resync workersAlex Auvolat2022-09-024-22/+95
| | |
| * | Make BlockManagerLocked fully private againAlex Auvolat2022-09-022-25/+24
| | |
| * | block manager: refactor: split resync into separate fileAlex Auvolat2022-09-025-555/+595
| | |
| * | Ability to dynamically set resync tranquilityAlex Auvolat2022-09-026-23/+108
| |/
* | Update to netapp 0.4.5 - fixed pingAlex Auvolat2022-09-021-1/+1
| |
* | Add env filter to tracing subscriberAlex Auvolat2022-08-312-1/+2
| |
* | Tracing-subscriber: write to stderrAlex Auvolat2022-08-311-1/+3
| |
* | Replace logging crate pretty_env_logger by tracing_subscriber::fmtAlex Auvolat2022-08-312-2/+2
| |
* | Merge branch 'main' into lx-perf-improvementsAlex Auvolat2022-08-297-57/+65
|\|
| * Configure structopt to report the right versionv0.7.2_ci-test-2bug/reported-versionQuentin Dufour2022-08-117-57/+65
| | | | | | | | | | | | | | | | | | | | By default, structopt reports the value provided by the env var CARGO_PKG_VERSION, feeded by Cargo when reading Cargo.toml. However for Garage we use a versioning based on git, so we often report a version that is behind the real version. In this commit, we create garage_util::version::garage() that reports the right version and configure all structopt subcommands to call this function instead of using the env var.
* | fix clippyAlex Auvolat2022-07-291-6/+1
| |
* | Faster chunkerAlex Auvolat2022-07-291-10/+32
| |
* | cargo fmtAlex Auvolat2022-07-291-1/+1
| |
* | Fix testsAlex Auvolat2022-07-292-1/+4
| |
* | More make clippy happyAlex Auvolat2022-07-291-2/+0
| |
* | Make clippy happyAlex Auvolat2022-07-291-0/+6
| |
* | Performance improvements:Alex Auvolat2022-07-294-28/+59
| | | | | | | | | | - reduce contention on mutation_lock by having 256 of them - better lmdb defaults
* | Compute hashes on dedicated threadsAlex Auvolat2022-07-2910-34/+110
|/
* Uniformize tracing::* imports (hopefully fixes 32-bit build)fix-32bit-buildAlex Auvolat2022-07-154-4/+3
|
* Background task manager (#332)Alex2022-07-0824-709/+1606
| | | | | | | | | | | | | | | | | | | | | - [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>
* add delays in k2v test_items_and_indicesAlex Auvolat2022-07-081-0/+6
|
* Publish k2v-client crate to crates.io (#337)Alex2022-07-041-2/+7
| | | | | | | Co-authored-by: Alex Auvolat <alex@adnab.me> Reviewed-on: https://git.deuxfleurs.fr/Deuxfleurs/garage/pulls/337 Co-authored-by: Alex <alex@adnab.me> Co-committed-by: Alex <alex@adnab.me>
* Fix poll item when item didn't changek2v-poll-fixAlex Auvolat2022-07-042-5/+12
|
* Add `poll` command to `k2v-cli` (#335)Alex2022-07-041-0/+28
| | | | | | | Co-authored-by: Alex Auvolat <alex@adnab.me> Reviewed-on: https://git.deuxfleurs.fr/Deuxfleurs/garage/pulls/335 Co-authored-by: Alex <alex@adnab.me> Co-committed-by: Alex <alex@adnab.me>