From aa3505a9e4523c2a8bec5ca6368b3bc2068185ef Mon Sep 17 00:00:00 2001 From: Tamara Schmitz <15906939+tamara-schmitz@users.noreply.github.com> Date: Sun, 4 Dec 2022 12:35:03 +0100 Subject: [PATCH] Add missing optional dependencies to Container Image (#12914) --- Dockerfile | 68 +++++++++++++++++++++++++++++++++--------------------- 1 file changed, 42 insertions(+), 26 deletions(-) diff --git a/Dockerfile b/Dockerfile index 1def5407a..3a1db6f83 100644 --- a/Dockerfile +++ b/Dockerfile @@ -3,23 +3,37 @@ FROM $DOCKER_IMAGE AS builder ENV MINETEST_GAME_VERSION master ENV IRRLICHT_VERSION master +ENV SPATIALINDEX_VERSION 1.9.3 +ENV LUAJIT_VERSION v2.1 -RUN apk add --no-cache git build-base cmake sqlite-dev curl-dev zlib-dev zstd-dev \ - gmp-dev jsoncpp-dev postgresql-dev ninja luajit-dev ca-certificates +RUN apk add --no-cache git build-base cmake curl-dev zlib-dev zstd-dev \ + sqlite-dev postgresql-dev hiredis-dev leveldb-dev \ + gmp-dev jsoncpp-dev ninja ca-certificates WORKDIR /usr/src/ RUN git clone --recursive https://github.com/jupp0r/prometheus-cpp/ && \ - cd prometheus-cpp && \ - cmake -B build \ - -DCMAKE_INSTALL_PREFIX=/usr/local \ - -DCMAKE_BUILD_TYPE=Release \ - -DENABLE_TESTING=0 \ - -GNinja && \ - cmake --build build && \ - cmake --install build - -RUN git clone --depth=1 https://github.com/minetest/irrlicht/ -b ${IRRLICHT_VERSION} && \ - cp -r irrlicht/include /usr/include/irrlichtmt + cd prometheus-cpp && \ + cmake -B build \ + -DCMAKE_INSTALL_PREFIX=/usr/local \ + -DCMAKE_BUILD_TYPE=Release \ + -DENABLE_TESTING=0 \ + -GNinja && \ + cmake --build build && \ + cmake --install build && \ + cd /usr/src/ && \ + git clone --recursive https://github.com/libspatialindex/libspatialindex -b ${SPATIALINDEX_VERSION} && \ + cd libspatialindex && \ + cmake -B build \ + -DCMAKE_INSTALL_PREFIX=/usr/local && \ + cmake --build build && \ + cmake --install build && \ + cd /usr/src/ && \ + git clone --recursive https://luajit.org/git/luajit.git -b ${LUAJIT_VERSION} && \ + cd luajit && \ + make && make install && \ + cd /usr/src/ && \ + git clone --depth=1 https://github.com/minetest/irrlicht/ -b ${IRRLICHT_VERSION} && \ + cp -r irrlicht/include /usr/include/irrlichtmt COPY .git /usr/src/minetest/.git COPY CMakeLists.txt /usr/src/minetest/CMakeLists.txt @@ -37,22 +51,23 @@ COPY textures /usr/src/minetest/textures WORKDIR /usr/src/minetest RUN git clone --depth=1 -b ${MINETEST_GAME_VERSION} https://github.com/minetest/minetest_game.git ./games/minetest_game && \ - rm -fr ./games/minetest_game/.git && \ - cmake -B build \ - -DCMAKE_INSTALL_PREFIX=/usr/local \ - -DCMAKE_BUILD_TYPE=Release \ - -DBUILD_SERVER=TRUE \ - -DENABLE_PROMETHEUS=TRUE \ - -DBUILD_UNITTESTS=FALSE \ - -DBUILD_CLIENT=FALSE \ - -GNinja && \ - cmake --build build && \ - cmake --install build + rm -fr ./games/minetest_game/.git && \ + cmake -B build \ + -DCMAKE_INSTALL_PREFIX=/usr/local \ + -DCMAKE_BUILD_TYPE=Release \ + -DBUILD_SERVER=TRUE \ + -DENABLE_PROMETHEUS=TRUE \ + -DBUILD_UNITTESTS=FALSE \ + -DBUILD_CLIENT=FALSE \ + -GNinja && \ + cmake --build build && \ + cmake --install build ARG DOCKER_IMAGE=alpine:3.16 FROM $DOCKER_IMAGE AS runtime -RUN apk add --no-cache sqlite-libs curl gmp libstdc++ libgcc libpq luajit jsoncpp zstd-libs && \ +RUN apk add --no-cache curl gmp libstdc++ libgcc libpq jsoncpp zstd-libs \ + sqlite-libs postgresql hiredis leveldb && \ adduser -D minetest --uid 30000 -h /var/lib/minetest && \ chown -R minetest:minetest /var/lib/minetest @@ -61,7 +76,8 @@ WORKDIR /var/lib/minetest COPY --from=builder /usr/local/share/minetest /usr/local/share/minetest COPY --from=builder /usr/local/bin/minetestserver /usr/local/bin/minetestserver COPY --from=builder /usr/local/share/doc/minetest/minetest.conf.example /etc/minetest/minetest.conf - +COPY --from=builder /usr/local/lib/libspatialindex* /usr/local/lib/ +COPY --from=builder /usr/local/lib/libluajit* /usr/local/lib/ USER minetest:minetest EXPOSE 30000/udp 30000/tcp