ae76eaa761
With nar-bridge supporting zstd content-encoding, we don't need the nginx zstd module and can re-enable http2. We also need to propagate the Accept-Encoding sent by the client to nar-bridge, so it actually knows it can send zstd. This reduces the time measured in the microbenchmark from ~13s to this: ``` hyperfine 'rm -rf /tmp/cache; nix copy --from https://nixos.tvix.store/ --to "file:///tmp/cache?compression=none" /nix/store/jlkypcf54nrh4n6r0l62ryx93z752hb2-firefox-132.0' Benchmark 1: rm -rf /tmp/cache; nix copy --from https://nixos.tvix.store/ --to "file:///tmp/cache?compression=none" /nix/store/jlkypcf54nrh4n6r0l62ryx93z752hb2-firefox-132.0 Time (mean ± σ): 4.880 s ± 0.207 s [User: 4.661 s, System: 2.377 s] Range (min … max): 4.700 s … 5.274 s 10 runs ``` Change-Id: Id092307423636163ae95ef87ec8fa558b83ce0bb Reviewed-on: https://cl.tvl.fyi/c/depot/+/12835 Reviewed-by: Jörg Thalheim <joerg@thalheim.io> Autosubmit: flokli <flokli@flokli.de> Tested-by: BuildkiteCI Reviewed-by: Ilan Joselevich <personal@ilanjoselevich.com>
126 lines
3.4 KiB
Nix
126 lines
3.4 KiB
Nix
{ config, depot, pkgs, ... }:
|
|
{
|
|
imports = [ ./nar-bridge-module.nix ];
|
|
|
|
# Microbenchmark
|
|
# hyperfine --warmup 1 'rm -rf /tmp/cache; nix copy --from https://nixos.tvix.store/ --to "file:///tmp/cache?compression=none" /nix/store/jlkypcf54nrh4n6r0l62ryx93z752hb2-firefox-132.0'
|
|
services.nginx = {
|
|
package = pkgs.nginxStable;
|
|
virtualHosts.${config.machine.domain} = {
|
|
locations."=/" = {
|
|
tryFiles = "$uri $uri/index.html =404";
|
|
root = pkgs.runCommand "index"
|
|
{
|
|
nativeBuildInputs = [ depot.tools.cheddar ];
|
|
} ''
|
|
mkdir -p $out
|
|
cheddar README.md < ${./README.md} > $out/index.html
|
|
find $out
|
|
'';
|
|
};
|
|
locations."/" = {
|
|
proxyPass = "http://unix:/run/nar-bridge.sock:/";
|
|
extraConfig = ''
|
|
# Restrict allowed HTTP methods
|
|
limit_except GET HEAD {
|
|
# nar bridge allows to upload nars via PUT
|
|
deny all;
|
|
}
|
|
|
|
# Propagate content-encoding to the backend
|
|
proxy_set_header Accept-Encoding $http_accept_encoding;
|
|
|
|
# Enable proxy cache
|
|
proxy_cache nar-bridge;
|
|
proxy_cache_key "$scheme$proxy_host$request_uri";
|
|
proxy_cache_valid 200 301 302 10m; # Cache responses for 10 minutes
|
|
proxy_cache_valid 404 1m; # Cache 404 responses for 1 minute
|
|
proxy_cache_min_uses 2; # Cache only if the object is requested at least twice
|
|
proxy_cache_use_stale error timeout updating;
|
|
'';
|
|
};
|
|
};
|
|
|
|
# use more cores for compression
|
|
appendConfig = ''
|
|
worker_processes auto;
|
|
'';
|
|
|
|
proxyCachePath."nar-bridge" = {
|
|
enable = true;
|
|
levels = "1:2";
|
|
keysZoneName = "nar-bridge";
|
|
# Put our 1TB NVME to good use
|
|
maxSize = "200G";
|
|
inactive = "10d";
|
|
useTempPath = false;
|
|
};
|
|
};
|
|
|
|
services.nar-bridge = {
|
|
enable = true;
|
|
|
|
settings = {
|
|
blobservices = {
|
|
root = {
|
|
type = "objectstore";
|
|
object_store_url = "file:///var/lib/nar-bridge/blobs.object_store";
|
|
object_store_options = { };
|
|
};
|
|
};
|
|
|
|
directoryservices = {
|
|
root = {
|
|
type = "redb";
|
|
is_temporary = false;
|
|
path = "/var/lib/nar-bridge/directories.redb";
|
|
};
|
|
};
|
|
|
|
pathinfoservices = {
|
|
root = {
|
|
type = "cache";
|
|
near = "redb";
|
|
far = "cache-nixos-org";
|
|
};
|
|
|
|
redb = {
|
|
type = "redb";
|
|
is_temporary = false;
|
|
path = "/var/lib/nar-bridge/pathinfo.redb";
|
|
};
|
|
|
|
"cache-nixos-org" = {
|
|
type = "nix";
|
|
base_url = "https://cache.nixos.org";
|
|
blob_service = "root";
|
|
directory_service = "root";
|
|
public_keys = [
|
|
"cache.nixos.org-1:6NCHdD59X431o0gWypbMrAURkbJ16ZPMQFGspcDShjY="
|
|
];
|
|
};
|
|
};
|
|
};
|
|
};
|
|
|
|
systemd.tmpfiles.rules = [
|
|
# Put the data in the big disk
|
|
"d /tank/nar-bridge 0755 nar-bridge nar-bridge -"
|
|
# Cache responses on NVME
|
|
"d /var/cache/nginx 0755 ${config.services.nginx.user} ${config.services.nginx.group} -"
|
|
];
|
|
|
|
fileSystems."/var/lib/nar-bridge" = {
|
|
device = "/tank/nar-bridge";
|
|
options = [
|
|
"bind"
|
|
"nofail"
|
|
];
|
|
};
|
|
|
|
systemd.services.nar-bridge = {
|
|
unitConfig.RequiresMountsFor = "/var/lib/nar-bridge";
|
|
# twice the normal allowed limit, same as nix-daemon
|
|
serviceConfig.LimitNOFILE = "1048576";
|
|
};
|
|
}
|