aboutsummaryrefslogtreecommitdiff
Commit message (Collapse)AuthorAgeFilesLines
...
| | * | | | | | Merge pull request 'Make OTLP exporter optional and allow building without ↵Alex2022-09-066-30/+55
| | |\ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Prometheus exporter (/metrics)' (#372) from jirutka/garage:telemetry-and-metrics into improve-deps Reviewed-on: https://git.deuxfleurs.fr/Deuxfleurs/garage/pulls/372 Reviewed-by: Alex <alex@adnab.me>
| | | * | | | | | 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).
| | | * | | | | | Use the new cargo feature resolver "2"Jakub Jirutka2022-09-061-0/+1
| | |/ / / / / / | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Garage currently uses the legacy resolver "1". The new one is used by default if the root package specifies 'edition = 2021', which Garage does not (yet). The problem with the legacy resolver is, among others, that features enabled by dev-dependencies are propagated to normal dependencies. This affects e.g. hyper - one of the dev-dependencies enables "http2" feature that adds many extra dependencies. If we build garage without opentelemetry-otlp (this is enabled in the following commit), there's no normal dependency enabling "http2" feature. See https://doc.rust-lang.org/cargo/reference/resolver.html#feature-resolver-version-2
| | * | | | | | Remove Heed default featuresAlex Auvolat2022-09-052-2/+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-034-0/+7
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 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-060-0/+0
| | | |\ \ \ \ \ | | |_|/ / / / / | |/| | | | | |
| * | | | | | | Merge pull request 'Update .drone.yml signature' (#374) from ↵Alex2022-09-051-1/+1
| |\ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | fix-drone-signature into main Reviewed-on: https://git.deuxfleurs.fr/Deuxfleurs/garage/pulls/374
| | * | | | | | | Update .drone.yml signaturefix-drone-signatureAlex Auvolat2022-09-051-1/+1
| |/ / / / / / /
| | | * | | | | Merge branch 'main' into lx-perf-improvementsAlex Auvolat2022-09-058-521/+725
| | | |\ \ \ \ \ | | |_|/ / / / / | |/| | | | | |
| * | | | | | | Merge pull request 'Make block resync speed dynamically configurable' (#369) ↵Alex2022-09-058-527/+724
| |\ \ \ \ \ \ \ | | |/ / / / / / | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | from resync-ajustable-speed into main Included in this PR: - [x] Small refactor, resync code is moved to a separate `block/resync.rs` file - [x] Block resync tranquility is no longer in config file, it is set dynamically using `garage worker set resync-tranquility` (this parameter is persisted over Garage restarts) - [x] Up to 4 block resync workers can be activated to run simultaneously to speed up big resyncs, this parameter is set dynamically using `garage worker set resync-n-workers` Reviewed-on: https://git.deuxfleurs.fr/Deuxfleurs/garage/pulls/369
| | * | | | | | 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-024-78/+44
| | | |_|_|/ | | |/| | |
| | * | | | update cargo.nixAlex Auvolat2022-08-311-4/+38
| | | | | |
| | * | | | Add env filter to tracing subscriberAlex Auvolat2022-08-313-1/+24
| | | | | |
| | * | | | Tracing-subscriber: write to stderrAlex Auvolat2022-08-311-1/+3
| | | | | |
| | * | | | Replace logging crate pretty_env_logger by tracing_subscriber::fmtAlex Auvolat2022-08-314-9/+156
| | | |_|/ | | |/| |
| | * | | Update drone signatureAlex Auvolat2022-08-291-1/+1
| | | |/ | | |/|
| | * | Merge branch 'main' into lx-perf-improvementsAlex Auvolat2022-08-2913-85/+118
| | |\ \ | | |/ / | |/| / | | |/
| * | Add some documentation for CaddyQuentin Dufour2022-08-121-0/+22
| | |
| * | Configure structopt to report the right versionv0.7.2_ci-test-2bug/reported-versionQuentin Dufour2022-08-1112-90/+97
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 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.
| * | drone: set TARGET env as needed by "to_s3" funcQuentin Dufour2022-08-031-1/+5
| | |
| | * fix clippyAlex Auvolat2022-07-291-6/+1
| | |
| | * Faster chunkerAlex Auvolat2022-07-291-10/+32
| | |
| | * Update cargo.nixAlex Auvolat2022-07-291-29/+7
| | |
| | * cargo fmtAlex Auvolat2022-07-291-1/+1
| | |
| | * Fix testsAlex Auvolat2022-07-293-22/+5
| | |
| | * More make clippy happyAlex Auvolat2022-07-291-2/+0
| | |
| | * Make clippy happyAlex Auvolat2022-07-291-0/+6
| | |
| | * Update cargo.nixAlex Auvolat2022-07-291-14/+104
| | |
| | * 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-2911-51/+188
| |/
| * Migrate to nix-daemon buildersci/bump-nix-imgQuentin Dufour2022-07-291-194/+13
| |
| * Run clippy in nix, leveraging nix caching abilityQuentin Dufour2022-07-266-74/+148
| |
| * Refactor default.nix to follow Nix Flakes patternsQuentin Dufour2022-07-264-189/+201
| |
| * Bump Nix image to 22.05Quentin Dufour2022-07-262-45/+40
| |
| * Fix: compile aarch64+armv6 as static binariesQuentin Dufour2022-07-261-27/+29
| |
| * Put log-lines in nix.confQuentin Dufour2022-07-262-1/+2
| |
| * Fail if compiled binary is dynamicQuentin Dufour2022-07-263-65/+98
| |
| * Uniformize tracing::* imports (hopefully fixes 32-bit build)fix-32bit-buildAlex Auvolat2022-07-154-4/+3
| |
| * Background task manager (#332)Alex2022-07-0827-737/+2049
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | - [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>