build(docker): simplification of assembly to facilitate further support (#24504)

This commit is contained in:
Aleksey Karpov 2023-06-24 21:41:57 +03:00 committed by GitHub
parent cd8418496f
commit ba3bdc077c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 52 additions and 60 deletions

View File

@ -50,7 +50,7 @@ jobs:
mkdir -p ./build mkdir -p ./build
echo ${{ github.sha }} > ./build/SHA echo ${{ github.sha }} > ./build/SHA
echo ${{ github.event.pull_request.number }} > ./build/PR-NUM echo ${{ github.event.pull_request.number }} > ./build/PR-NUM
docker build --target ci -t ${{ github.sha }} -t "pr-${{ github.event.pull_request.number }}" . DOCKER_BUILDKIT=1 docker build --target ci -t ${{ github.sha }} -t "pr-${{ github.event.pull_request.number }}" .
docker save ${{ github.sha }} | gzip > ./build/${{ github.sha }}.tar.gz docker save ${{ github.sha }} | gzip > ./build/${{ github.sha }}.tar.gz
- name: Upload build artifacts - name: Upload build artifacts

View File

@ -46,7 +46,7 @@ EOF
# #
# Build the "lean" image # Build the "lean" image
# #
docker build --target lean \ DOCKER_BUILDKIT=1 docker build --target lean \
-t "${REPO_NAME}:${SHA}" \ -t "${REPO_NAME}:${SHA}" \
-t "${REPO_NAME}:${REFSPEC}" \ -t "${REPO_NAME}:${REFSPEC}" \
-t "${REPO_NAME}:${LATEST_TAG}" \ -t "${REPO_NAME}:${LATEST_TAG}" \
@ -59,7 +59,7 @@ docker build --target lean \
# #
# Build the "lean310" image # Build the "lean310" image
# #
docker build --target lean \ DOCKER_BUILDKIT=1 docker build --target lean \
-t "${REPO_NAME}:${SHA}-py310" \ -t "${REPO_NAME}:${SHA}-py310" \
-t "${REPO_NAME}:${REFSPEC}-py310" \ -t "${REPO_NAME}:${REFSPEC}-py310" \
-t "${REPO_NAME}:${LATEST_TAG}-py310" \ -t "${REPO_NAME}:${LATEST_TAG}-py310" \
@ -73,7 +73,7 @@ docker build --target lean \
# #
# Build the "websocket" image # Build the "websocket" image
# #
docker build \ DOCKER_BUILDKIT=1 docker build \
-t "${REPO_NAME}:${SHA}-websocket" \ -t "${REPO_NAME}:${SHA}-websocket" \
-t "${REPO_NAME}:${REFSPEC}-websocket" \ -t "${REPO_NAME}:${REFSPEC}-websocket" \
-t "${REPO_NAME}:${LATEST_TAG}-websocket" \ -t "${REPO_NAME}:${LATEST_TAG}-websocket" \
@ -86,7 +86,7 @@ docker build \
# #
# Build the dev image # Build the dev image
# #
docker build --target dev \ DOCKER_BUILDKIT=1 docker build --target dev \
-t "${REPO_NAME}:${SHA}-dev" \ -t "${REPO_NAME}:${SHA}-dev" \
-t "${REPO_NAME}:${REFSPEC}-dev" \ -t "${REPO_NAME}:${REFSPEC}-dev" \
-t "${REPO_NAME}:${LATEST_TAG}-dev" \ -t "${REPO_NAME}:${LATEST_TAG}-dev" \

View File

@ -29,17 +29,17 @@ ENV BUILD_CMD=${NPM_BUILD_CMD}
ENV PUPPETEER_SKIP_CHROMIUM_DOWNLOAD=true ENV PUPPETEER_SKIP_CHROMIUM_DOWNLOAD=true
# NPM ci first, as to NOT invalidate previous steps except for when package.json changes # NPM ci first, as to NOT invalidate previous steps except for when package.json changes
RUN mkdir -p /app/superset-frontend WORKDIR /app/superset-frontend
COPY ./docker/frontend-mem-nag.sh / COPY ./docker/frontend-mem-nag.sh /
RUN /frontend-mem-nag.sh RUN /frontend-mem-nag.sh
WORKDIR /app/superset-frontend/
COPY superset-frontend/package*.json ./ COPY superset-frontend/package*.json ./
RUN npm ci RUN npm ci
COPY ./superset-frontend . COPY ./superset-frontend ./
# This seems to be the most expensive step # This seems to be the most expensive step
RUN npm run ${BUILD_CMD} RUN npm run ${BUILD_CMD}
@ -49,6 +49,7 @@ RUN npm run ${BUILD_CMD}
###################################################################### ######################################################################
FROM python:${PY_VER} AS lean FROM python:${PY_VER} AS lean
WORKDIR /app
ENV LANG=C.UTF-8 \ ENV LANG=C.UTF-8 \
LC_ALL=C.UTF-8 \ LC_ALL=C.UTF-8 \
FLASK_ENV=production \ FLASK_ENV=production \
@ -59,8 +60,8 @@ ENV LANG=C.UTF-8 \
RUN mkdir -p ${PYTHONPATH} \ RUN mkdir -p ${PYTHONPATH} \
&& useradd --user-group -d ${SUPERSET_HOME} -m --no-log-init --shell /bin/bash superset \ && useradd --user-group -d ${SUPERSET_HOME} -m --no-log-init --shell /bin/bash superset \
&& apt-get update -y \ && apt-get update -q \
&& apt-get install -y --no-install-recommends \ && apt-get install -yq --no-install-recommends \
build-essential \ build-essential \
curl \ curl \
default-libmysqlclient-dev \ default-libmysqlclient-dev \
@ -71,11 +72,8 @@ RUN mkdir -p ${PYTHONPATH} \
libldap2-dev \ libldap2-dev \
&& rm -rf /var/lib/apt/lists/* && rm -rf /var/lib/apt/lists/*
WORKDIR /app
COPY --chown=superset:superset ./requirements/*.txt requirements/ COPY --chown=superset:superset ./requirements/*.txt requirements/
COPY --chown=superset:superset setup.py MANIFEST.in README.md ./ COPY --chown=superset:superset setup.py MANIFEST.in README.md ./
# setup.py uses the version information in package.json # setup.py uses the version information in package.json
COPY --chown=superset:superset superset-frontend/package.json superset-frontend/ COPY --chown=superset:superset superset-frontend/package.json superset-frontend/
@ -84,16 +82,14 @@ RUN mkdir -p superset/static \
&& pip install --no-cache-dir -r requirements/local.txt && pip install --no-cache-dir -r requirements/local.txt
COPY --chown=superset:superset --from=superset-node /app/superset/static/assets superset/static/assets COPY --chown=superset:superset --from=superset-node /app/superset/static/assets superset/static/assets
## Lastly, let's install superset itself ## Lastly, let's install superset itself
COPY --chown=superset:superset superset superset COPY --chown=superset:superset superset superset
RUN chown -R superset:superset ./* \ RUN chown -R superset:superset ./* \
&& pip install --no-cache-dir -e . \ && pip install --no-cache-dir -e . \
&& flask fab babel-compile --target superset/translations && flask fab babel-compile --target superset/translations
COPY ./docker/run-server.sh /usr/bin/ COPY --chmod=755 ./docker/run-server.sh /usr/bin/
RUN chmod a+x /usr/bin/run-server.sh
USER superset USER superset
HEALTHCHECK CMD curl -f "http://localhost:$SUPERSET_PORT/health" HEALTHCHECK CMD curl -f "http://localhost:$SUPERSET_PORT/health"
@ -109,47 +105,35 @@ FROM lean AS dev
ARG GECKODRIVER_VERSION=v0.32.0 ARG GECKODRIVER_VERSION=v0.32.0
ARG FIREFOX_VERSION=106.0.3 ARG FIREFOX_VERSION=106.0.3
COPY ./requirements/*.txt ./docker/requirements-*.txt/ /app/requirements/
USER root USER root
RUN apt-get update -y \ RUN apt-get update -q \
&& apt-get install -y --no-install-recommends \ && apt-get install -yq --no-install-recommends \
libnss3 \ libnss3 \
libdbus-glib-1-2 \ libdbus-glib-1-2 \
libgtk-3-0 \ libgtk-3-0 \
libx11-xcb1 \ libx11-xcb1 \
libasound2 \ libasound2 \
libxtst6 \ libxtst6 \
wget wget \
# Install GeckoDriver WebDriver
# Install GeckoDriver WebDriver && wget https://github.com/mozilla/geckodriver/releases/download/${GECKODRIVER_VERSION}/geckodriver-${GECKODRIVER_VERSION}-linux64.tar.gz -O - | tar xfz - -C /usr/local/bin \
RUN wget https://github.com/mozilla/geckodriver/releases/download/${GECKODRIVER_VERSION}/geckodriver-${GECKODRIVER_VERSION}-linux64.tar.gz -O /tmp/geckodriver.tar.gz && \ # Install Firefox
tar xvfz /tmp/geckodriver.tar.gz -C /tmp && \ && wget https://download-installer.cdn.mozilla.net/pub/firefox/releases/${FIREFOX_VERSION}/linux-x86_64/en-US/firefox-${FIREFOX_VERSION}.tar.bz2 -O - | tar xfj - -C /opt \
mv /tmp/geckodriver /usr/local/bin/geckodriver && \ && ln -s /opt/firefox/firefox /usr/local/bin/firefox \
rm /tmp/geckodriver.tar.gz && apt-get autoremove -yqq --purge wget && rm -rf /var/lib/apt/lists/* && apt-get clean
# Install Firefox
RUN wget https://download-installer.cdn.mozilla.net/pub/firefox/releases/${FIREFOX_VERSION}/linux-x86_64/en-US/firefox-${FIREFOX_VERSION}.tar.bz2 -O /opt/firefox.tar.bz2 && \
tar xvf /opt/firefox.tar.bz2 -C /opt && \
ln -s /opt/firefox/firefox /usr/local/bin/firefox
COPY ./requirements/*.txt ./docker/requirements-*.txt/ /app/requirements/
# Cache everything for dev purposes... # Cache everything for dev purposes...
RUN cd /app \ RUN pip install --no-cache-dir -r /app/requirements/docker.txt \
&& pip install --no-cache -r requirements/docker.txt \ && pip install --no-cache-dir -r /app/requirements/requirements-local.txt || true
&& pip install --no-cache -r requirements/requirements-local.txt || true
USER superset USER superset
###################################################################### ######################################################################
# CI image... # CI image...
###################################################################### ######################################################################
FROM lean AS ci FROM lean AS ci
COPY --chown=superset ./docker/docker-bootstrap.sh /app/docker/ COPY --chown=superset --chmod=755 ./docker/*.sh /app/docker/
COPY --chown=superset ./docker/docker-init.sh /app/docker/
COPY --chown=superset ./docker/docker-ci.sh /app/docker/
RUN chmod a+x /app/docker/*.sh CMD ["/app/docker/docker-ci.sh"]
CMD /app/docker/docker-ci.sh

View File

@ -30,22 +30,30 @@ fi
# #
if [ -f "${REQUIREMENTS_LOCAL}" ]; then if [ -f "${REQUIREMENTS_LOCAL}" ]; then
echo "Installing local overrides at ${REQUIREMENTS_LOCAL}" echo "Installing local overrides at ${REQUIREMENTS_LOCAL}"
pip install -r "${REQUIREMENTS_LOCAL}" pip install --no-cache-dir -r "${REQUIREMENTS_LOCAL}"
else else
echo "Skipping local overrides" echo "Skipping local overrides"
fi fi
if [[ "${1}" == "worker" ]]; then case "${1}" in
echo "Starting Celery worker..." worker)
celery --app=superset.tasks.celery_app:app worker -O fair -l INFO echo "Starting Celery worker..."
elif [[ "${1}" == "beat" ]]; then celery --app=superset.tasks.celery_app:app worker -O fair -l INFO
echo "Starting Celery beat..." ;;
rm -f /tmp/celerybeat.pid beat)
celery --app=superset.tasks.celery_app:app beat --pidfile /tmp/celerybeat.pid -l INFO -s "${SUPERSET_HOME}"/celerybeat-schedule echo "Starting Celery beat..."
elif [[ "${1}" == "app" ]]; then rm -f /tmp/celerybeat.pid
echo "Starting web app..." celery --app=superset.tasks.celery_app:app beat --pidfile /tmp/celerybeat.pid -l INFO -s "${SUPERSET_HOME}"/celerybeat-schedule
flask run -p 8088 --with-threads --reload --debugger --host=0.0.0.0 ;;
elif [[ "${1}" == "app-gunicorn" ]]; then app)
echo "Starting web app..." echo "Starting web app..."
/usr/bin/run-server.sh flask run -p 8088 --with-threads --reload --debugger --host=0.0.0.0
fi ;;
app-gunicorn)
echo "Starting web app..."
/usr/bin/run-server.sh
;;
*)
echo "Unknown Operation!!!"
;;
esac