Add a patched nix with s3 cache deduplication
This commit is contained in:
parent
f3a40f58f4
commit
3c474d2a64
4 changed files with 65 additions and 1 deletions
1
.github/workflows/build.yml
vendored
1
.github/workflows/build.yml
vendored
|
@ -55,6 +55,7 @@ jobs:
|
||||||
- clean-s3-cache
|
- clean-s3-cache
|
||||||
- python-instagram
|
- python-instagram
|
||||||
- moa
|
- moa
|
||||||
|
- nix-s3-dedup
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- name: Checkout repository
|
- name: Checkout repository
|
||||||
|
|
|
@ -55,4 +55,5 @@
|
||||||
clean-s3-cache = pkgs.python3Packages.callPackage ./scripts/clean-s3-cache.nix {};
|
clean-s3-cache = pkgs.python3Packages.callPackage ./scripts/clean-s3-cache.nix {};
|
||||||
python-instagram = pkgs.python3Packages.callPackage ./python/instagram.nix {};
|
python-instagram = pkgs.python3Packages.callPackage ./python/instagram.nix {};
|
||||||
moa = pkgs.python3Packages.callPackage ./moa {};
|
moa = pkgs.python3Packages.callPackage ./moa {};
|
||||||
|
nix-s3-dedup = pkgs.callPackage ./nix {};
|
||||||
}
|
}
|
||||||
|
|
54
nix/dedupNixCache.patch
Normal file
54
nix/dedupNixCache.patch
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
diff --git a/src/libstore/s3-binary-cache-store.cc b/src/libstore/s3-binary-cache-store.cc
|
||||||
|
index 844553ad3..a7a9cd702 100644
|
||||||
|
--- a/src/libstore/s3-binary-cache-store.cc
|
||||||
|
+++ b/src/libstore/s3-binary-cache-store.cc
|
||||||
|
@@ -214,6 +214,14 @@ struct S3BinaryCacheStoreImpl : virtual S3BinaryCacheStoreConfig, public virtual
|
||||||
|
Stats stats;
|
||||||
|
|
||||||
|
S3Helper s3Helper;
|
||||||
|
+ ref<Store> mNixosCache;
|
||||||
|
+
|
||||||
|
+ BinaryCacheStore * nixosCache() {
|
||||||
|
+ auto * casted = dynamic_cast<BinaryCacheStore *>(&*this->mNixosCache);
|
||||||
|
+ if (!casted)
|
||||||
|
+ throw UsageError("cache.nixos.org is not a BinaryCacheStore");
|
||||||
|
+ return casted;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
S3BinaryCacheStoreImpl(
|
||||||
|
const std::string & uriScheme,
|
||||||
|
@@ -227,6 +235,7 @@ struct S3BinaryCacheStoreImpl : virtual S3BinaryCacheStoreConfig, public virtual
|
||||||
|
, S3BinaryCacheStore(params)
|
||||||
|
, bucketName(bucketName)
|
||||||
|
, s3Helper(profile, region, scheme, endpoint)
|
||||||
|
+ , mNixosCache(openStore("https://cache.nixos.org/"))
|
||||||
|
{
|
||||||
|
diskCache = getNarInfoDiskCache();
|
||||||
|
}
|
||||||
|
@@ -268,6 +277,8 @@ struct S3BinaryCacheStoreImpl : virtual S3BinaryCacheStoreConfig, public virtual
|
||||||
|
|
||||||
|
bool fileExists(const std::string & path) override
|
||||||
|
{
|
||||||
|
+ if(this->nixosCache()->fileExists(path))
|
||||||
|
+ return true;
|
||||||
|
stats.head++;
|
||||||
|
|
||||||
|
auto res = s3Helper.client->HeadObject(
|
||||||
|
@@ -389,6 +400,8 @@ struct S3BinaryCacheStoreImpl : virtual S3BinaryCacheStoreConfig, public virtual
|
||||||
|
std::shared_ptr<std::basic_iostream<char>> istream,
|
||||||
|
const std::string & mimeType) override
|
||||||
|
{
|
||||||
|
+ if(this->nixosCache()->fileExists(path))
|
||||||
|
+ return;
|
||||||
|
auto compress = [&](std::string compression)
|
||||||
|
{
|
||||||
|
auto compressed = nix::compress(compression, StreamToSourceAdapter(istream).drain());
|
||||||
|
@@ -407,6 +420,8 @@ struct S3BinaryCacheStoreImpl : virtual S3BinaryCacheStoreConfig, public virtual
|
||||||
|
|
||||||
|
void getFile(const std::string & path, Sink & sink) override
|
||||||
|
{
|
||||||
|
+ if(this->nixosCache()->fileExists(path))
|
||||||
|
+ return this->nixosCache()->getFile(path, sink);
|
||||||
|
stats.get++;
|
||||||
|
|
||||||
|
// FIXME: stream output to sink.
|
8
nix/default.nix
Normal file
8
nix/default.nix
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
{nix}:
|
||||||
|
nix.overrideAttrs (super: {
|
||||||
|
patches =
|
||||||
|
(super.patches or [])
|
||||||
|
++ [
|
||||||
|
./dedupNixCache.patch
|
||||||
|
];
|
||||||
|
})
|
Reference in a new issue