All checks were successful
Build Container / detect (push) Successful in 3s
Build Container / build-dockerfile (alloy) (push) Successful in 12s
Build Container / build-dockerfile (ntfy) (push) Successful in 11s
Build Container / build-nix (alloy) (push) Successful in 20s
Build Container / build-nix (authentik) (push) Successful in 6m10s
Build Container / build-nix (authentik-redis) (push) Successful in 20s
Build Container / build-nix (ntfy) (push) Successful in 6s
## Summary - Replace upstream `docker.io/library/redis:7-alpine` (Redis 7.4.8) with a nix-built container using Redis 8.2.3 from nixpkgs - Introduce **attached service pattern**: `parent` field in service-versions.yaml, `<parent>-<component>` naming convention, and `assert pkgs.redis.version == version` in default.nix to prevent silent version drift on `flake.lock` updates - Document the pattern in [[review-services]] so future attached services slot in cleanly - Backfill `parent: grafana` on existing `grafana-sidecar` entry ## Version drift protection 1. `flake.lock` update bumps nixpkgs redis → `assert` in `default.nix` breaks `nix-build` 2. Developer updates `version` in `default.nix` → prek's `container-version-check` demands matching `service-versions.yaml` update 3. Both must agree before commit succeeds ## Test plan - [ ] Build container from branch on ringtail (`mise run container-build-and-release authentik-redis`) - [ ] Update kustomization `newTag` to branch-built image tag - [ ] Sync authentik ArgoCD app from branch (`argocd app set authentik --revision localize-redis && argocd app sync authentik`) - [ ] Verify Authentik login, session persistence, and task queue still work - [ ] After merge: C0 follow-up to update `newTag` to the main-built image tag 🤖 Generated with [Claude Code](https://claude.com/claude-code) Reviewed-on: #309
138 lines
3.4 KiB
Nix
138 lines
3.4 KiB
Nix
# Nix-built Grafana Alloy telemetry collector
|
|
# Builds v1.14.0 from forge mirror with embedded web UI
|
|
# Uses stdenv + make (not buildGoModule) due to multi-module workspace
|
|
# with local replace directives (collector/ -> ../, ../syntax, ../extension)
|
|
# Built with dockerTools.buildLayeredImage for efficient layer caching
|
|
{ pkgs ? import <nixpkgs> { } }:
|
|
|
|
let
|
|
version = "1.14.0";
|
|
|
|
src = pkgs.fetchgit {
|
|
url = "https://forge.ops.eblu.me/mirrors/alloy.git";
|
|
rev = "v${version}";
|
|
hash = "sha256-gxNz4XDE8XSl6LsP3k8DERqDdMLcmbWKfXZGGyRULkg=";
|
|
};
|
|
|
|
ui = pkgs.buildNpmPackage {
|
|
inherit version;
|
|
pname = "alloy-ui";
|
|
src = "${src}/internal/web/ui";
|
|
npmDepsHash = "sha256-GT0yisPn+3FCtWL3he0i5zPMlaWNparQDefU69G4Yis=";
|
|
|
|
buildPhase = ''
|
|
runHook preBuild
|
|
npx tsc -b
|
|
npx vite build
|
|
runHook postBuild
|
|
'';
|
|
|
|
installPhase = ''
|
|
runHook preInstall
|
|
mkdir -p $out/dist
|
|
cp -r dist/* $out/dist/
|
|
runHook postInstall
|
|
'';
|
|
};
|
|
|
|
# Pre-fetch Go modules for all three go.mod files (fixed-output derivation)
|
|
goModules = pkgs.stdenv.mkDerivation {
|
|
pname = "alloy-go-modules";
|
|
inherit src version;
|
|
|
|
nativeBuildInputs = with pkgs; [ go git cacert ];
|
|
|
|
buildPhase = ''
|
|
export GOPATH=$TMPDIR/go
|
|
export GOFLAGS=-modcacherw
|
|
# Download modules for all three go.mod files
|
|
go mod download
|
|
cd syntax && go mod download && cd ..
|
|
cd collector && go mod download && cd ..
|
|
'';
|
|
|
|
installPhase = ''
|
|
cp -r $TMPDIR/go/pkg/mod $out
|
|
'';
|
|
|
|
outputHashMode = "recursive";
|
|
outputHash = "sha256-rD7zqomSVv4d8NaC7jXXgihuQvK8guaAN0KrsBRWMVQ=";
|
|
outputHashAlgo = "sha256";
|
|
};
|
|
|
|
alloy = pkgs.stdenv.mkDerivation {
|
|
inherit src version;
|
|
pname = "alloy";
|
|
|
|
nativeBuildInputs = with pkgs; [
|
|
go
|
|
git
|
|
gnumake
|
|
cacert
|
|
];
|
|
|
|
buildPhase = ''
|
|
runHook preBuild
|
|
|
|
export HOME=$TMPDIR
|
|
export GOPATH=$TMPDIR/go
|
|
export GOFLAGS=-modcacherw
|
|
|
|
# Populate module cache from pre-fetched modules
|
|
mkdir -p $GOPATH/pkg
|
|
cp -r ${goModules} $GOPATH/pkg/mod
|
|
chmod -R u+w $GOPATH/pkg/mod
|
|
|
|
# Copy pre-built web UI assets
|
|
cp -r ${ui}/dist/ internal/web/ui/dist
|
|
|
|
# Build using upstream Makefile
|
|
# promtail_journal_enabled omitted: requires systemd headers
|
|
# and our k8s deployments read pod logs from the filesystem, not journald
|
|
RELEASE_BUILD=1 \
|
|
VERSION=v${version} \
|
|
GO_TAGS="netgo embedalloyui" \
|
|
SKIP_UI_BUILD=1 \
|
|
make alloy
|
|
|
|
runHook postBuild
|
|
'';
|
|
|
|
installPhase = ''
|
|
runHook preInstall
|
|
mkdir -p $out/bin
|
|
cp build/alloy $out/bin/alloy
|
|
runHook postInstall
|
|
'';
|
|
|
|
meta = with pkgs.lib; {
|
|
description = "OpenTelemetry Collector distribution with programmable pipelines";
|
|
homepage = "https://grafana.com/docs/alloy/";
|
|
license = licenses.asl20;
|
|
mainProgram = "alloy";
|
|
};
|
|
};
|
|
in
|
|
|
|
pkgs.dockerTools.buildLayeredImage {
|
|
name = "blumeops/alloy";
|
|
contents = [
|
|
alloy
|
|
pkgs.cacert
|
|
pkgs.tzdata
|
|
];
|
|
|
|
config = {
|
|
Entrypoint = [ "${alloy}/bin/alloy" ];
|
|
Cmd = [ "run" "/etc/alloy/config.alloy" "--storage.path=/var/lib/alloy/data" ];
|
|
Env = [
|
|
"SSL_CERT_FILE=${pkgs.cacert}/etc/ssl/certs/ca-bundle.crt"
|
|
"TZDIR=${pkgs.tzdata}/share/zoneinfo"
|
|
"ALLOY_DEPLOY_MODE=docker"
|
|
];
|
|
ExposedPorts = {
|
|
"12345/tcp" = { };
|
|
};
|
|
User = "65534";
|
|
};
|
|
}
|