-
Notifications
You must be signed in to change notification settings - Fork 228
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
Add support for git tokens, to be used for python dependencies from private git repos, in the main python template. #292
Changes from 1 commit
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 |
---|---|---|
@@ -1,56 +1,88 @@ | ||
FROM --platform=${TARGETPLATFORM:-linux/amd64} ghcr.io/openfaas/classic-watchdog:0.2.0 as watchdog | ||
FROM --platform=${TARGETPLATFORM:-linux/amd64} python:3-alpine | ||
|
||
ARG TARGETPLATFORM | ||
ARG BUILDPLATFORM | ||
# Builder stage that allows you to use git modules from private repos | ||
FROM --platform=${TARGETPLATFORM:-linux/amd64} python:3-alpine as builder | ||
|
||
# Allows you to add additional packages via build-arg | ||
# Basic user, python and certificate setup | ||
ARG ADDITIONAL_PACKAGE | ||
|
||
COPY --from=watchdog /fwatchdog /usr/bin/fwatchdog | ||
RUN chmod +x /usr/bin/fwatchdog | ||
RUN apk --no-cache add ca-certificates ${ADDITIONAL_PACKAGE} | ||
RUN addgroup -S app && adduser app -S -G app | ||
WORKDIR /home/app/ | ||
RUN chown -R app /home/app && \ | ||
mkdir -p /home/app/python && chown -R app /home/app | ||
USER app | ||
ENV PATH=$PATH:/home/app/.local/bin:/home/app/python/bin/ | ||
ENV PYTHONPATH=$PYTHONPATH:/home/app/python | ||
|
||
# Token to be provided as argument | ||
ARG GIT_TOKEN=no_token_set | ||
|
||
# Add non root user | ||
RUN addgroup -S app && adduser app -S -G app | ||
# Install git and make the git token available as environment variable | ||
USER root | ||
RUN apk --no-cache add git | ||
ENV GIT_TOKEN=${GIT_TOKEN} | ||
|
||
# Install template requirements | ||
USER app | ||
WORKDIR /home/app/ | ||
|
||
COPY index.py . | ||
COPY requirements.txt . | ||
RUN pip install -r requirements.txt --target=/home/app/python | ||
|
||
# Install function specific requirements | ||
RUN mkdir -p function | ||
WORKDIR /home/app/function/ | ||
COPY function/requirements.txt . | ||
RUN pip install -r requirements.txt --target=/home/app/python | ||
|
||
FROM --platform=${TARGETPLATFORM:-linux/amd64} ghcr.io/openfaas/classic-watchdog:0.2.0 as watchdog | ||
|
||
# Actual image | ||
FROM --platform=${TARGETPLATFORM:-linux/amd64} python:3-alpine | ||
|
||
# Basic user, python and certificate setup | ||
ARG ADDITIONAL_PACKAGE | ||
RUN apk --no-cache add ca-certificates ${ADDITIONAL_PACKAGE} | ||
RUN addgroup -S app && adduser app -S -G app | ||
WORKDIR /home/app/ | ||
RUN chown -R app /home/app && \ | ||
mkdir -p /home/app/python && chown -R app /home/app | ||
mkdir -p /home/app/python && chown -R app /home/app | ||
USER app | ||
ENV PATH=$PATH:/home/app/.local/bin:/home/app/python/bin/ | ||
ENV PYTHONPATH=$PYTHONPATH:/home/app/python | ||
|
||
RUN pip install -r requirements.txt --target=/home/app/python | ||
# Copy over watchdog | ||
USER root | ||
COPY --from=watchdog /fwatchdog /usr/bin/fwatchdog | ||
RUN chmod +x /usr/bin/fwatchdog | ||
|
||
# Copy over template files | ||
USER app | ||
WORKDIR /home/app/ | ||
COPY index.py . | ||
COPY requirements.txt . | ||
|
||
# Mark the function dir as a module | ||
RUN mkdir -p function | ||
RUN touch ./function/__init__.py | ||
|
||
# Copy over the function specific requirements file | ||
WORKDIR /home/app/function/ | ||
COPY function/requirements.txt . | ||
|
||
RUN pip install -r requirements.txt --target=/home/app/python | ||
|
||
# Copy over resolved dependencies from builder stage | ||
WORKDIR /home/app/ | ||
COPY --from=builder /home/app/.cache /home/app/.cache | ||
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. My concern would be whether any C/C++ libraries that were built or installed into the system are still available at this point such as numpy, pillow or pandas. 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. Good point. I'll see if I can test this. I believe 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. Confirmed that numpy only installs to 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. Pillow doesn't correctly install, due to a missing zlib dependency (and even when that is added, it is installed to See: link 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. Pandas seems to work fine too, only using those 2 folders |
||
COPY --from=builder /home/app/python /home/app/python | ||
|
||
# Copy over the specific function code | ||
USER root | ||
|
||
COPY function function | ||
|
||
# Allow any user-id for OpenShift users. | ||
RUN chown -R app:app ./ && \ | ||
chmod -R 777 /home/app/python | ||
chmod -R 777 /home/app/python | ||
|
||
# Prepare and run the watchdog | ||
USER app | ||
|
||
ENV fprocess="python3 index.py" | ||
EXPOSE 8080 | ||
|
||
HEALTHCHECK --interval=3s CMD [ -e /tmp/.lock ] || exit 1 | ||
|
||
CMD ["fwatchdog"] |
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.
It may be better to avoid leaking the ENV into the build, and instead prefixing the value in the pip install command.
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.
I was going to say the same thing, like this
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.
I didn't think that the env var would be leaked if used in the builder stage, but I do agree that it's neater the way that @LucasRoesler proposes. That way it won't unnecessarily be available to all the other commands.
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.
Changed