Files
icecast-ripper/Dockerfile
Dmitrii Andreev f64163d12a Rework with go
2025-04-07 11:15:05 +03:00

47 lines
1.4 KiB
Docker

# Stage 1: Build the application
FROM golang:1.22-alpine AS builder
WORKDIR /app
# Copy go mod and sum files
COPY go.mod go.sum ./
# Download dependencies
RUN go mod download
# Copy the source code
COPY . .
# Build the application
# CGO_ENABLED=0 is important for static linking, especially with sqlite and alpine
# -ldflags="-w -s" strips debug information, reducing binary size
RUN CGO_ENABLED=0 go build -ldflags="-w -s" -o /icecast-ripper ./cmd/icecast-ripper/main.go
# Stage 2: Create the final lightweight image
FROM alpine:latest
WORKDIR /app
# Copy the binary from the builder stage
COPY --from=builder /icecast-ripper /app/icecast-ripper
# Create directories for recordings, temp files, and database if needed inside the container
# These should ideally be mounted as volumes in production
RUN mkdir -p /app/recordings /app/temp
# Expose the server port (if different from default, adjust accordingly)
EXPOSE 8080
# Set default environment variables (can be overridden)
ENV DATABASE_PATH=/app/icecast-ripper.db
ENV RECORDINGS_PATH=/app/recordings
ENV TEMP_PATH=/app/temp
ENV SERVER_ADDRESS=:8080
ENV LOG_LEVEL=info
# ENV STREAM_URL= # Required: Must be set at runtime
# ENV CHECK_INTERVAL=1m # Optional: Defaults to 1m
# ENV RSS_FEED_URL= # Optional: Defaults to http://<container_ip>:8080/rss
# Command to run the application
ENTRYPOINT ["/app/icecast-ripper"]