diff --git a/.github/workflows/build-images.yaml b/.github/workflows/build-images.yaml index ddef80496a2e..5e24e488efc6 100644 --- a/.github/workflows/build-images.yaml +++ b/.github/workflows/build-images.yaml @@ -74,17 +74,17 @@ jobs: matrix: include: - image: ds-pipelines-api-server - dockerfile: backend/Dockerfile + dockerfile: odh_images/Dockerfile - image: ds-pipelines-frontend dockerfile: frontend/Dockerfile - image: ds-pipelines-persistenceagent - dockerfile: backend/Dockerfile.persistenceagent + dockerfile: odh_images/Dockerfile.persistenceagent - image: ds-pipelines-scheduledworkflow - dockerfile: backend/Dockerfile.scheduledworkflow + dockerfile: odh_images/Dockerfile.scheduledworkflow - image: ds-pipelines-driver - dockerfile: backend/Dockerfile.driver + dockerfile: odh_images/Dockerfile.driver - image: ds-pipelines-launcher - dockerfile: backend/Dockerfile.launcher + dockerfile: odh_images/Dockerfile.launcher steps: - uses: actions/checkout@v3 - uses: ./.github/actions/build diff --git a/.github/workflows/build-master.yml b/.github/workflows/build-master.yml index 6e0b28c477f8..0bb93167b970 100644 --- a/.github/workflows/build-master.yml +++ b/.github/workflows/build-master.yml @@ -20,17 +20,17 @@ jobs: matrix: include: - image: ds-pipelines-api-server - dockerfile: backend/Dockerfile + dockerfile: odh_images/Dockerfile - image: ds-pipelines-frontend dockerfile: frontend/Dockerfile - image: ds-pipelines-persistenceagent - dockerfile: backend/Dockerfile.persistenceagent + dockerfile: odh_images/Dockerfile.persistenceagent - image: ds-pipelines-scheduledworkflow - dockerfile: backend/Dockerfile.scheduledworkflow + dockerfile: odh_images/Dockerfile.scheduledworkflow - image: ds-pipelines-driver - dockerfile: backend/Dockerfile.driver + dockerfile: odh_images/Dockerfile.driver - image: ds-pipelines-launcher - dockerfile: backend/Dockerfile.launcher + dockerfile: odh_images/Dockerfile.launcher steps: - uses: actions/checkout@v3 - name: Generate Tag diff --git a/.github/workflows/build-prs.yml b/.github/workflows/build-prs.yml index a3f3960b9acc..dff033259822 100644 --- a/.github/workflows/build-prs.yml +++ b/.github/workflows/build-prs.yml @@ -69,17 +69,17 @@ jobs: matrix: include: - image: ds-pipelines-api-server - dockerfile: backend/Dockerfile + dockerfile: odh_images/Dockerfile - image: ds-pipelines-frontend dockerfile: frontend/Dockerfile - image: ds-pipelines-persistenceagent - dockerfile: backend/Dockerfile.persistenceagent + dockerfile: odh_images/Dockerfile.persistenceagent - image: ds-pipelines-scheduledworkflow - dockerfile: backend/Dockerfile.scheduledworkflow + dockerfile: odh_images/Dockerfile.scheduledworkflow - image: ds-pipelines-driver - dockerfile: backend/Dockerfile.driver + dockerfile: odh_images/Dockerfile.driver - image: ds-pipelines-launcher - dockerfile: backend/Dockerfile.launcher + dockerfile: odh_images/Dockerfile.launcher steps: - uses: actions/checkout@v3 - name: Build Image diff --git a/backend/Dockerfile b/backend/Dockerfile index 05fab08013b0..d5624ce8ab35 100644 --- a/backend/Dockerfile +++ b/backend/Dockerfile @@ -1,4 +1,4 @@ -# Copyright 2021-2024 The Kubeflow Authors +# Copyright 2021-2022 The Kubeflow Authors # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -12,12 +12,34 @@ # See the License for the specific language governing permissions and # limitations under the License. -# Build arguments -ARG SOURCE_CODE=. +# 1. Build api server application +FROM golang:1.21.7-bookworm as builder +RUN apt-get update && apt-get install -y cmake clang musl-dev openssl +WORKDIR /go/src/github.com/kubeflow/pipelines -FROM registry.access.redhat.com/ubi8/go-toolset:1.21 as builder +COPY ./go.mod ./ +COPY ./go.sum ./ +COPY ./hack/install-go-licenses.sh ./hack/ + +RUN GO111MODULE=on go mod download +RUN ./hack/install-go-licenses.sh + +COPY . . +RUN GO111MODULE=on go build -o /bin/apiserver backend/src/apiserver/*.go +# Check licenses and comply with license terms. +# First, make sure there's no forbidden license. +RUN go-licenses check ./backend/src/apiserver +RUN go-licenses csv ./backend/src/apiserver > /tmp/licenses.csv && \ + diff /tmp/licenses.csv backend/third_party_licenses/apiserver.csv && \ + go-licenses save ./backend/src/apiserver --save_path /tmp/NOTICES + +# 2. Compile preloaded pipeline samples +FROM python:3.9 as compiler +RUN apt-get update -y && apt-get install --no-install-recommends -y -q default-jdk python3-setuptools python3-dev jq +RUN wget https://bootstrap.pypa.io/get-pip.py && python3 get-pip.py +COPY backend/requirements.txt . +RUN python3 -m pip install -r requirements.txt --no-cache-dir -USER root # Downloading Argo CLI so that the samples are validated ENV ARGO_VERSION v3.4.17 RUN curl -sLO https://github.com/argoproj/argo-workflows/releases/download/${ARGO_VERSION}/argo-linux-amd64.gz && \ @@ -25,34 +47,44 @@ RUN curl -sLO https://github.com/argoproj/argo-workflows/releases/download/${ARG chmod +x argo-linux-amd64 && \ mv ./argo-linux-amd64 /usr/local/bin/argo -RUN dnf install -y cmake clang openssl - -COPY ${SOURCE_CODE}/go.mod ./ -COPY ${SOURCE_CODE}/go.sum ./ +WORKDIR / +COPY ./samples /samples +COPY backend/src/apiserver/config/sample_config.json /samples/ -RUN GO111MODULE=on go mod download - -# Copy the source -COPY ${SOURCE_CODE}/ ./ +# Compiling the preloaded samples. +# The default image is replaced with the GCR-hosted python image. +RUN set -e; \ + < /samples/sample_config.json jq .[].file --raw-output | while read pipeline_yaml; do \ + pipeline_py="${pipeline_yaml%.yaml}"; \ + python3 "$pipeline_py"; \ + done -RUN GO111MODULE=on go build -o /bin/apiserver ./backend/src/apiserver/ && \ - dnf clean all +# 3. Start api web server +FROM debian:stable -FROM registry.access.redhat.com/ubi8/ubi-minimal:latest +ARG COMMIT_SHA=unknown +ENV COMMIT_SHA=${COMMIT_SHA} +ARG TAG_NAME=unknown +ENV TAG_NAME=${TAG_NAME} +ENV LOG_LEVEL info WORKDIR /bin -COPY --from=builder /opt/app-root/src/backend/src/apiserver/config/ /config +COPY backend/src/apiserver/config/ /config COPY --from=builder /bin/apiserver /bin/apiserver +# Copy licenses and notices. +COPY --from=builder /tmp/licenses.csv /third_party/licenses.csv +COPY --from=builder /tmp/NOTICES /third_party/NOTICES +COPY --from=compiler /samples/ /samples/ RUN chmod +x /bin/apiserver -USER root - # Adding CA certificate so API server can download pipeline through URL and wget is used for liveness/readiness probe command -RUN microdnf install -y ca-certificates wget +RUN apt-get update && apt-get install -y ca-certificates wget -USER 1001 +# Pin sample doc links to the commit that built the backend image +RUN sed -E "s#/(blob|tree)/master/#/\1/${COMMIT_SHA}/#g" -i /config/sample_config.json && \ + sed -E "s/%252Fmaster/%252F${COMMIT_SHA}/#g" -i /config/sample_config.json # Expose apiserver port EXPOSE 8888 diff --git a/backend/Dockerfile.conformance b/backend/Dockerfile.conformance index 9a2920a580db..15c97b7277f1 100644 --- a/backend/Dockerfile.conformance +++ b/backend/Dockerfile.conformance @@ -19,6 +19,12 @@ RUN apk update && apk upgrade && \ apk add --no-cache bash git openssh gcc musl-dev WORKDIR /go/src/github.com/kubeflow/pipelines + +COPY ./go.mod ./ +COPY ./go.sum ./ + +RUN GO111MODULE=on go mod download + COPY . . # Compile the test @@ -34,7 +40,7 @@ RUN chmod +x /test/integration/run.sh RUN tar -czvf /test.tar.gz /test -FROM alpine:3.8 +FROM alpine:3.9 COPY --from=builder /test.tar.gz / RUN tar -xzvf /test.tar.gz diff --git a/backend/Dockerfile.driver b/backend/Dockerfile.driver index b2f21f30a895..99008585712c 100644 --- a/backend/Dockerfile.driver +++ b/backend/Dockerfile.driver @@ -1,4 +1,4 @@ -# Copyright 2021-2024 The Kubeflow Authors +# Copyright 2023 The Kubeflow Authors # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -12,37 +12,38 @@ # See the License for the specific language governing permissions and # limitations under the License. -# Build arguments -ARG SOURCE_CODE=. +FROM golang:1.21.7-alpine3.19 as builder -# Use ubi8/nodejs-14 as base image -FROM registry.access.redhat.com/ubi8/go-toolset:1.21 as builder +WORKDIR /go/src/github.com/kubeflow/pipelines - -## Build args to be used at this step -ARG SOURCE_CODE - -## Switch to root as required for some operations -USER root - -COPY ${SOURCE_CODE}/go.mod ./ -COPY ${SOURCE_CODE}/go.sum ./ +COPY ./go.mod ./ +COPY ./go.sum ./ +COPY ./hack/install-go-licenses.sh ./hack/ RUN GO111MODULE=on go mod download +RUN ./hack/install-go-licenses.sh -# Copy the source -COPY ${SOURCE_CODE}/ ./ +COPY . . RUN GO111MODULE=on CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -tags netgo -ldflags '-extldflags "-static"' -o /bin/driver ./backend/src/v2/cmd/driver/*.go -FROM registry.access.redhat.com/ubi8/ubi-minimal:latest +# Check licenses and comply with license terms. +# First, make sure there's no forbidden license. +RUN go-licenses check ./backend/src/v2/cmd/driver +RUN go-licenses csv ./backend/src/v2/cmd/driver > /tmp/licenses.csv && \ + diff /tmp/licenses.csv backend/third_party_licenses/driver.csv && \ + go-licenses save ./backend/src/v2/cmd/driver --save_path /tmp/NOTICES + +FROM alpine:3.19 + +RUN adduser -S appuser +USER appuser WORKDIR /bin COPY --from=builder /bin/driver /bin/driver -RUN chmod +x /bin/driver - -ENTRYPOINT ["/bin/driver"] +# Copy licenses and notices. +COPY --from=builder /tmp/licenses.csv /third_party/licenses.csv +COPY --from=builder /tmp/NOTICES /third_party/NOTICES -LABEL name="ds-pipelines-driver" \ - summary="DSP Driver" +ENTRYPOINT [ "/bin/driver" ] \ No newline at end of file diff --git a/backend/Dockerfile.launcher b/backend/Dockerfile.launcher index e91228c485cf..2fc931156d09 100644 --- a/backend/Dockerfile.launcher +++ b/backend/Dockerfile.launcher @@ -1,4 +1,4 @@ -# Copyright 2021-2024 The Kubeflow Authors +# Copyright 2023 The Kubeflow Authors # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. @@ -12,39 +12,38 @@ # See the License for the specific language governing permissions and # limitations under the License. -# Build arguments -ARG SOURCE_CODE=. -ARG CI_CONTAINER_VERSION="unknown" +FROM golang:1.21.7-alpine3.19 as builder +WORKDIR /go/src/github.com/kubeflow/pipelines -# Use ubi8/nodejs-14 as base image -FROM registry.access.redhat.com/ubi8/go-toolset:1.21 as builder - - -## Build args to be used at this step -ARG SOURCE_CODE - -## Switch to root as required for some operations -USER root - -COPY ${SOURCE_CODE}/go.mod ./ -COPY ${SOURCE_CODE}/go.sum ./ +COPY ./go.mod ./ +COPY ./go.sum ./ +COPY ./hack/install-go-licenses.sh ./hack/ RUN GO111MODULE=on go mod download +RUN ./hack/install-go-licenses.sh -# Copy the source -COPY ${SOURCE_CODE}/ ./ +COPY . . RUN GO111MODULE=on CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -tags netgo -ldflags '-extldflags "-static"' -o /bin/launcher-v2 ./backend/src/v2/cmd/launcher-v2/*.go -FROM registry.access.redhat.com/ubi8/ubi-minimal:latest +# Check licenses and comply with license terms. +# First, make sure there's no forbidden license. +RUN go-licenses check ./backend/src/v2/cmd/launcher-v2 +RUN go-licenses csv ./backend/src/v2/cmd/launcher-v2 > /tmp/licenses.csv && \ + diff /tmp/licenses.csv backend/third_party_licenses/launcher.csv && \ + go-licenses save ./backend/src/v2/cmd/launcher-v2 --save_path /tmp/NOTICES + +FROM alpine:3.19 + +RUN adduser -S appuser +USER appuser WORKDIR /bin COPY --from=builder /bin/launcher-v2 /bin/launcher-v2 -RUN chmod +x /bin/launcher-v2 - -ENTRYPOINT ["/bin/launcher-v2"] +# Copy licenses and notices. +COPY --from=builder /tmp/licenses.csv /third_party/licenses.csv +COPY --from=builder /tmp/NOTICES /third_party/NOTICES -LABEL name="ds-pipelines-launcher" \ - summary="DSP launcher" +ENTRYPOINT [ "/bin/launcher-v2" ] \ No newline at end of file diff --git a/backend/Dockerfile.persistenceagent b/backend/Dockerfile.persistenceagent index 5fc5231f8040..93a38618d3d3 100644 --- a/backend/Dockerfile.persistenceagent +++ b/backend/Dockerfile.persistenceagent @@ -12,35 +12,42 @@ # See the License for the specific language governing permissions and # limitations under the License. -# Build arguments -ARG SOURCE_CODE=. -ARG CI_CONTAINER_VERSION="unknown" +FROM golang:1.21.7-alpine3.19 as builder +WORKDIR /go/src/github.com/kubeflow/pipelines -# Use ubi8/go-toolset as base image -FROM registry.access.redhat.com/ubi8/go-toolset:1.21 as builder +COPY ./go.mod ./ +COPY ./go.sum ./ +COPY ./hack/install-go-licenses.sh ./hack/ -## Build args to be used at this step -ARG SOURCE_CODE - -USER root +RUN GO111MODULE=on go mod download +RUN ./hack/install-go-licenses.sh -RUN dnf install -y bash git openssh gcc +COPY . . -COPY ${SOURCE_CODE}/go.mod ./ -COPY ${SOURCE_CODE}/go.sum ./ +# Needed musl-dev for github.com/mattn/go-sqlite3 +RUN apk update && apk upgrade && \ + apk add --no-cache bash git openssh gcc musl-dev -RUN GO111MODULE=on go mod download +RUN GO111MODULE=on go build -o /bin/persistence_agent backend/src/agent/persistence/*.go +# Check licenses and comply with license terms. +# First, make sure there's no forbidden license. +RUN go-licenses check ./backend/src/agent/persistence +RUN go-licenses csv ./backend/src/agent/persistence > /tmp/licenses.csv && \ + diff /tmp/licenses.csv backend/third_party_licenses/persistence_agent.csv && \ + go-licenses save ./backend/src/agent/persistence --save_path /tmp/NOTICES -# Copy the source -COPY ${SOURCE_CODE}/ ./ +FROM alpine:3.19 -RUN GO111MODULE=on go build -o /bin/persistence_agent backend/src/agent/persistence/*.go +RUN adduser -S appuser +USER appuser -FROM registry.access.redhat.com/ubi8/ubi-minimal:latest WORKDIR /bin COPY --from=builder /bin/persistence_agent /bin/persistence_agent +# Copy licenses and notices. +COPY --from=builder /tmp/licenses.csv /third_party/licenses.csv +COPY --from=builder /tmp/NOTICES /third_party/NOTICES ENV NAMESPACE "" @@ -53,4 +60,4 @@ ENV LOG_LEVEL info ENV EXECUTIONTYPE Workflow -CMD persistence_agent --logtostderr=true --namespace=${NAMESPACE} --ttlSecondsAfterWorkflowFinish=${TTL_SECONDS_AFTER_WORKFLOW_FINISH} --numWorker ${NUM_WORKERS} --executionType ${EXECUTIONTYPE} --logLevel=${LOG_LEVEL} +CMD persistence_agent --logtostderr=true --namespace=${NAMESPACE} --ttlSecondsAfterWorkflowFinish=${TTL_SECONDS_AFTER_WORKFLOW_FINISH} --numWorker ${NUM_WORKERS} --executionType ${EXECUTIONTYPE} --logLevel=${LOG_LEVEL} \ No newline at end of file diff --git a/backend/Dockerfile.scheduledworkflow b/backend/Dockerfile.scheduledworkflow index a71b5d877e7d..021f15b4691c 100644 --- a/backend/Dockerfile.scheduledworkflow +++ b/backend/Dockerfile.scheduledworkflow @@ -12,44 +12,44 @@ # See the License for the specific language governing permissions and # limitations under the License. -# Build arguments -ARG SOURCE_CODE=. +FROM golang:1.21.7-alpine3.19 as builder -# Use ubi8/nodejs-14 as base image -FROM registry.access.redhat.com/ubi8/go-toolset:1.21 as builder +WORKDIR /go/src/github.com/kubeflow/pipelines -## Build args to be used at this step -ARG SOURCE_CODE +COPY ./go.mod ./ +COPY ./go.sum ./ +COPY ./hack/install-go-licenses.sh ./hack/ -## Switch to root as required for some operations -USER root +RUN GO111MODULE=on go mod download +RUN ./hack/install-go-licenses.sh -RUN dnf upgrade -y && \ - dnf install -y bash \ - git \ - openssh \ - gcc && \ - dnf clean all && rm -rf /var/cache/yum +COPY . . +# Needed musl-dev for github.com/mattn/go-sqlite3 +RUN apk update && apk upgrade && \ + apk add --no-cache bash git openssh gcc musl-dev -COPY ${SOURCE_CODE}/go.mod ./ -COPY ${SOURCE_CODE}/go.sum ./ +RUN GO111MODULE=on go build -o /bin/controller backend/src/crd/controller/scheduledworkflow/*.go +# Check licenses and comply with license terms. +# First, make sure there's no forbidden license. +RUN go-licenses check ./backend/src/crd/controller/scheduledworkflow +RUN go-licenses csv ./backend/src/crd/controller/scheduledworkflow > /tmp/licenses.csv && \ + diff /tmp/licenses.csv backend/third_party_licenses/swf.csv && \ + go-licenses save ./backend/src/crd/controller/scheduledworkflow --save_path /tmp/NOTICES -RUN GO111MODULE=on go mod download +FROM alpine:3.19 -# Copy the source -COPY ${SOURCE_CODE}/ ./ +RUN apk --no-cache add tzdata -RUN GO111MODULE=on go build -o /bin/controller backend/src/crd/controller/scheduledworkflow/*.go +RUN adduser -S appuser +USER appuser -FROM registry.access.redhat.com/ubi8/ubi-minimal:latest WORKDIR /bin COPY --from=builder /bin/controller /bin/controller -RUN chmod +x /bin/controller - -RUN microdnf makecache && \ - microdnf install -y tzdata.noarch +# Copy licenses and notices. +COPY --from=builder /tmp/licenses.csv /third_party/licenses.csv +COPY --from=builder /tmp/NOTICES /third_party/NOTICES ENV NAMESPACE "" ENV LOG_LEVEL info diff --git a/odh_images/Dockerfile b/odh_images/Dockerfile new file mode 100644 index 000000000000..05fab08013b0 --- /dev/null +++ b/odh_images/Dockerfile @@ -0,0 +1,61 @@ +# Copyright 2021-2024 The Kubeflow Authors +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# Build arguments +ARG SOURCE_CODE=. + +FROM registry.access.redhat.com/ubi8/go-toolset:1.21 as builder + +USER root +# Downloading Argo CLI so that the samples are validated +ENV ARGO_VERSION v3.4.17 +RUN curl -sLO https://github.com/argoproj/argo-workflows/releases/download/${ARGO_VERSION}/argo-linux-amd64.gz && \ + gunzip argo-linux-amd64.gz && \ + chmod +x argo-linux-amd64 && \ + mv ./argo-linux-amd64 /usr/local/bin/argo + +RUN dnf install -y cmake clang openssl + +COPY ${SOURCE_CODE}/go.mod ./ +COPY ${SOURCE_CODE}/go.sum ./ + +RUN GO111MODULE=on go mod download + +# Copy the source +COPY ${SOURCE_CODE}/ ./ + +RUN GO111MODULE=on go build -o /bin/apiserver ./backend/src/apiserver/ && \ + dnf clean all + +FROM registry.access.redhat.com/ubi8/ubi-minimal:latest + +WORKDIR /bin + +COPY --from=builder /opt/app-root/src/backend/src/apiserver/config/ /config +COPY --from=builder /bin/apiserver /bin/apiserver + +RUN chmod +x /bin/apiserver + +USER root + +# Adding CA certificate so API server can download pipeline through URL and wget is used for liveness/readiness probe command +RUN microdnf install -y ca-certificates wget + +USER 1001 + +# Expose apiserver port +EXPOSE 8888 + +# Start the apiserver +CMD /bin/apiserver --config=/config --sampleconfig=/config/sample_config.json -logtostderr=true --logLevel=${LOG_LEVEL} diff --git a/odh_images/Dockerfile.cacheserver b/odh_images/Dockerfile.cacheserver new file mode 100644 index 000000000000..4e7d3508bd34 --- /dev/null +++ b/odh_images/Dockerfile.cacheserver @@ -0,0 +1,53 @@ +# Copyright 2021 The Kubeflow Authors +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# Dockerfile for building the source code of cache_server +FROM golang:1.21.7-alpine3.19 as builder + +RUN apk update && apk upgrade && \ + apk add --no-cache bash git openssh gcc musl-dev + +WORKDIR /go/src/github.com/kubeflow/pipelines + +COPY ./go.mod ./ +COPY ./go.sum ./ +COPY ./hack/install-go-licenses.sh ./hack/ + +RUN GO111MODULE=on go mod download +RUN ./hack/install-go-licenses.sh + +COPY . . + +RUN GO111MODULE=on go build -o /bin/cache_server backend/src/cache/*.go + +# Check licenses and comply with license terms. +# First, make sure there's no forbidden license. +RUN go-licenses check ./backend/src/cache +RUN go-licenses csv ./backend/src/cache > /tmp/licenses.csv && \ + diff /tmp/licenses.csv backend/third_party_licenses/cache_server.csv && \ + go-licenses save ./backend/src/cache --save_path /tmp/NOTICES + +FROM alpine:3.19 + +RUN adduser -S appuser +USER appuser + +WORKDIR /bin + +COPY --from=builder /bin/cache_server /bin/cache_server +# Copy licenses and notices. +COPY --from=builder /tmp/licenses.csv /third_party/licenses.csv +COPY --from=builder /tmp/NOTICES /third_party/NOTICES + +ENTRYPOINT [ "/bin/cache_server" ] diff --git a/odh_images/Dockerfile.conformance b/odh_images/Dockerfile.conformance new file mode 100644 index 000000000000..9a2920a580db --- /dev/null +++ b/odh_images/Dockerfile.conformance @@ -0,0 +1,43 @@ +# Copyright 2022 The Kubeflow Authors +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# Dockerfile for building the source code of conformance tests +FROM golang:1.21.7-alpine3.19 as builder + +RUN apk update && apk upgrade && \ + apk add --no-cache bash git openssh gcc musl-dev + +WORKDIR /go/src/github.com/kubeflow/pipelines +COPY . . + +# Compile the test +RUN GO111MODULE=on go test -c -o /test/integration/api-test backend/test/integration/*.go +# Add test resources +ADD backend/test/resources /test/resources + +# Add test script. +COPY backend/conformance/run.sh /test/integration +RUN chmod +x /test/integration/run.sh + +# Create a tar ball for all the test assets, to be copied into the final image. +RUN tar -czvf /test.tar.gz /test + + +FROM alpine:3.8 + +COPY --from=builder /test.tar.gz / +RUN tar -xzvf /test.tar.gz +WORKDIR /test/integration + +ENTRYPOINT [ "./run.sh" ] diff --git a/odh_images/Dockerfile.driver b/odh_images/Dockerfile.driver new file mode 100644 index 000000000000..b2f21f30a895 --- /dev/null +++ b/odh_images/Dockerfile.driver @@ -0,0 +1,48 @@ +# Copyright 2021-2024 The Kubeflow Authors +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# Build arguments +ARG SOURCE_CODE=. + +# Use ubi8/nodejs-14 as base image +FROM registry.access.redhat.com/ubi8/go-toolset:1.21 as builder + + +## Build args to be used at this step +ARG SOURCE_CODE + +## Switch to root as required for some operations +USER root + +COPY ${SOURCE_CODE}/go.mod ./ +COPY ${SOURCE_CODE}/go.sum ./ + +RUN GO111MODULE=on go mod download + +# Copy the source +COPY ${SOURCE_CODE}/ ./ + +RUN GO111MODULE=on CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -tags netgo -ldflags '-extldflags "-static"' -o /bin/driver ./backend/src/v2/cmd/driver/*.go + +FROM registry.access.redhat.com/ubi8/ubi-minimal:latest + +WORKDIR /bin + +COPY --from=builder /bin/driver /bin/driver +RUN chmod +x /bin/driver + +ENTRYPOINT ["/bin/driver"] + +LABEL name="ds-pipelines-driver" \ + summary="DSP Driver" diff --git a/odh_images/Dockerfile.launcher b/odh_images/Dockerfile.launcher new file mode 100644 index 000000000000..e91228c485cf --- /dev/null +++ b/odh_images/Dockerfile.launcher @@ -0,0 +1,50 @@ +# Copyright 2021-2024 The Kubeflow Authors +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# Build arguments +ARG SOURCE_CODE=. +ARG CI_CONTAINER_VERSION="unknown" + + +# Use ubi8/nodejs-14 as base image +FROM registry.access.redhat.com/ubi8/go-toolset:1.21 as builder + + +## Build args to be used at this step +ARG SOURCE_CODE + +## Switch to root as required for some operations +USER root + +COPY ${SOURCE_CODE}/go.mod ./ +COPY ${SOURCE_CODE}/go.sum ./ + +RUN GO111MODULE=on go mod download + +# Copy the source +COPY ${SOURCE_CODE}/ ./ + +RUN GO111MODULE=on CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -tags netgo -ldflags '-extldflags "-static"' -o /bin/launcher-v2 ./backend/src/v2/cmd/launcher-v2/*.go + +FROM registry.access.redhat.com/ubi8/ubi-minimal:latest + +WORKDIR /bin + +COPY --from=builder /bin/launcher-v2 /bin/launcher-v2 +RUN chmod +x /bin/launcher-v2 + +ENTRYPOINT ["/bin/launcher-v2"] + +LABEL name="ds-pipelines-launcher" \ + summary="DSP launcher" diff --git a/odh_images/Dockerfile.persistenceagent b/odh_images/Dockerfile.persistenceagent new file mode 100644 index 000000000000..5fc5231f8040 --- /dev/null +++ b/odh_images/Dockerfile.persistenceagent @@ -0,0 +1,56 @@ +# Copyright 2021 The Kubeflow Authors +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# Build arguments +ARG SOURCE_CODE=. +ARG CI_CONTAINER_VERSION="unknown" + + +# Use ubi8/go-toolset as base image +FROM registry.access.redhat.com/ubi8/go-toolset:1.21 as builder + +## Build args to be used at this step +ARG SOURCE_CODE + +USER root + +RUN dnf install -y bash git openssh gcc + +COPY ${SOURCE_CODE}/go.mod ./ +COPY ${SOURCE_CODE}/go.sum ./ + +RUN GO111MODULE=on go mod download + +# Copy the source +COPY ${SOURCE_CODE}/ ./ + +RUN GO111MODULE=on go build -o /bin/persistence_agent backend/src/agent/persistence/*.go + +FROM registry.access.redhat.com/ubi8/ubi-minimal:latest +WORKDIR /bin + +COPY --from=builder /bin/persistence_agent /bin/persistence_agent + +ENV NAMESPACE "" + +# Set Workflow TTL to 1 day. The way to use a different value for a particular Kubeflow Pipelines deployment is demonstrated in manifests/kustomize/base/pipeline/ml-pipeline-persistenceagent-deployment.yaml +ENV TTL_SECONDS_AFTER_WORKFLOW_FINISH 86400 + +# NUM_WORKERS indicates now many worker goroutines +ENV NUM_WORKERS 2 +ENV LOG_LEVEL info + +ENV EXECUTIONTYPE Workflow + +CMD persistence_agent --logtostderr=true --namespace=${NAMESPACE} --ttlSecondsAfterWorkflowFinish=${TTL_SECONDS_AFTER_WORKFLOW_FINISH} --numWorker ${NUM_WORKERS} --executionType ${EXECUTIONTYPE} --logLevel=${LOG_LEVEL} diff --git a/odh_images/Dockerfile.scheduledworkflow b/odh_images/Dockerfile.scheduledworkflow new file mode 100644 index 000000000000..a71b5d877e7d --- /dev/null +++ b/odh_images/Dockerfile.scheduledworkflow @@ -0,0 +1,57 @@ +# Copyright 2021 The Kubeflow Authors +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# Build arguments +ARG SOURCE_CODE=. + +# Use ubi8/nodejs-14 as base image +FROM registry.access.redhat.com/ubi8/go-toolset:1.21 as builder + +## Build args to be used at this step +ARG SOURCE_CODE + +## Switch to root as required for some operations +USER root + +RUN dnf upgrade -y && \ + dnf install -y bash \ + git \ + openssh \ + gcc && \ + dnf clean all && rm -rf /var/cache/yum + + +COPY ${SOURCE_CODE}/go.mod ./ +COPY ${SOURCE_CODE}/go.sum ./ + +RUN GO111MODULE=on go mod download + +# Copy the source +COPY ${SOURCE_CODE}/ ./ + +RUN GO111MODULE=on go build -o /bin/controller backend/src/crd/controller/scheduledworkflow/*.go + +FROM registry.access.redhat.com/ubi8/ubi-minimal:latest +WORKDIR /bin + +COPY --from=builder /bin/controller /bin/controller +RUN chmod +x /bin/controller + +RUN microdnf makecache && \ + microdnf install -y tzdata.noarch + +ENV NAMESPACE "" +ENV LOG_LEVEL info + +CMD /bin/controller --logtostderr=true --namespace=${NAMESPACE} --logLevel=${LOG_LEVEL} diff --git a/odh_images/Dockerfile.viewercontroller b/odh_images/Dockerfile.viewercontroller new file mode 100644 index 000000000000..73f4fbdb1db4 --- /dev/null +++ b/odh_images/Dockerfile.viewercontroller @@ -0,0 +1,52 @@ +# Copyright 2021 The Kubeflow Authors +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +FROM golang:1.21.7-alpine3.19 as builder + +RUN apk update && apk upgrade +RUN apk add --no-cache git gcc musl-dev + +WORKDIR /src/github.com/kubeflow/pipelines + +COPY ./go.mod ./ +COPY ./go.sum ./ +COPY ./hack/install-go-licenses.sh ./hack/ + +RUN GO111MODULE=on go mod download +RUN ./hack/install-go-licenses.sh + +COPY . . + +RUN GO111MODULE=on go build -o /bin/controller backend/src/crd/controller/viewer/*.go +# Check licenses and comply with license terms. +# First, make sure there's no forbidden license. +RUN go-licenses check ./backend/src/crd/controller/viewer +RUN go-licenses csv ./backend/src/crd/controller/viewer > /tmp/licenses.csv && \ + diff /tmp/licenses.csv backend/third_party_licenses/viewer.csv && \ + go-licenses save ./backend/src/crd/controller/viewer --save_path /tmp/NOTICES + +FROM alpine +WORKDIR /bin + +COPY --from=builder /bin/controller /bin/controller +RUN chmod +x /bin/controller + +# Copy licenses and notices. +COPY --from=builder /tmp/licenses.csv /third_party/licenses.csv +COPY --from=builder /tmp/NOTICES /third_party/NOTICES + +ENV MAX_NUM_VIEWERS "50" +ENV NAMESPACE "kubeflow" + +CMD /bin/controller -logtostderr=true -max_num_viewers=${MAX_NUM_VIEWERS} --namespace=${NAMESPACE} diff --git a/odh_images/Dockerfile.visualization b/odh_images/Dockerfile.visualization new file mode 100644 index 000000000000..f1e0d8d0d13a --- /dev/null +++ b/odh_images/Dockerfile.visualization @@ -0,0 +1,40 @@ +# Copyright 2019-2021 The Kubeflow Authors +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +# This docker file starts server.py (located at src/apiserver/visualization) +# which accepts a post request that resolves to html that depicts a specified +# visualization. More details about this process can be found in the server.py +# and exporter.py files in the directory specified above. + +# This image should be in sync with image in backend/src/apiserver/visualization/update_requirements.sh. +FROM tensorflow/tensorflow:2.10.1 + +RUN apt-get update \ + && apt-get install -y wget curl tar openssl + +RUN curl https://dl.google.com/dl/cloudsdk/release/google-cloud-sdk.tar.gz > /tmp/google-cloud-sdk.tar.gz +RUN mkdir -p /usr/local/gcloud +RUN tar -C /usr/local/gcloud -xf /tmp/google-cloud-sdk.tar.gz +RUN /usr/local/gcloud/google-cloud-sdk/install.sh +ENV PATH $PATH:/usr/local/gcloud/google-cloud-sdk/bin + +WORKDIR /src + +COPY backend/src/apiserver/visualization/requirements.txt /src + +RUN python3 -m pip install -r requirements.txt --no-cache-dir + +COPY backend/src/apiserver/visualization /src + +ENTRYPOINT [ "python3", "server.py" ]