Skip to content

Commit

Permalink
Use docker-container driver
Browse files Browse the repository at this point in the history
Signed-off-by: Sivanantham Chinnaiyan <[email protected]>
  • Loading branch information
sivanantha321 committed Feb 11, 2024
1 parent 306c029 commit 144c534
Show file tree
Hide file tree
Showing 5 changed files with 100 additions and 125 deletions.
34 changes: 10 additions & 24 deletions .github/actions/base-download/action.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,28 +10,14 @@ runs:
path: ./tmp
pattern: ${{ env.BASE_ARTIFACT_PREFIX }}-*
merge-multiple: true
#
# - name: Load base images
# run: |
# pushd ./tmp >> /dev/null
# docker image load -i sflj

# - name: Download controller image
# uses: ishworkh/docker-image-artifact-download@v1
# with:
# image: "kserve/kserve-controller:${{ github.sha }}"
#
# - name: Download agent image
# uses: ishworkh/docker-image-artifact-download@v1
# with:
# image: "kserve/agent:${{ github.sha }}"
#
# - name: Download storage initializer image
# uses: ishworkh/docker-image-artifact-download@v1
# with:
# image: "kserve/storage-initializer:${{ github.sha }}"
#
# - name: Download router image
# uses: ishworkh/docker-image-artifact-download@v1
# with:
# image: "kserve/router:${{ github.sha }}"
- name: Load base images
shell: bash
run: |
ls -l ./tmp
files=$(find ./tmp -maxdepth 1 -type f)
for file in ${pyproject_files[@]};do
echo "Loading image $(basename ${file})"
docker image load -i ${file}
done
rm -rf ./tmp
127 changes: 58 additions & 69 deletions .github/workflows/e2e-test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
DOCKER_IMAGES_PATH: /mnt/docker-images
DOCKER_REPO: kserve
# artifact prefixes for bulk download
PREDICTOR_ARTIFACT_PREFIX: pred
EXPLAINER_ARTIFACT_PREFIX: exp
TRANSFORMER_ARTIFACT_PREFIX: trans
Expand Down Expand Up @@ -42,7 +43,6 @@ env:
SUCCESS_200_ISVC_IMG: success-200-isvc
ERROR_404_ISVC_IMG: error-404-isvc


concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
cancel-in-progress: true
Expand All @@ -53,6 +53,9 @@ jobs:
steps:
- uses: actions/checkout@v3

- name: Setup Docker Buildx
uses: docker/setup-buildx-action@v2

- name: Build KServe images
run: |
sudo mkdir -p ${DOCKER_IMAGES_PATH}
Expand Down Expand Up @@ -117,6 +120,9 @@ jobs:
- name: Free-up disk space
uses: ./.github/actions/free-up-disk-space

- name: Setup Docker Buildx
uses: docker/setup-buildx-action@v2

- name: Build runtime server images
run: |
sudo mkdir -p ${DOCKER_IMAGES_PATH}
Expand Down Expand Up @@ -195,6 +201,9 @@ jobs:
steps:
- uses: actions/checkout@v3

- name: Setup Docker Buildx
uses: docker/setup-buildx-action@v2

- name: Build runtime server images
run: |
sudo mkdir -p ${DOCKER_IMAGES_PATH}
Expand Down Expand Up @@ -228,6 +237,9 @@ jobs:
- name: Free-up disk space
uses: ./.github/actions/free-up-disk-space

- name: Setup Docker Buildx
uses: docker/setup-buildx-action@v2

- name: Build test images needed for graph tests
run: |
sudo mkdir -p ${DOCKER_IMAGES_PATH}
Expand Down Expand Up @@ -292,36 +304,14 @@ jobs:
pattern: ${{ env.PREDICTOR_ARTIFACT_PREFIX }}-*
merge-multiple: true


# - name: Download sklearn server image
# uses: ishworkh/[email protected]
# with:
# image: "kserve/sklearnserver:${{ github.sha }}"
#
# - name: Download xgb server image
# uses: ishworkh/[email protected]
# with:
# image: "kserve/xgbserver:${{ github.sha }}"
#
# - name: Download lgb server image
# uses: ishworkh/[email protected]
# with:
# image: "kserve/lgbserver:${{ github.sha }}"
#
# - name: Download pmml image
# uses: ishworkh/[email protected]
# with:
# image: "kserve/pmmlserver:${{ github.sha }}"
#
# - name: Download paddle image
# uses: ishworkh/[email protected]
# with:
# image: "kserve/paddleserver:${{ github.sha }}"
#
# - name: Download custom model grpc image
# uses: ishworkh/[email protected]
# with:
# image: "kserve/custom-model-grpc:${{ github.sha }}"
- name: Load predictor images
run: |
files=$(find ./tmp -maxdepth 1 -type f)
for file in ${pyproject_files[@]};do
echo "Loading image $(basename ${file})"
docker image load -i ${file}
done
rm -rf ./tmp
- name: Install Poetry and version plugin
run: ./test/scripts/gh-actions/setup-poetry.sh
Expand Down Expand Up @@ -371,38 +361,29 @@ jobs:
- name: Download sklearn server image
uses: actions/download-artifact@v4
with:
name: ${{ env.PREDICTOR_ARTIFACT_PREFIX }}-${{ env.SKLEARN_IMG }}
name: ${{ env.PREDICTOR_ARTIFACT_PREFIX }}-${{ env.SKLEARN_IMG }}-${{ github.sha }}
path: ./tmp

- name: Download custom model grpc image
uses: ishworkh/docker-image-artifact-download@v1
uses: actions/download-artifact@v4
with:
image: "kserve/custom-model-grpc:${{ github.sha }}"

# - name: Download transformer image
# uses: ishworkh/[email protected]
# with:
# image: "kserve/image-transformer:${{ github.sha }}"
#
# - name: Download custom transformer grpc image
# uses: ishworkh/[email protected]
# with:
# image: "kserve/custom-image-transformer-grpc:${{ github.sha }}"
name: ${{ env.PREDICTOR_ARTIFACT_PREFIX }}-${{ env.CUSTOM_MODEL_GRPC_IMG }}-${{ github.sha }}
path: ./tmp

- name: Download xgb server image
uses: ishworkh/container-image-artifact[email protected]
uses: actions/download-artifact@v4
with:
image: "kserve/xgbserver:${{ github.sha }}"

# - name: Download alibi image
# uses: ishworkh/[email protected]
# with:
# image: "kserve/alibi-explainer:${{ github.sha }}"
#
# - name: Download art explainer image
# uses: ishworkh/container-image[email protected]
# with:
# image: "kserve/art-explainer:${{ github.sha }}"
name: ${{ env.PREDICTOR_ARTIFACT_PREFIX }}-${{ env.XGB_IMG }}-${{ github.sha }}
path: ./tmp

- name: Load docker images
run: |
files=$(find ./tmp -maxdepth 1 -type f)
for file in ${pyproject_files[@]};do
echo "Loading image $(basename ${file})"
docker image load -i ${file}
done
rm -rf ./tmp
- name: Install Poetry and version plugin
run: ./test/scripts/gh-actions/setup-poetry.sh
Expand Down Expand Up @@ -458,25 +439,33 @@ jobs:
- name: KServe dependency setup
uses: ./.github/actions/kserve-dep-setup

- name: Download sklearn server image
uses: ishworkh/container-image-artifact[email protected]
- name: Download graph artifacts
uses: actions/download-artifact@v4
with:
image: "kserve/sklearnserver:${{ github.sha }}"
path: ./tmp
pattern: ${{ env.GRAPH_ARTIFACT_PREFIX }}-*
merge-multiple: true

- name: Download xgb server image
uses: ishworkh/docker-image-artifact-download@v1
- name: Download sklearn server image
uses: actions/download-artifact@v4
with:
image: "kserve/xgbserver:${{ github.sha }}"
name: ${{ env.PREDICTOR_ARTIFACT_PREFIX }}-${{ env.SKLEARN_IMG }}-${{ github.sha }}
path: ./tmp

- name: Download success_200_isvc predictor image
uses: ishworkh/container-image-artifact[email protected]
- name: Download xgb server image
uses: actions/download-artifact@v4
with:
image: "kserve/success-200-isvc:${{ github.sha }}"
name: ${{ env.PREDICTOR_ARTIFACT_PREFIX }}-${{ env.XGB_IMG }}-${{ github.sha }}
path: ./tmp

- name: Download error_404_isvc predictor image
uses: ishworkh/[email protected]
with:
image: "kserve/error-404-isvc:${{ github.sha }}"
- name: Load docker images
run: |
files=$(find ./tmp -maxdepth 1 -type f)
for file in ${pyproject_files[@]};do
echo "Loading image $(basename ${file})"
docker image load -i ${file}
done
rm -rf ./tmp
- name: Install Poetry and version plugin
run: ./test/scripts/gh-actions/setup-poetry.sh
Expand Down
8 changes: 4 additions & 4 deletions test/scripts/gh-actions/build-graph-tests-images.sh
Original file line number Diff line number Diff line change
Expand Up @@ -26,12 +26,12 @@ ERROR_404_ISVC_IMG_TAG=${DOCKER_REPO}/${ERROR_404_ISVC_IMG}:${GITHUB_SHA}

