X-Git-Url: https://git.lizzy.rs/?a=blobdiff_plain;f=Dockerfile;h=3a1db6f8334b1befde171885fd7b8d63dee8f24c;hb=b8aaad4f1ef2e4b22cb7d47de9cb54068ccbbe18;hp=8843e4bbc87f0efb09d2879c5457a3e42c0605bf;hpb=ff3aa18436c54eb16c937774f8c9a20689fce5b3;p=minetest.git diff --git a/Dockerfile b/Dockerfile index 8843e4bbc..3a1db6f83 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,8 +1,39 @@ -ARG DOCKER_IMAGE=alpine:3.14 +ARG DOCKER_IMAGE=alpine:3.16 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 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 && \ + 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 @@ -19,45 +50,24 @@ COPY src /usr/src/minetest/src 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 -RUN apk add --no-cache git build-base cmake sqlite-dev curl-dev zlib-dev \ - gmp-dev jsoncpp-dev postgresql-dev ninja luajit-dev ca-certificates && \ - git clone --depth=1 -b ${MINETEST_GAME_VERSION} https://github.com/minetest/minetest_game.git ./games/minetest_game && \ - rm -fr ./games/minetest_game/.git - -WORKDIR /usr/src/ -RUN git clone --recursive https://github.com/jupp0r/prometheus-cpp/ && \ - mkdir prometheus-cpp/build && \ - cd prometheus-cpp/build && \ - cmake .. \ - -DCMAKE_INSTALL_PREFIX=/usr/local \ - -DCMAKE_BUILD_TYPE=Release \ - -DENABLE_TESTING=0 \ - -GNinja && \ - ninja && \ - ninja install - -RUN git clone --depth=1 https://github.com/minetest/irrlicht/ -b ${IRRLICHT_VERSION} && \ - cp -r irrlicht/include /usr/include/irrlichtmt - -WORKDIR /usr/src/minetest -RUN mkdir build && \ - cd build && \ - cmake .. \ - -DCMAKE_INSTALL_PREFIX=/usr/local \ - -DCMAKE_BUILD_TYPE=Release \ - -DBUILD_SERVER=TRUE \ - -DENABLE_PROMETHEUS=TRUE \ - -DBUILD_UNITTESTS=FALSE \ - -DBUILD_CLIENT=FALSE \ - -GNinja && \ - ninja && \ - ninja install - -ARG DOCKER_IMAGE=alpine:3.14 +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 && \ +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 @@ -66,9 +76,12 @@ 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 +VOLUME /var/lib/minetest/ /etc/minetest/ -CMD ["/usr/local/bin/minetestserver", "--config", "/etc/minetest/minetest.conf"] +ENTRYPOINT ["/usr/local/bin/minetestserver"] +CMD ["--config", "/etc/minetest/minetest.conf"]