build(docker): simplification of assembly to facilitate further support (#24504)
This commit is contained in:
parent
cd8418496f
commit
ba3bdc077c
|
|
@ -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
|
||||||
|
|
|
||||||
|
|
@ -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" \
|
||||||
|
|
|
||||||
64
Dockerfile
64
Dockerfile
|
|
@ -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
|
|
||||||
|
|
|
||||||
|
|
@ -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
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue