C1(valkey-mirror): add valkey container build
Native Dagger build of valkey 8.1.6-r0 on Alpine 3.22. Mirrors upstream docker.io/valkey/valkey:8.1-alpine for paperless and immich sidecars. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
parent
f84f5f02b3
commit
946fa75baa
3 changed files with 60 additions and 0 deletions
47
containers/valkey/container.py
Normal file
47
containers/valkey/container.py
Normal file
|
|
@ -0,0 +1,47 @@
|
||||||
|
"""Valkey — native Dagger build.
|
||||||
|
|
||||||
|
Alpine 3.22 base with the `valkey` apk package (8.1.x — Redis-compatible).
|
||||||
|
Mirrors `docker.io/valkey/valkey:8.1-alpine`, used by paperless and immich
|
||||||
|
as a cache/queue sidecar.
|
||||||
|
"""
|
||||||
|
|
||||||
|
import dagger
|
||||||
|
from dagger import dag
|
||||||
|
|
||||||
|
from blumeops.containers import oci_labels
|
||||||
|
|
||||||
|
# Alpine 3.22 ships valkey 8.1.6-r0. Alpine 3.23 jumps to 9.0 — hold on 3.22
|
||||||
|
# to keep this a 1:1 swap for the upstream `valkey:8.1-alpine` image.
|
||||||
|
VERSION = "8.1.6-r0"
|
||||||
|
|
||||||
|
ALPINE_BASE = "alpine:3.22"
|
||||||
|
|
||||||
|
|
||||||
|
async def build(src: dagger.Directory) -> dagger.Container:
|
||||||
|
ctr = (
|
||||||
|
dag.container()
|
||||||
|
.from_(ALPINE_BASE)
|
||||||
|
.with_exec(["apk", "add", "--no-cache", f"valkey={VERSION}"])
|
||||||
|
.with_exec(["mkdir", "-p", "/data"])
|
||||||
|
.with_exec(["chown", "valkey:valkey", "/data"])
|
||||||
|
.with_workdir("/data")
|
||||||
|
.with_exposed_port(6379)
|
||||||
|
.with_user("valkey")
|
||||||
|
.with_default_args(
|
||||||
|
args=[
|
||||||
|
"valkey-server",
|
||||||
|
"--bind",
|
||||||
|
"0.0.0.0",
|
||||||
|
"--protected-mode",
|
||||||
|
"no",
|
||||||
|
"--dir",
|
||||||
|
"/data",
|
||||||
|
]
|
||||||
|
)
|
||||||
|
)
|
||||||
|
return oci_labels(
|
||||||
|
ctr,
|
||||||
|
title="Valkey",
|
||||||
|
description="Valkey high-performance key/value datastore (Redis-compatible)",
|
||||||
|
version=VERSION,
|
||||||
|
)
|
||||||
1
docs/changelog.d/valkey-mirror.infra.md
Normal file
1
docs/changelog.d/valkey-mirror.infra.md
Normal file
|
|
@ -0,0 +1 @@
|
||||||
|
Mirror Valkey 8.1 locally as `registry.ops.eblu.me/blumeops/valkey`. Replaces direct pulls of `docker.io/valkey/valkey:8.1-alpine` for paperless and immich sidecars. Built via native Dagger pipeline on Alpine 3.22. Stateless swap — no data migration. Authentik's nix-built Redis remains separate.
|
||||||
|
|
@ -125,6 +125,18 @@ services:
|
||||||
upstream-source: https://github.com/immich-app/immich/releases
|
upstream-source: https://github.com/immich-app/immich/releases
|
||||||
notes: Kustomize manifests with upstream images
|
notes: Kustomize manifests with upstream images
|
||||||
|
|
||||||
|
- name: valkey
|
||||||
|
type: argocd
|
||||||
|
last-reviewed: 2026-05-01
|
||||||
|
current-version: "8.1.6-r0"
|
||||||
|
upstream-source: https://pkgs.alpinelinux.org/package/v3.22/community/aarch64/valkey
|
||||||
|
notes: >-
|
||||||
|
Shared Alpine-built valkey image, used as a sidecar/cache by paperless
|
||||||
|
(sidecar) and immich (separate Deployment). Mirrors the upstream
|
||||||
|
docker.io/valkey/valkey:8.1-alpine. Pinned to Alpine 3.22 for valkey 8.1.x;
|
||||||
|
Alpine 3.23 jumps to 9.0. Distinct from authentik-redis (nix-built Redis
|
||||||
|
8.x) which has its own entry.
|
||||||
|
|
||||||
- name: external-secrets
|
- name: external-secrets
|
||||||
type: argocd
|
type: argocd
|
||||||
last-reviewed: 2026-03-25
|
last-reviewed: 2026-03-25
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue