OP#176 edit Dockerfile and start.sh

This commit is contained in:
2025-12-02 15:46:23 +01:00
parent f2e0012683
commit ff896ae842
2 changed files with 46 additions and 39 deletions

View File

@@ -6,33 +6,37 @@ RUN apk add --no-cache git make gcc musl-dev
WORKDIR /src
COPY . .
# Fix missing go.sum entries
RUN go mod tidy
# Build (default target = all)
RUN make
# Verify binary exists and is executable — no --version check
# Verify binary
RUN ls -la postgresql-prometheus-adapter && \
./postgresql-prometheus-adapter --help > /dev/null
# ───── Stage 2: Runtime (Alpine = has glibc + loader) ─────
# ───── Stage 2: Runtime (Alpine for glibc/loader) ─────
FROM alpine:3.20
# Install only what the binary needs (tiny)
RUN apk add --no-cache libc6-compat
RUN apk add --no-cache libc6-compat bash # bash for start.sh, libc for binary
# Copy binary
COPY --from=builder /src/postgresql-prometheus-adapter /usr/local/bin/postgresql-prometheus-adapter
# Make sure it's executable (just in case)
RUN chmod +x /usr/local/bin/postgresql-prometheus-adapter
USER 1001:1001
# Copy and make start.sh executable
COPY start.sh /usr/local/bin/start.sh
RUN chmod +x /usr/local/bin/start.sh
# Non-root user
RUN addgroup -g 1001 -S appgroup && \
adduser -S -D -H -u 1001 -h /home/app -s /bin/bash -G appgroup -g appuser appuser
USER appuser
WORKDIR /home/app
EXPOSE 9201
HEALTHCHECK --interval=30s --timeout=3s --start-period=5s --retries=3 \
CMD ["wget", "--spider", "-q", "http://127.0.0.1:9201/health"] || exit 1
CMD wget --no-verbose --tries=1 --spider http://localhost:9201/health || exit 1
ENTRYPOINT ["/usr/local/bin/postgresql-prometheus-adapter"]
ENTRYPOINT ["/usr/local/bin/start.sh"]

View File

@@ -1,6 +1,8 @@
#!/bin/bash
if [[ "${DATABASE_URL}" == "" ]]; then
set -e
if [[ "${DATABASE_URL}" = "" ]]; then
echo 'Missing DATABASE_URL'
echo 'example -e DATABASE_URL="user=<db user> password=<db user password> host=<db host> port=<db port> database=<db name>"'
exit 1
@@ -12,18 +14,18 @@ function shutdown() {
pkill -SIGINT postgresql-prometheus-adapter
}
adapter_send_timeout=${adapter_send_timeout:-'30s'}
adapter_send_timeout="${adapter_send_timeout:-'30s'}"
web_listen_address="${web_listen_address:-':9201'}"
web_telemetry_path="${web_telemetry_path:-'/metrics'}"
log_level="${log_level:-'info'}"
log_format="${log_format:-'logfmt'}"
pg_partition="${pg_partition:-'hourly'}"
pg_commit_secs=${pg_commit_secs:-30}
pg_commit_rows=${pg_commit_rows:-20000}
pg_commit_secs="${pg_commit_secs:-30}"
pg_commit_rows="${pg_commit_rows:-20000}"
pg_threads="${pg_threads:-1}"
parser_threads="${parser_threads:-5}"
echo /postgresql-prometheus-adapter \
echo "/usr/local/bin/postgresql-prometheus-adapter \
--adapter-send-timeout=${adapter_send_timeout} \
--web-listen-address=${web_listen_address} \
--web-telemetry-path=${web_telemetry_path} \
@@ -33,17 +35,18 @@ echo /postgresql-prometheus-adapter \
--pg-commit-secs=${pg_commit_secs} \
--pg-commit-rows=${pg_commit_rows} \
--pg-threads=${pg_threads} \
--parser-threads=${parser_threads}
/postgresql-prometheus-adapter \
--adapter-send-timeout=${adapter_send_timeout} \
--web-listen-address=${web_listen_address} \
--web-telemetry-path=${web_telemetry_path} \
--log.level=${log_level} \
--log.format=${log_format} \
--pg-partition=${pg_partition} \
--pg-commit-secs=${pg_commit_secs} \
--pg-commit-rows=${pg_commit_rows} \
--pg-threads=${pg_threads} \
--parser-threads=${parser_threads}
--parser-threads=${parser_threads} \
--database-url=${DATABASE_URL}"
/usr/local/bin/postgresql-prometheus-adapter \
--adapter-send-timeout="${adapter_send_timeout}" \
--web-listen-address="${web_listen_address}" \
--web-telemetry-path="${web_telemetry_path}" \
--log.level="${log_level}" \
--log.format="${log_format}" \
--pg-partition="${pg_partition}" \
--pg-commit-secs="${pg_commit_secs}" \
--pg-commit-rows="${pg_commit_rows}" \
--pg-threads="${pg_threads}" \
--parser-threads="${parser_threads}" \
--database-url="${DATABASE_URL}"