pushd python >/dev/null
echo "Building success_200_isvc image"
docker buildx build -t "${SUCCESS_200_ISVC_IMG_TAG}" -f success_200_isvc.Dockerfile .
docker image save -o "${DOCKER_IMAGES_PATH}/${SUCCESS_200_ISVC_IMG}-${GITHUB_SHA}" "${SUCCESS_200_ISVC_IMG_TAG}"
docker buildx build -t "${SUCCESS_200_ISVC_IMG_TAG}" -f success_200_isvc.Dockerfile \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${SUCCESS_200_ISVC_IMG}-${GITHUB_SHA}",compression-level=0 .
echo "Done building success_200_isvc image"
echo "Building error_404_isvc image"
docker buildx build -t "${ERROR_404_ISVC_IMG_TAG}" -f error_404_isvc.Dockerfile .
docker image save -o "${DOCKER_IMAGES_PATH}/${ERROR_404_ISVC_IMG}-${GITHUB_SHA}" "${ERROR_404_ISVC_IMG_TAG}"
docker buildx build -t "${ERROR_404_ISVC_IMG_TAG}" -f error_404_isvc.Dockerfile \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${ERROR_404_ISVC_IMG}-${GITHUB_SHA}",compression-level=0 .
echo "Done building error_404_isvc image"
popd
echo "Done building images"
Expand Down
16 changes: 8 additions & 8 deletions test/scripts/gh-actions/build-images.sh
Original file line number Diff line number Diff line change
Expand Up @@ -29,21 +29,21 @@ AGENT_IMG_TAG=${DOCKER_REPO}/${AGENT_IMG}:${GITHUB_SHA}
ROUTER_IMG_TAG=${DOCKER_REPO}/${ROUTER_IMG}:${GITHUB_SHA}

echo "Building Kserve controller image"
docker buildx build . -t "${CONTROLLER_IMG_TAG}"
docker image save -o "${DOCKER_IMAGES_PATH}/${CONTROLLER_IMG}-${GITHUB_SHA}" "${CONTROLLER_IMG_TAG}"
docker buildx build . -t "${CONTROLLER_IMG_TAG}" \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${CONTROLLER_IMG}-${GITHUB_SHA}",compression-level=0

echo "Building agent image"
docker buildx build -f agent.Dockerfile . -t "${AGENT_IMG_TAG}"
docker image save -o "${DOCKER_IMAGES_PATH}/${AGENT_IMG}-${GITHUB_SHA}" "${AGENT_IMG_TAG}"
docker buildx build -f agent.Dockerfile . -t "${AGENT_IMG_TAG}" \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${AGENT_IMG}-${GITHUB_SHA}",compression-level=0

echo "Building router image"
docker buildx build -f router.Dockerfile . -t "${ROUTER_IMG_TAG}"
docker image save -o "${DOCKER_IMAGES_PATH}/${ROUTER_IMG}-${GITHUB_SHA}" "${ROUTER_IMG_TAG}"
docker buildx build -f router.Dockerfile . -t "${ROUTER_IMG_TAG}" \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${ROUTER_IMG}-${GITHUB_SHA}",compression-level=0

pushd python >/dev/null
echo "Building storage initializer"
docker buildx build -t "${STORAGE_INIT_IMG_TAG}" -f storage-initializer.Dockerfile .
docker image save -o "${DOCKER_IMAGES_PATH}/${STORAGE_INIT_IMG}-${GITHUB_SHA}" "${STORAGE_INIT_IMG_TAG}"
docker buildx build -f storage-initializer.Dockerfile . -t "${STORAGE_INIT_IMG_TAG}" \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${STORAGE_INIT_IMG}-${GITHUB_SHA}",compression-level=0
popd

