1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- # Start from the latest alpine based golang base image
- FROM golang:alpine as builder
- # Install git
- RUN apk update && apk add --no-cache git
- # Add maintainer info
- LABEL maintainer="Matthias Ladkau <matthias@ladkau.de>"
- # Set the current working directory inside the container
- WORKDIR /app
- # Copy go mod and sum files
- COPY go.mod go.sum ./
- # Download all dependencies
- RUN go mod download
- # Copy the source from the current directory to the working directory inside the container
- COPY . .
- # Build eliasdb and link statically (no CGO)
- # Use ldflags -w -s to omit the symbol table, debug information and the DWARF table
- RUN CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -a -ldflags="-w -s" cli/eliasdb.go
- # Start again from scratch
- FROM scratch
- # Copy the eliasdb binary
- COPY --from=builder /app/eliasdb /eliasdb
- # Set the working directory to data so all created files (e.g. eliasdb.config.json)
- # can be mapped to physical files on disk
- WORKDIR /data
- # Run eliasdb binary
- ENTRYPOINT ["../eliasdb"]
- # To run the server as the current user, expose port 9090 and preserve
- # all runtime related files on disk in the local directory run:
- #
- # docker run --rm --user $(id -u):$(id -g) -v $PWD:/data -p 9090:9090 krotik/eliasdb server
- # To run the console as the current user and use the eliasdb.config.json in
- # the local directory run:
- # docker run --rm --network="host" -it -v $PWD:/data --user $(id -u):$(id -g) -v $PWD:/data krotik/eliasdb console
|