mirror of
https://github.com/tursodatabase/libsql.git
synced 2025-01-19 03:01:50 +00:00
96 lines
3.4 KiB
Docker
96 lines
3.4 KiB
Docker
# build sqld
|
|
FROM rust:slim-bullseye AS chef
|
|
RUN apt update \
|
|
&& apt install -y libclang-dev clang \
|
|
build-essential tcl protobuf-compiler file \
|
|
libssl-dev pkg-config git cmake \
|
|
&& apt clean \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# We need to install and set as default the toolchain specified in rust-toolchain.toml
|
|
# Otherwise cargo-chef will build dependencies using wrong toolchain
|
|
# This also prevents planner and builder steps from installing the toolchain over and over again
|
|
COPY rust-toolchain.toml rust-toolchain.toml
|
|
RUN cat rust-toolchain.toml | grep "channel" | awk '{print $3}' | sed 's/\"//g' > toolchain.txt \
|
|
&& rustup update $(cat toolchain.txt) \
|
|
&& rustup default $(cat toolchain.txt) \
|
|
&& rm toolchain.txt rust-toolchain.toml \
|
|
&& cargo install cargo-chef
|
|
|
|
FROM chef AS planner
|
|
ARG BUILD_DEBUG=false
|
|
ENV CARGO_PROFILE_RELEASE_DEBUG=$BUILD_DEBUG
|
|
RUN echo $CARGO_PROFILE_RELEASE_DEBUG
|
|
COPY . .
|
|
RUN cargo chef prepare --recipe-path recipe.json
|
|
|
|
FROM chef AS builder
|
|
ARG BUILD_DEBUG=false
|
|
ENV CARGO_PROFILE_RELEASE_DEBUG=$BUILD_DEBUG
|
|
COPY --from=planner /recipe.json recipe.json
|
|
RUN cargo chef cook --release --recipe-path recipe.json
|
|
COPY . .
|
|
ARG ENABLE_FEATURES=""
|
|
RUN if [ "$ENABLE_FEATURES" == "" ]; then \
|
|
cargo build -p libsql-server --release ; \
|
|
else \
|
|
cargo build -p libsql-server --features "$ENABLE_FEATURES" --release ; \
|
|
fi
|
|
RUN cargo build -p bottomless-cli --release
|
|
|
|
# official gosu install instruction (https://github.com/tianon/gosu/blob/master/INSTALL.md)
|
|
FROM debian:bullseye-slim as gosu
|
|
ENV GOSU_VERSION 1.17
|
|
RUN set -eux; \
|
|
# save list of currently installed packages for later so we can clean up
|
|
savedAptMark="$(apt-mark showmanual)"; \
|
|
apt-get update; \
|
|
apt-get install -y --no-install-recommends ca-certificates gnupg wget; \
|
|
rm -rf /var/lib/apt/lists/*; \
|
|
\
|
|
dpkgArch="$(dpkg --print-architecture | awk -F- '{ print $NF }')"; \
|
|
wget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$dpkgArch"; \
|
|
wget -O /usr/local/bin/gosu.asc "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$dpkgArch.asc"; \
|
|
\
|
|
# verify the signature
|
|
export GNUPGHOME="$(mktemp -d)"; \
|
|
gpg --batch --keyserver hkps://keys.openpgp.org --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4; \
|
|
gpg --batch --verify /usr/local/bin/gosu.asc /usr/local/bin/gosu; \
|
|
gpgconf --kill all; \
|
|
rm -rf "$GNUPGHOME" /usr/local/bin/gosu.asc; \
|
|
\
|
|
# clean up fetch dependencies
|
|
apt-mark auto '.*' > /dev/null; \
|
|
[ -z "$savedAptMark" ] || apt-mark manual $savedAptMark; \
|
|
apt-get purge -y --auto-remove -o APT::AutoRemove::RecommendsImportant=false; \
|
|
\
|
|
chmod +x /usr/local/bin/gosu; \
|
|
# verify that the binary works
|
|
gosu --version; \
|
|
gosu nobody true
|
|
|
|
# runtime
|
|
FROM debian:bullseye-slim
|
|
RUN apt update
|
|
|
|
EXPOSE 5001 8080
|
|
VOLUME [ "/var/lib/sqld" ]
|
|
|
|
RUN groupadd --system --gid 666 sqld
|
|
RUN adduser --system --home /var/lib/sqld --uid 666 --gid 666 sqld
|
|
WORKDIR /var/lib/sqld
|
|
USER sqld
|
|
|
|
COPY docker-entrypoint.sh /usr/local/bin
|
|
COPY docker-wrapper.sh /usr/local/bin
|
|
|
|
COPY --from=gosu /usr/local/bin/gosu /usr/local/bin/gosu
|
|
COPY --from=builder /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/ca-certificates.crt
|
|
COPY --from=builder /target/release/sqld /bin/sqld
|
|
COPY --from=builder /target/release/bottomless-cli /bin/bottomless-cli
|
|
|
|
USER root
|
|
|
|
ENTRYPOINT ["/usr/local/bin/docker-wrapper.sh"]
|
|
CMD ["/bin/sqld"]
|