echo "Done building images"
40 changes: 20 additions & 20 deletions test/scripts/gh-actions/build-server-runtimes.sh
Original file line number Diff line number Diff line change
Expand Up @@ -42,41 +42,41 @@ types=("$1")
pushd python >/dev/null
if [[ " ${types[*]} " =~ "predictor" ]]; then
echo "Building Sklearn image"
docker buildx build -t "${SKLEARN_IMG_TAG}" -f sklearn.Dockerfile .
docker image save -o "${DOCKER_IMAGES_PATH}/${SKLEARN_IMG}-${GITHUB_SHA}" "${SKLEARN_IMG_TAG}"
docker buildx build -t "${SKLEARN_IMG_TAG}" -f sklearn.Dockerfile \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${SKLEARN_IMG}-${GITHUB_SHA}",compression-level=0 .
echo "Building XGB image"
docker buildx build -t "${XGB_IMG_TAG}" -f xgb.Dockerfile .
docker image save -o "${DOCKER_IMAGES_PATH}/${XGB_IMG}-${GITHUB_SHA}" "${XGB_IMG_TAG}"
docker buildx build -t "${XGB_IMG_TAG}" -f xgb.Dockerfile \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${XGB_IMG}-${GITHUB_SHA}",compression-level=0 .
echo "Building LGB image"
docker buildx build -t "${LGB_IMG_TAG}" -f lgb.Dockerfile .
docker image save -o "${DOCKER_IMAGES_PATH}/${LGB_IMG}-${GITHUB_SHA}" "${LGB_IMG_TAG}"
docker buildx build -t "${LGB_IMG_TAG}" -f lgb.Dockerfile \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${LGB_IMG}-${GITHUB_SHA}",compression-level=0 .
echo "Building PMML image"
docker buildx build -t "${PMML_IMG_TAG}" -f pmml.Dockerfile .
docker image save -o "${DOCKER_IMAGES_PATH}/${PMML_IMG}-${GITHUB_SHA}" "${PMML_IMG_TAG}"
docker buildx build -t "${PMML_IMG_TAG}" -f pmml.Dockerfile \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${PMML_IMG}-${GITHUB_SHA}",compression-level=0 .
echo "Building Paddle image"
docker buildx build -t "${PADDLE_IMG_TAG}" -f paddle.Dockerfile .
docker image save -o "${DOCKER_IMAGES_PATH}/${PADDLE_IMG}-${GITHUB_SHA}" "${PADDLE_IMG_TAG}"
docker buildx build -t "${PADDLE_IMG_TAG}" -f paddle.Dockerfile \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${PADDLE_IMG}-${GITHUB_SHA}",compression-level=0 .
echo "Building Custom model gRPC image"
docker buildx build -t "${CUSTOM_MODEL_GRPC_IMG_TAG}" -f custom_model_grpc.Dockerfile .
docker image save -o "${DOCKER_IMAGES_PATH}/${CUSTOM_MODEL_GRPC_IMG}-${GITHUB_SHA}" "${CUSTOM_MODEL_GRPC_IMG_TAG}"
docker buildx build -t "${CUSTOM_MODEL_GRPC_IMG_TAG}" -f custom_model_grpc.Dockerfile \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${CUSTOM_MODEL_GRPC_IMG}-${GITHUB_SHA}",compression-level=0 .
echo "Building image transformer gRPC image"
docker buildx build -t "${CUSTOM_TRANSFORMER_GRPC_IMG_TAG}" -f custom_transformer_grpc.Dockerfile .
docker image save -o "${DOCKER_IMAGES_PATH}/${CUSTOM_TRANSFORMER_GRPC_IMG}-${GITHUB_SHA}" "${CUSTOM_TRANSFORMER_GRPC_IMG_TAG}"
docker buildx build -t "${CUSTOM_TRANSFORMER_GRPC_IMG_TAG}" -f custom_transformer_grpc.Dockerfile \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${CUSTOM_TRANSFORMER_GRPC_IMG}-${GITHUB_SHA}",compression-level=0 .
fi

if [[ " ${types[*]} " =~ "explainer" ]]; then
echo "Building Alibi image"
docker buildx build -t "${ALIBI_IMG_TAG}" -f alibiexplainer.Dockerfile .
docker save -o "${DOCKER_IMAGES_PATH}/${ALIBI_IMG}-${GITHUB_SHA}" "${ALIBI_IMG_TAG}"
docker buildx build -t "${ALIBI_IMG_TAG}" -f alibiexplainer.Dockerfile \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${ALIBI_IMG}-${GITHUB_SHA}",compression-level=0 .
echo "Building ART explainer image"
docker buildx build -t "${ART_IMG_TAG}" -f artexplainer.Dockerfile .
docker save -o "${DOCKER_IMAGES_PATH}/${ART_IMG}-${GITHUB_SHA}" "${ART_IMG_TAG}"
docker buildx build -t "${ART_IMG_TAG}" -f artexplainer.Dockerfile \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${ART_IMG}-${GITHUB_SHA}",compression-level=0 .
fi

if [[ " ${types[*]} " =~ "transformer" ]]; then
echo "Building Image transformer image"
docker buildx build -t "${IMAGE_TRANSFORMER_IMG_TAG}" -f custom_transformer.Dockerfile .
docker save -o "${DOCKER_IMAGES_PATH}/${IMAGE_TRANSFORMER_IMG}-${GITHUB_SHA}" "${IMAGE_TRANSFORMER_IMG_TAG}"
docker buildx build -t "${IMAGE_TRANSFORMER_IMG_TAG}" -f custom_transformer.Dockerfile \
-o type=docker,dest="${DOCKER_IMAGES_PATH}/${IMAGE_TRANSFORMER_IMG}-${GITHUB_SHA}",compression-level=0 .
fi

popd
Expand Down

0 comments on commit 144c534

Please sign in to comment.