-
Notifications
You must be signed in to change notification settings - Fork 7
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Use custom built-in python with ch-backup #152
Changes from all commits
890610f
b42ff94
c7d4361
ffe3f5a
068b0bd
d667b6d
3623451
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
ARG PYTHON_BUILD_NAME | ||
ARG BASE_IMAGE=ubuntu:22.04 | ||
|
||
FROM --platform=$TARGETPLATFORM $PYTHON_BUILD_NAME-build:latest as pybuild | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. How about passing full image name here without assumption |
||
|
||
FROM --platform=$TARGETPLATFORM $BASE_IMAGE | ||
|
||
ARG DEBIAN_FRONTEND=noninteractive | ||
ARG TARGET_PYTHON_VERSION | ||
|
||
RUN mkdir -p /opt/yandex/ch-backup/python | ||
COPY --from=pybuild /opt/yandex/ch-backup/python /opt/yandex/ch-backup/python | ||
|
||
RUN set -ex \ | ||
&& apt-get update \ | ||
&& apt-get install -y --no-install-recommends \ | ||
# Debian packaging tools | ||
build-essential \ | ||
debhelper \ | ||
devscripts \ | ||
fakeroot \ | ||
# Managing keys for debian package signing | ||
gpg \ | ||
gpg-agent \ | ||
# Python packaging tools | ||
python3-pip \ | ||
python3-venv \ | ||
# Misc | ||
curl \ | ||
locales \ | ||
# For building PyNacl library | ||
libffi-dev libssl-dev libboost-all-dev libsodium-dev \ | ||
# Configure locales | ||
&& locale-gen en_US.UTF-8 \ | ||
&& update-locale LANG=en_US.UTF-8 \ | ||
# Ensure that we use our custom built version of python during building ch-backup package. | ||
&& ln -sf /opt/yandex/ch-backup/python/bin/python3.12 /usr/bin/python \ | ||
&& ln -sf /opt/yandex/ch-backup/python/bin/python3.12 /usr/bin/python3 | ||
|
||
# Project directory must be mounted here | ||
VOLUME /src | ||
WORKDIR /src | ||
|
||
# For compiling PyNACL library, which is used by ch-backup | ||
# See https://pynacl.readthedocs.io/en/latest/install/#linux-source-build | ||
ENV SODIUM_INSTALL=system | ||
|
||
ENV PYTHON=/opt/yandex/ch-backup/python/bin/python3.12 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Let's remove hard-coded versions where it is possible |
||
ENV TARGET_PYTHON_VERSION=$TARGET_PYTHON_VERSION | ||
|
||
CMD ["make", "build-deb-package-local"] |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
ARG BASE_IMAGE=ubuntu:18.04 | ||
FROM --platform=$TARGETPLATFORM $BASE_IMAGE | ||
|
||
ENV DEBIAN_FRONTEND=noninteractive | ||
ENV LANG=C.UTF-8 | ||
|
||
RUN set -ex \ | ||
&& apt-get update \ | ||
&& apt-get install -y --no-install-recommends \ | ||
build-essential \ | ||
libbz2-dev \ | ||
libffi-dev \ | ||
libgdbm-dev \ | ||
libncurses5-dev \ | ||
libnss3-dev \ | ||
libreadline-dev \ | ||
libsqlite3-dev \ | ||
libssl-dev \ | ||
wget \ | ||
xz-utils \ | ||
zlib1g-dev \ | ||
&& apt-get clean \ | ||
&& rm -rf /var/lib/apt/lists/* | ||
|
||
ARG PYTHON_INSTALL_PREFIX=/src/python | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I would propose to remove default value and add checking if it is empty. Like so
|
||
RUN mkdir -p $PYTHON_INSTALL_PREFIX | ||
|
||
ARG PYTHON_VERSION=3.12.3 | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Let's move all ARG at the beginning of dockerfile |
||
|
||
RUN set -ex \ | ||
&& wget -O python.tar.xz --no-check-certificate "https://www.python.org/ftp/python/$PYTHON_VERSION/Python-$PYTHON_VERSION.tar.xz" \ | ||
&& tar -xf python.tar.xz \ | ||
&& rm python.tar.xz \ | ||
&& cd Python-$PYTHON_VERSION/ \ | ||
&& ./configure \ | ||
--build="$(dpkg-architecture --query DEB_BUILD_GNU_TYPE)" \ | ||
--prefix=$PYTHON_INSTALL_PREFIX \ | ||
--enable-optimizations \ | ||
&& make -j $(nproc) \ | ||
&& make altinstall \ | ||
&& rm -rf /Python-$PYTHON_VERSION | ||
|
||
WORKDIR $PYTHON_INSTALL_PREFIX |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
#!/usr/bin/env bash | ||
|
||
set -e | ||
|
||
BUILD_IMAGE=${PROJECT_NAME}-build | ||
BUILD_ARGS=() | ||
|
||
# Compose image name and build arguments | ||
# Example of image name "clickhouse-tools-build-linux-amd64-linux-bionic" | ||
if [[ -n "${DEB_TARGET_PLATFORM}" ]]; then | ||
BUILD_ARGS+=(--platform=${DEB_TARGET_PLATFORM}) | ||
BUILD_IMAGE="${BUILD_IMAGE}-${DEB_TARGET_PLATFORM}" | ||
fi | ||
if [[ -n "${DEB_BUILD_DISTRIBUTION}" ]]; then | ||
BUILD_ARGS+=(--build-arg BASE_IMAGE=${DEB_BUILD_DISTRIBUTION}) | ||
BUILD_IMAGE="${BUILD_IMAGE}-${DEB_BUILD_DISTRIBUTION}" | ||
fi | ||
if [[ -n "${PYTHON_BUILD_NAME}" ]]; then | ||
BUILD_ARGS+=(--build-arg PYTHON_BUILD_NAME=${PYTHON_BUILD_NAME}) | ||
fi | ||
if [[ -n "${TARGET_PYTHON_VERSION}" ]]; then | ||
BUILD_ARGS+=(--build-arg TARGET_PYTHON_VERSION=${TARGET_PYTHON_VERSION}) | ||
fi | ||
|
||
# Normalize docker image name | ||
BUILD_IMAGE=$(echo ${BUILD_IMAGE} | tr '[:upper:]' '[:lower:]' | sed 's/[^a-z0-9._-]/-/g') | ||
|
||
RUN_ARGS=( \ | ||
-v ${PWD}:/src \ | ||
--env BUILD_DEB_OUTPUT_DIR="${BUILD_DEB_OUTPUT_DIR}" \ | ||
--env DEB_SIGN_KEY="${DEB_SIGN_KEY}" \ | ||
--env DEB_SIGN_KEY_ID="${DEB_SIGN_KEY_ID}" \ | ||
) | ||
# Mount signing key file if its path is provided | ||
if [[ -n "${DEB_SIGN_KEY_PATH}" ]]; then | ||
RUN_ARGS+=( \ | ||
-v ${DEB_SIGN_KEY_PATH}:/signing_key \ | ||
--env DEB_SIGN_KEY_PATH=/signing_key \ | ||
) | ||
fi | ||
|
||
docker build "${BUILD_ARGS[@]}" -t "${BUILD_IMAGE}" -f Dockerfile-deb-python-build . | ||
docker run "${RUN_ARGS[@]}" "${BUILD_IMAGE}" |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
#!/usr/bin/env bash | ||
|
||
set -e | ||
|
||
BUILD_IMAGE=${PYTHON_BUILD_NAME}-build | ||
BUILD_ARGS=() | ||
|
||
# Normalize docker image name | ||
BUILD_IMAGE=$(echo ${BUILD_IMAGE} | tr '[:upper:]' '[:lower:]' | sed 's/[^a-z0-9._-]/-/g') | ||
|
||
if [[ -n "${DEB_TARGET_PLATFORM}" ]]; then | ||
BUILD_ARGS+=(--platform=${DEB_TARGET_PLATFORM}) | ||
fi | ||
if [[ -n "${DEB_BUILD_DISTRIBUTION}" ]]; then | ||
BUILD_ARGS+=(--build-arg BASE_IMAGE=${DEB_BUILD_DISTRIBUTION}) | ||
fi | ||
if [[ -n "${TARGET_PYTHON_VERSION}" ]]; then | ||
BUILD_ARGS+=(--build-arg PYTHON_VERSION=${TARGET_PYTHON_VERSION}) | ||
fi | ||
if [[ -n "${PYTHON_INSTALL_PREFIX}" ]]; then | ||
BUILD_ARGS+=(--build-arg PYTHON_INSTALL_PREFIX=${PYTHON_INSTALL_PREFIX}) | ||
fi | ||
|
||
docker build "${BUILD_ARGS[@]}" -t "${BUILD_IMAGE}" -f Dockerfile-python-build . | ||
|
||
echo "${BUILD_IMAGE} was built." |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
How about building full deb here and testing if it is workable like we do here