From 3ef250c30abf62e64472d5396ed555935ecab34a Mon Sep 17 00:00:00 2001 From: Thearas Date: Wed, 26 Jan 2022 18:17:10 +0800 Subject: [PATCH 1/2] fix: docker image failed to boot on arm64 node --- Dockerfile | 1 + 1 file changed, 1 insertion(+) diff --git a/Dockerfile b/Dockerfile index 075dede67..44743c9aa 100644 --- a/Dockerfile +++ b/Dockerfile @@ -17,6 +17,7 @@ COPY meilisearch-http/Cargo.toml meilisearch-http/ COPY meilisearch-lib/Cargo.toml meilisearch-lib/ ENV RUSTFLAGS="-C target-feature=-crt-static" +ENV JEMALLOC_SYS_WITH_LG_PAGE 16 # Create dummy main.rs files for each workspace member to be able to compile all the dependencies RUN find . -type d -name "meilisearch-*" | xargs -I{} sh -c 'mkdir {}/src; echo "fn main() { }" > {}/src/main.rs;' From 48d107cc133a391707026a7c0a7cf09d7692384c Mon Sep 17 00:00:00 2001 From: Thearas Date: Sat, 26 Mar 2022 20:06:00 +0800 Subject: [PATCH 2/2] Simplify Dockerfile --- Dockerfile | 35 +++++++---------------------------- 1 file changed, 7 insertions(+), 28 deletions(-) diff --git a/Dockerfile b/Dockerfile index 44743c9aa..ee0d62ce4 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,43 +1,22 @@ # Compile -FROM alpine:3.14 AS compiler +FROM rust:alpine3.14 AS compiler -RUN apk update --quiet \ - && apk add -q --no-cache curl build-base - -RUN curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y +RUN apk add -q --update-cache --no-cache build-base openssl-dev WORKDIR /meilisearch -COPY Cargo.lock . -COPY Cargo.toml . - -COPY meilisearch-auth/Cargo.toml meilisearch-auth/ -COPY meilisearch-error/Cargo.toml meilisearch-error/ -COPY meilisearch-http/Cargo.toml meilisearch-http/ -COPY meilisearch-lib/Cargo.toml meilisearch-lib/ - -ENV RUSTFLAGS="-C target-feature=-crt-static" -ENV JEMALLOC_SYS_WITH_LG_PAGE 16 - -# Create dummy main.rs files for each workspace member to be able to compile all the dependencies -RUN find . -type d -name "meilisearch-*" | xargs -I{} sh -c 'mkdir {}/src; echo "fn main() { }" > {}/src/main.rs;' -# Use `cargo build` instead of `cargo vendor` because we need to not only download but compile dependencies too -RUN if [ "$TARGETPLATFORM" = "linux/arm64" ]; then \ - export JEMALLOC_SYS_WITH_LG_PAGE=16; \ - fi && \ - $HOME/.cargo/bin/cargo build --release -# Cleanup dummy main.rs files -RUN find . -path "*/src/main.rs" -delete - ARG COMMIT_SHA ARG COMMIT_DATE ENV COMMIT_SHA=${COMMIT_SHA} COMMIT_DATE=${COMMIT_DATE} +ENV RUSTFLAGS="-C target-feature=-crt-static" COPY . . -RUN if [ "$TARGETPLATFORM" = "linux/arm64" ]; then \ +RUN set -eux; \ + apkArch="$(apk --print-arch)"; \ + if [ "$apkArch" = "aarch64" ]; then \ export JEMALLOC_SYS_WITH_LG_PAGE=16; \ fi && \ - $HOME/.cargo/bin/cargo build --release + cargo build --release # Run FROM alpine:3.14