summaryrefslogtreecommitdiff
path: root/Dockerfile
diff options
context:
space:
mode:
authorkaniini <ariadne@dereferenced.org>2019-08-03 18:12:03 +0000
committerkaniini <ariadne@dereferenced.org>2019-08-03 18:12:03 +0000
commitba72d02f86d229ae83d4ca669e548b9968bdf8dd (patch)
treee2a1b26787c5f42fd7a318a2ff96527f90574ddd /Dockerfile
parente553a17e98394ecdd64908ab524a192f1b2390bf (diff)
parent4007717534f9cc880b808b91ba6be5801afb71a0 (diff)
downloadpleroma-ba72d02f86d229ae83d4ca669e548b9968bdf8dd.tar.gz
pleroma-ba72d02f86d229ae83d4ca669e548b9968bdf8dd.zip
Merge branch 'official-docker-support' into 'develop'
Add Dockerfile See merge request pleroma/pleroma!1523
Diffstat (limited to 'Dockerfile')
-rw-r--r--Dockerfile39
1 files changed, 39 insertions, 0 deletions
diff --git a/Dockerfile b/Dockerfile
new file mode 100644
index 000000000..268ec61dc
--- /dev/null
+++ b/Dockerfile
@@ -0,0 +1,39 @@
+FROM rinpatch/elixir:1.9.0-rc.0-alpine as build
+
+COPY . .
+
+ENV MIX_ENV=prod
+
+RUN apk add git gcc g++ musl-dev make &&\
+ echo "import Mix.Config" > config/prod.secret.exs &&\
+ mix local.hex --force &&\
+ mix local.rebar --force &&\
+ mix deps.get --only prod &&\
+ mkdir release &&\
+ mix release --path release
+
+FROM alpine:latest
+
+ARG HOME=/opt/pleroma
+ARG DATA=/var/lib/pleroma
+
+RUN echo "http://nl.alpinelinux.org/alpine/latest-stable/community" >> /etc/apk/repositories &&\
+ apk update &&\
+ apk add ncurses postgresql-client &&\
+ adduser --system --shell /bin/false --home ${HOME} pleroma &&\
+ mkdir -p ${DATA}/uploads &&\
+ mkdir -p ${DATA}/static &&\
+ chown -R pleroma ${DATA} &&\
+ mkdir -p /etc/pleroma &&\
+ chown -R pleroma /etc/pleroma
+
+USER pleroma
+
+COPY --from=build --chown=pleroma:0 /release ${HOME}
+
+COPY ./config/docker.exs /etc/pleroma/config.exs
+COPY ./docker-entrypoint.sh ${HOME}
+
+EXPOSE 4000
+
+ENTRYPOINT ["/opt/pleroma/docker-entrypoint.sh"]