## Summary - Add `containers/alloy/` with dual Dockerfile + Nix build files for Grafana Alloy v1.14.0 - Both builds fetch source from forge mirror (`forge.ops.eblu.me/mirrors/alloy.git`), build the web UI (Node), then compile the Go binary with `netgo embedalloyui` tags - Update all three alloy deployments (alloy-k8s, alloy-ringtail, alloy-tracing-ringtail) to use `registry.ops.eblu.me/blumeops/alloy` - `promtail_journal_enabled` tag omitted — requires systemd headers and none of our configs use `loki.source.journal` ## Build verification - **Dockerfile:** Tested locally via `docker build`, binary reports `v1.14.0` with correct tags - **Nix:** Tested on ringtail via `nix-build`, all three hashes (fetchgit, npmDeps, goModules) resolved and build succeeds ## Post-merge steps 1. Wait for CI to build the container from main (both Dockerfile and Nix workflows) 2. `mise run container-list alloy` to find the `[main]` tagged image 3. C0 follow-up to update `newTag` in all three kustomizations from `v1.14.0-placeholder` to the real tag 4. Sync ArgoCD apps and verify pods come up healthy Reviewed-on: #300
65 lines
1.9 KiB
Docker
65 lines
1.9 KiB
Docker
# Grafana Alloy telemetry collector
|
|
# Three-stage build: Web UI (Node), server (Go), runtime (Alpine)
|
|
|
|
ARG CONTAINER_APP_VERSION=1.14.0
|
|
ARG ALLOY_VERSION=v${CONTAINER_APP_VERSION}
|
|
ARG ALLOY_COMMIT=626a738319812d58ebc25ca6d71651f4925b8b18
|
|
|
|
FROM node:22-alpine AS ui-build
|
|
|
|
ARG ALLOY_COMMIT
|
|
RUN apk add --no-cache git
|
|
|
|
RUN mkdir /app && cd /app \
|
|
&& git init \
|
|
&& git remote add origin https://forge.ops.eblu.me/mirrors/alloy.git \
|
|
&& git fetch --depth 1 origin ${ALLOY_COMMIT} \
|
|
&& git checkout FETCH_HEAD
|
|
|
|
WORKDIR /app/internal/web/ui
|
|
RUN npm ci
|
|
RUN npx tsc -b && npx vite build
|
|
|
|
FROM golang:1.25-alpine3.22 AS build
|
|
|
|
ARG ALLOY_VERSION
|
|
ARG ALLOY_COMMIT
|
|
RUN apk add --no-cache build-base git
|
|
|
|
RUN mkdir /app && cd /app \
|
|
&& git init \
|
|
&& git remote add origin https://forge.ops.eblu.me/mirrors/alloy.git \
|
|
&& git fetch --depth 1 origin ${ALLOY_COMMIT} \
|
|
&& git checkout FETCH_HEAD
|
|
|
|
WORKDIR /app
|
|
|
|
# Copy pre-built web UI assets
|
|
COPY --from=ui-build /app/internal/web/ui/dist /app/internal/web/ui/dist
|
|
|
|
ENV CGO_ENABLED=1
|
|
|
|
# promtail_journal_enabled omitted: requires systemd headers (libsystemd-dev)
|
|
# and our k8s deployments read pod logs from the filesystem, not journald
|
|
RUN RELEASE_BUILD=1 VERSION=${ALLOY_VERSION} \
|
|
GO_TAGS="netgo embedalloyui" \
|
|
SKIP_UI_BUILD=1 \
|
|
make alloy
|
|
|
|
FROM alpine:3.22
|
|
|
|
LABEL org.opencontainers.image.title=alloy
|
|
LABEL org.opencontainers.image.description="Grafana Alloy is an OpenTelemetry Collector distribution"
|
|
LABEL org.opencontainers.image.source=https://github.com/grafana/alloy
|
|
|
|
RUN apk --no-cache add ca-certificates tzdata \
|
|
&& addgroup -g 473 alloy \
|
|
&& adduser -D -u 473 -G alloy alloy \
|
|
&& mkdir -p /var/lib/alloy/data \
|
|
&& chown -R alloy:alloy /var/lib/alloy
|
|
|
|
COPY --from=build --chown=473:473 /app/build/alloy /bin/alloy
|
|
|
|
ENTRYPOINT ["/bin/alloy"]
|
|
ENV ALLOY_DEPLOY_MODE=docker
|
|
CMD ["run", "/etc/alloy/config.alloy", "--storage.path=/var/lib/alloy/data"]
|