forked from h2non/imaginary
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathDockerfile
124 lines (107 loc) · 3.03 KB
/
Dockerfile
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
ARG GOLANG_VERSION=1.24
FROM golang:${GOLANG_VERSION}-bookworm AS builder
ARG IMAGINARY_VERSION=dev
ARG GOLANGCILINT_VERSION=1.64.7
# Installs libvips + required libraries
RUN DEBIAN_FRONTEND=noninteractive \
apt-get update && \
apt-get dist-upgrade -y && \
apt-get install --no-install-recommends -y \
automake \
build-essential \
ca-certificates \
curl \
gobject-introspection \
gtk-doc-tools \
libcfitsio-dev \
libexif-dev \
libfftw3-dev \
libgif-dev \
libglib2.0-dev \
libgsf-1-dev \
libheif-dev \
libimagequant-dev \
libjpeg62-turbo-dev \
libmagickwand-dev \
libmatio-dev \
libopenslide-dev \
liborc-0.4-dev \
libpango1.0-dev \
libpng-dev \
libpoppler-glib-dev \
librsvg2-dev \
libtiff-dev \
libvips-dev \
libwebp-dev \
libxml2-dev \
swig
WORKDIR ${GOPATH}/src/github.com/sycured/imaginary
# Cache go modules
ENV GO111MODULE=on
COPY go.mod .
COPY go.sum .
RUN go mod download
# Copy imaginary sources
COPY . .
# Compile imaginary
RUN go build -a \
-o ${GOPATH}/bin/imaginary \
-ldflags="-s -w -h -X main.Version=${IMAGINARY_VERSION}" \
-trimpath \
github.com/sycured/imaginary
FROM debian:bookworm-slim@sha256:b1211f6d19afd012477bd34fdcabb6b663d680e0f4b0537da6e6b0fd057a3ec3
ARG IMAGINARY_VERSION
LABEL maintainer="[email protected]" \
org.label-schema.description="Fast, simple, scalable HTTP microservice for high-level image processing with first-class Docker support" \
org.label-schema.schema-version="1.0" \
org.label-schema.url="https://github.com/sycured/imaginary" \
org.label-schema.vcs-url="https://github.com/sycured/imaginary" \
org.label-schema.version="${IMAGINARY_VERSION}"
COPY --from=builder /usr/local/lib /usr/local/lib
COPY --from=builder /go/bin/imaginary /usr/local/bin/imaginary
COPY --from=builder /etc/ssl/certs /etc/ssl/certs
# Install runtime dependencies
RUN DEBIAN_FRONTEND=noninteractive \
apt-get update && \
apt-get dist-upgrade -y && \
apt-get install --no-install-recommends -y \
libcfitsio10 \
libexif12 \
libfftw3-bin \
libgif7 \
libglib2.0-0 \
libgsf-1-114 \
libheif1 \
libimagequant0 \
libjemalloc2 \
libjpeg62-turbo \
libmagickwand-6.q16-6 \
libmatio11 \
libopenexr-3-1-30 \
libopenslide0 \
liborc-0.4-0 \
libpango1.0-0 \
libpng16-16 \
libpoppler-glib8 \
librsvg2-2 \
libtiff6 \
libvips42 \
libwebp7 \
libwebpdemux2 \
libwebpmux3 \
libxml2 \
procps && \
ln -s /usr/lib/$(uname -m)-linux-gnu/libjemalloc.so.2 /usr/local/lib/libjemalloc.so && \
apt-get autoremove -y && \
apt-get autoclean && \
apt-get clean && \
rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
ENV LD_PRELOAD=/usr/local/lib/libjemalloc.so
# Server port to listen
ENV PORT=9000
# Drop privileges for non-UID mapped environments
USER nobody
# Run the entrypoint command by default when the container starts.
ENTRYPOINT ["/usr/local/bin/imaginary"]
# Expose the server TCP port
EXPOSE ${PORT}