aboutsummaryrefslogtreecommitdiff
Commit message (Collapse)AuthorAgeFilesLines
...
| | * | | | | | 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>
* Fix typoAlex2022-06-291-1/+1
|