-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Define a Docker stage for local development #133
- Loading branch information
Showing
2 changed files
with
15 additions
and
76 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,68 +1,34 @@ | ||
# Dockerfile to build and serve scigateway-auth | ||
FROM python:3.11.10-alpine3.20@sha256:f089154eb2546de825151b9340a60d39e2ba986ab17aaffca14301b0b961a11c as base | ||
|
||
# Build stage | ||
FROM python:3.11-alpine3.17 as builder | ||
WORKDIR /app | ||
|
||
WORKDIR /scigateway-auth-build | ||
|
||
COPY README.md poetry.lock pyproject.toml ./ | ||
COPY scigateway_auth/ scigateway_auth/ | ||
COPY poetry.lock pyproject.toml ./ | ||
|
||
RUN --mount=type=cache,target=/root/.cache \ | ||
set -eux; \ | ||
\ | ||
python3 -m pip install 'poetry~=1.3.2'; \ | ||
poetry build; | ||
pip install --no-cache-dir 'poetry~=1.8.4'; \ | ||
\ | ||
poetry export --only dev --format requirements.txt --without-hashes --output requirements-dev.txt; \ | ||
poetry export --without dev --format requirements.txt --without-hashes --output requirements-prod.txt; | ||
|
||
|
||
# Install & run stage | ||
FROM python:3.11-alpine3.17 | ||
FROM python:3.11.10-alpine3.20@sha256:f089154eb2546de825151b9340a60d39e2ba986ab17aaffca14301b0b961a11c as dev | ||
|
||
WORKDIR /scigateway-auth-run | ||
WORKDIR /app | ||
|
||
COPY --from=builder /scigateway-auth-build/dist/scigateway_auth-*.whl /tmp/ | ||
COPY --from=base /app/requirements-*.txt ./ | ||
COPY scigateway_auth/ scigateway_auth/ | ||
COPY maintenance/ maintenance/ | ||
COPY keys/ keys/ | ||
|
||
RUN --mount=type=cache,target=/root/.cache \ | ||
set -eux; \ | ||
\ | ||
apk add --no-cache openssh-keygen; \ | ||
python3 -m pip install \ | ||
'gunicorn~=20.1.0' \ | ||
/tmp/scigateway_auth-*.whl; \ | ||
\ | ||
# Create a symlink to the installed python module \ | ||
SCIGATEWAY_AUTH_LOCATION="$(python3 -m pip show scigateway_auth | awk '/^Location:/ { print $2 }')"; \ | ||
ln -s "$SCIGATEWAY_AUTH_LOCATION/scigateway_auth/" scigateway_auth; \ | ||
apk add --no-cache gcc musl-dev linux-headers python3-dev; \ | ||
\ | ||
# Create config.json from its .example file \ | ||
cp scigateway_auth/config.json.example scigateway_auth/config.json; \ | ||
\ | ||
# Create directory for JWT keys (they will be generated in the entrypoint script) \ | ||
mkdir keys; \ | ||
chmod 0700 keys; \ | ||
\ | ||
# Create a non-root user to run as \ | ||
addgroup -S scigateway-auth; \ | ||
adduser -S -D -G scigateway-auth -H -h /scigateway-auth-run scigateway-auth; \ | ||
\ | ||
# Change ownership of maintenance/ - it needs to be writable at runtime \ | ||
# Change ownership of keys/ and config.json - the entrypoint script will need to edit them \ | ||
chown -R scigateway-auth:scigateway-auth keys/ maintenance/ scigateway_auth/config.json; | ||
|
||
USER scigateway-auth | ||
|
||
ENV ICAT_URL="http://localhost" | ||
ENV LOG_LOCATION="/dev/stdout" | ||
ENV PRIVATE_KEY_PATH="keys/jwt-key" | ||
ENV PUBLIC_KEY_PATH="keys/jwt-key.pub" | ||
ENV MAINTENANCE_CONFIG_PATH="maintenance/maintenance.json" | ||
ENV SCHEDULED_MAINTENANCE_CONFIG_PATH="maintenance/scheduled_maintenance.json" | ||
ENV VERIFY="true" | ||
pip install --no-cache-dir --requirement requirements-dev.txt --requirement requirements-prod.txt; | ||
|
||
COPY docker/docker-entrypoint.sh /usr/local/bin/ | ||
ENTRYPOINT ["docker-entrypoint.sh"] | ||
CMD ["fastapi", "dev", "scigateway_auth/main.py", "--host", "0.0.0.0", "--port", "8000"] | ||
|
||
# Serve the application using gunicorn - production ready WSGI server | ||
CMD ["gunicorn", "-b", "0.0.0.0:8000", "scigateway_auth.wsgi"] | ||
EXPOSE 8000 |
This file was deleted.
Oops, something went wrong.