mirror of
https://github.com/GreptimeTeam/greptimedb.git
synced 2026-01-09 14:52:58 +00:00
61 lines
2.5 KiB
Docker
61 lines
2.5 KiB
Docker
FROM ubuntu:20.04
|
||
|
||
# The root path under which contains all the dependencies to build this Dockerfile.
|
||
ARG DOCKER_BUILD_ROOT=.
|
||
|
||
ENV LANG en_US.utf8
|
||
WORKDIR /greptimedb
|
||
|
||
# Add PPA for Python 3.10.
|
||
RUN apt-get update && \
|
||
DEBIAN_FRONTEND=noninteractive apt-get install -y software-properties-common && \
|
||
add-apt-repository ppa:deadsnakes/ppa -y
|
||
|
||
# Install dependencies.
|
||
RUN apt-get update && DEBIAN_FRONTEND=noninteractive apt-get install -y \
|
||
libssl-dev \
|
||
tzdata \
|
||
protobuf-compiler \
|
||
curl \
|
||
ca-certificates \
|
||
git \
|
||
build-essential \
|
||
pkg-config \
|
||
python3.10 \
|
||
python3.10-dev
|
||
|
||
# Remove Python 3.8 and install pip.
|
||
RUN apt-get -y purge python3.8 && \
|
||
apt-get -y autoremove && \
|
||
ln -s /usr/bin/python3.10 /usr/bin/python3 && \
|
||
curl -sS https://bootstrap.pypa.io/get-pip.py | python3.10
|
||
|
||
# Silence all `safe.directory` warnings, to avoid the "detect dubious repository" error when building with submodules.
|
||
# Disabling the safe directory check here won't pose extra security issues, because in our usage for this dev build
|
||
# image, we use it solely on our own environment (that github action's VM, or ECS created dynamically by ourselves),
|
||
# and the repositories are pulled from trusted sources (still us, of course). Doing so does not violate the intention
|
||
# of the Git's addition to the "safe.directory" at the first place (see the commit message here:
|
||
# https://github.com/git/git/commit/8959555cee7ec045958f9b6dd62e541affb7e7d9).
|
||
# There's also another solution to this, that we add the desired submodules to the safe directory, instead of using
|
||
# wildcard here. However, that requires the git's config files and the submodules all owned by the very same user.
|
||
# It's troublesome to do this since the dev build runs in Docker, which is under user "root"; while outside the Docker,
|
||
# it can be a different user that have prepared the submodules.
|
||
RUN git config --global --add safe.directory ‘*’
|
||
|
||
# Install Python dependencies.
|
||
COPY $DOCKER_BUILD_ROOT/docker/python/requirements.txt /etc/greptime/requirements.txt
|
||
RUN python3 -m pip install -r /etc/greptime/requirements.txt
|
||
|
||
# Install Rust.
|
||
SHELL ["/bin/bash", "-c"]
|
||
RUN curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- --no-modify-path --default-toolchain none -y
|
||
ENV PATH /root/.cargo/bin/:$PATH
|
||
|
||
# Install Rust toolchains.
|
||
ARG RUST_TOOLCHAIN
|
||
RUN rustup toolchain install ${RUST_TOOLCHAIN}
|
||
|
||
# Install nextest.
|
||
RUN cargo install cargo-binstall --locked
|
||
RUN cargo binstall cargo-nextest --no-confirm
|