-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathDockerfile
More file actions
30 lines (28 loc) · 1.44 KB
/
Copy pathDockerfile
File metadata and controls
30 lines (28 loc) · 1.44 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
# syntax=docker/dockerfile:1
# Bookworm build + runtime for the mina-verify binaries.
FROM rust:bookworm AS builder
# rust:bookworm ships rustup; rust-toolchain.toml pins the exact toolchain (1.94.1).
RUN apt-get update && apt-get install -y --no-install-recommends \
build-essential pkg-config libssl-dev git ca-certificates \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /src
COPY . .
RUN cargo build --release --locked
RUN strip \
target/release/mina-verify \
target/release/mina-verify-capture \
target/release/mina-verify-monitor \
target/release/mina-verify-server
FROM debian:bookworm-slim
RUN apt-get update && apt-get install -y --no-install-recommends \
ca-certificates libssl3 curl \
&& rm -rf /var/lib/apt/lists/*
# curl: for the verify-server container healthcheck (GET /health)
COPY --from=builder /src/target/release/mina-verify /usr/local/bin/mina-verify
COPY --from=builder /src/target/release/mina-verify-capture /usr/local/bin/mina-verify-capture
COPY --from=builder /src/target/release/mina-verify-monitor /usr/local/bin/mina-verify-monitor
COPY --from=builder /src/target/release/mina-verify-server /usr/local/bin/mina-verify-server
# default: the live verify-before-ingest monitor (MINA_NETWORK env selects the network)
# Run the verify HTTP sidecar instead with:
# docker run -e MINA_NETWORK=devnet -p 8090:8090 --entrypoint mina-verify-server <image>
ENTRYPOINT ["mina-verify-monitor"]