Automated cherry pick of #1621 #1627 [IBM] Add kfp-tekton deployment and update IBM stacks (#1628)

* add kfp-tekton deployment and update IBM stacks

* update owner file

* pin ibm v1.2 manifests

* Apply suggestions from code review

Co-authored-by: Animesh Singh <singhan@us.ibm.com>

Co-authored-by: Animesh Singh <singhan@us.ibm.com>
This commit is contained in:
Tommy Li 2020-11-10 12:24:22 -08:00 committed by GitHub
parent 92d68285b2
commit da3fb83f86
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
386 changed files with 8810 additions and 242 deletions

View File

@ -26,16 +26,19 @@ spec:
name: manifests
path: stacks/ibm/application/add-anonymous-user-filter
name: add-anonymous-user-filter
# application
- kustomizeConfig:
repoRef:
name: manifests
path: application/v3
name: application
# bootstrap
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/bootstrap
name: bootstrap
# cert-manager
- kustomizeConfig:
repoRef:
name: manifests
@ -51,22 +54,76 @@ spec:
name: manifests
path: stacks/ibm/application/cert-manager
name: cert-manager
# Install Kubeflow applications.
# Tekton
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm
path: tektoncd/tektoncd-install/base
name: tektoncd-install
- kustomizeConfig:
repoRef:
name: manifests
path: tektoncd/tektoncd-dashboard/base
name: tektoncd-dashboard
# Kubeflow components
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/admission-webhook
name: admission-webhook
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/profile-control-plane
name: kubeflow-apps
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/metadata
name: metadata
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/katib
name: katib
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/kfp-tekton
name: kfp-tekton
# Default on IBM Cloud is Kubeflow Pipelines with Tekton. Switch the above kfp-tekton to
# the below applications if you want to
# run Kubeflow Pipelines with Argo
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/argo
# name: argo
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/kfp-argo
# name: kfp-argo
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/notebooks
name: notebooks
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/pytorch-job
name: pytorch-job
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/tf-job
name: tf-job
- kustomizeConfig:
repoRef:
name: manifests
path: metacontroller/base
name: metacontroller
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/spark-operator
name: spark-operator
- kustomizeConfig:
repoRef:
name: manifests
@ -84,11 +141,17 @@ spec:
name: manifests
path: stacks/ibm/application/spartakus
name: spartakus
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/tensorboard
name: tensorboard
# Optional applications: Uncomment the following lines if you want to run Seldon or Spark on IBM Cloud.
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/seldon-core-operator
# name: seldon-core-operator
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/spark-operator
# name: spark-operator
repos:
- name: manifests
uri: https://github.com/kubeflow/manifests/archive/v1.2-branch.tar.gz

View File

@ -26,16 +26,19 @@ spec:
name: manifests
path: stacks/ibm/application/add-anonymous-user-filter
name: add-anonymous-user-filter
# application
- kustomizeConfig:
repoRef:
name: manifests
path: application/v3
name: application
# bootstrap
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/bootstrap
name: bootstrap
# cert-manager
- kustomizeConfig:
repoRef:
name: manifests
@ -51,22 +54,76 @@ spec:
name: manifests
path: stacks/ibm/application/cert-manager
name: cert-manager
# Install Kubeflow applications.
# Tekton
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm
path: tektoncd/tektoncd-install/base
name: tektoncd-install
- kustomizeConfig:
repoRef:
name: manifests
path: tektoncd/tektoncd-dashboard/base
name: tektoncd-dashboard
# Kubeflow components
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/admission-webhook
name: admission-webhook
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/profile-control-plane
name: kubeflow-apps
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/metadata
name: metadata
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/katib
name: katib
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/kfp-tekton
name: kfp-tekton
# Default on IBM Cloud is Kubeflow Pipelines with Tekton. Switch the above kfp-tekton to
# the below applications if you want to
# run Kubeflow Pipelines with Argo
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/argo
# name: argo
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/kfp-argo
# name: kfp-argo
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/notebooks
name: notebooks
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/pytorch-job
name: pytorch-job
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/tf-job
name: tf-job
- kustomizeConfig:
repoRef:
name: manifests
path: metacontroller/base
name: metacontroller
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/spark-operator
name: spark-operator
- kustomizeConfig:
repoRef:
name: manifests
@ -84,6 +141,17 @@ spec:
name: manifests
path: stacks/ibm/application/spartakus
name: spartakus
# Optional applications: Uncomment the following lines if you want to run Seldon or Spark on IBM Cloud.
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/seldon-core-operator
# name: seldon-core-operator
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/spark-operator
# name: spark-operator
repos:
- name: manifests
uri: https://github.com/kubeflow/manifests/archive/master.tar.gz

View File

@ -1,98 +0,0 @@
apiVersion: kfdef.apps.kubeflow.org/v1
kind: KfDef
metadata:
namespace: kubeflow
spec:
applications:
- kustomizeConfig:
repoRef:
name: manifests
path: namespaces/base
name: namespaces
# Install istio in a different namespace: istio-system
# Remove this application if istio is already installed
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/istio-1-3-1-stack
name: istio-stack
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/cluster-local-gateway-1-3-1
name: cluster-local-gateway
- kustomizeConfig:
repoRef:
name: manifests
path: istio/istio/base
name: istio
- kustomizeConfig:
repoRef:
name: manifests
path: application/v3
name: application
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/bootstrap
name: bootstrap
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/cert-manager-crds
name: cert-manager-crds
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/cert-manager-kube-system-resources
name: cert-manager-kube-system-resources
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/cert-manager
name: cert-manager
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/oidc-authservice
name: oidc-authservice
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/dex-auth
name: dex-auth
- kustomizeConfig:
repoRef:
name: manifests
path: metacontroller/base
name: metacontroller
# Install kubeflow applications.
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/multi-user
name: kubeflow-apps
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/spark-operator
name: spark-operator
- kustomizeConfig:
repoRef:
name: manifests
path: knative/installs/generic
name: knative
- kustomizeConfig:
repoRef:
name: manifests
path: kfserving/installs/generic
name: kfserving
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/spartakus
name: spartakus
repos:
- name: manifests
uri: https://github.com/kubeflow/manifests/archive/v1.2-branch.tar.gz
version: v1.2-branch

View File

@ -4,6 +4,11 @@ metadata:
namespace: kubeflow
spec:
applications:
- kustomizeConfig:
repoRef:
name: manifests
path: namespaces/base
name: namespaces
# Install istio in a different namespace: istio-system
# Remove this application if istio is already installed
- kustomizeConfig:
@ -19,26 +24,18 @@ spec:
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/istio
path: istio/istio/base
name: istio
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/add-anonymous-user-filter
name: add-anonymous-user-filter
# application
- kustomizeConfig:
repoRef:
name: manifests
path: application/v3
name: application
# bootstrap
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/bootstrap
name: bootstrap
# cert-manager
- kustomizeConfig:
repoRef:
name: manifests
@ -54,7 +51,26 @@ spec:
name: manifests
path: stacks/ibm/application/cert-manager
name: cert-manager
# Kubeflow components
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/oidc-authservice-appid
name: oidc-authservice
- kustomizeConfig:
repoRef:
name: manifests
path: metacontroller/base
name: metacontroller
- kustomizeConfig:
repoRef:
name: manifests
path: tektoncd/tektoncd-install/base
name: tektoncd-install
- kustomizeConfig:
repoRef:
name: manifests
path: tektoncd/tektoncd-dashboard/base
name: tektoncd-dashboard
- kustomizeConfig:
repoRef:
name: manifests
@ -70,11 +86,6 @@ spec:
name: manifests
path: stacks/ibm/application/metadata
name: metadata
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/argo
name: argo
- kustomizeConfig:
repoRef:
name: manifests
@ -83,8 +94,21 @@ spec:
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/pipelines
name: pipelines
path: stacks/ibm/application/kfp-tekton-multi-user
name: kfp-tekton-multi-user
# Switch the above kfp-tekton to
# the below applications if you want to
# run KFP with Argo
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/argo
# name: argo
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/kfp-argo-multi-user
# name: kfp-argo-multi-user
- kustomizeConfig:
repoRef:
name: manifests
@ -100,22 +124,6 @@ spec:
name: manifests
path: stacks/ibm/application/tf-job
name: tf-job
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/seldon-core-operator
name: seldon-core-operator
# other applications
- kustomizeConfig:
repoRef:
name: manifests
path: metacontroller/base
name: metacontroller
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/spark-operator
name: spark-operator
- kustomizeConfig:
repoRef:
name: manifests
@ -126,14 +134,23 @@ spec:
name: manifests
path: kfserving/installs/generic
name: kfserving
# Spartakus is a separate applications so that kfctl can remove it
# to disable usage reporting
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/spartakus
name: spartakus
# Optional applications
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/seldon-core-operator
# name: seldon-core-operator
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/spark-operator
# name: spark-operator
repos:
- name: manifests
uri: https://github.com/kubeflow/manifests/archive/master.tar.gz
version: master
uri: https://github.com/kubeflow/manifests/archive/v1.2-branch.tar.gz
version: v1.2-branch

View File

@ -61,17 +61,69 @@ spec:
name: manifests
path: metacontroller/base
name: metacontroller
# Install kubeflow applications.
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/multi-user
path: tektoncd/tektoncd-install/base
name: tektoncd-install
- kustomizeConfig:
repoRef:
name: manifests
path: tektoncd/tektoncd-dashboard/base
name: tektoncd-dashboard
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/admission-webhook
name: admission-webhook
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/profile-control-plane
name: kubeflow-apps
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/spark-operator
name: spark-operator
path: stacks/ibm/application/metadata
name: metadata
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/katib
name: katib
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/kfp-tekton-multi-user
name: kfp-tekton-multi-user
# Switch the above kfp-tekton to
# the below applications if you want to
# run KFP with Argo
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/argo
# name: argo
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/kfp-argo-multi-user
# name: kfp-argo-multi-user
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/notebooks
name: notebooks
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/pytorch-job
name: pytorch-job
- kustomizeConfig:
repoRef:
name: manifests
path: stacks/ibm/application/tf-job
name: tf-job
- kustomizeConfig:
repoRef:
name: manifests
@ -87,6 +139,17 @@ spec:
name: manifests
path: stacks/ibm/application/spartakus
name: spartakus
# Optional applications
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/seldon-core-operator
# name: seldon-core-operator
# - kustomizeConfig:
# repoRef:
# name: manifests
# path: stacks/ibm/application/spark-operator
# name: spark-operator
repos:
- name: manifests
uri: https://github.com/kubeflow/manifests/archive/master.tar.gz

View File

@ -0,0 +1,42 @@
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
namespace: kubeflow
commonLabels:
app.kubernetes.io/name: kubeflow-pipelines
app.kubernetes.io/component: ml-pipeline
resources:
- ../multi-user
- ../tekton/kfp-tekton/kfp-pipeline-config.yaml
patchesStrategicMerge:
- metadata-writer-clusterrole.yaml
- ml-pipeline-apiserver-clusterrole.yaml
- ml-pipeline-persistenceagent-clusterrole.yaml
- ml-pipeline-ui-clusterrole.yaml
- scheduled-workflow-clusterrole.yaml
- ../tekton/kfp-tekton/ml-pipeline-deployment-patch.yaml
- ../tekton/kfp-tekton/metadata-writer-deployment-patch.yaml
configMapGenerator:
- name: kubeflow-pipelines-profile-controller-code
behavior: replace
files:
- sync.py
images:
- name: mysql
newTag: "5.6"
- name: minio/minio
newTag: RELEASE.2018-02-09T22-40-05Z
- name: gcr.io/ml-pipeline/api-server
newName: docker.io/aipipeline/api-server
newTag: 0.4.0
- name: gcr.io/ml-pipeline/persistenceagent
newName: docker.io/aipipeline/persistenceagent
newTag: 0.4.0
- name: gcr.io/ml-pipeline/frontend
newName: docker.io/aipipeline/frontend
newTag: 0.4.0
- name: gcr.io/ml-pipeline/metadata-writer
newName: docker.io/aipipeline/metadata-writer
newTag: 0.4.0
- name: gcr.io/ml-pipeline/scheduledworkflow
newName: docker.io/aipipeline/scheduledworkflow
newTag: 0.4.0

View File

@ -0,0 +1,43 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: kubeflow-pipelines-metadata-writer-role
rules:
- apiGroups:
- ""
resources:
- pods
verbs:
- get
- list
- watch
- update
- patch
- apiGroups:
- ""
resources:
- configmaps
verbs:
- get
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- get
- list
- watch
- update
- patch
- apiGroups:
- tekton.dev
resources:
- pipelineruns
- taskruns
- conditions
verbs:
- get
- list
- watch
- update
- patch

View File

@ -0,0 +1,50 @@
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRole
metadata:
name: ml-pipeline
rules:
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- create
- get
- list
- watch
- update
- patch
- delete
- apiGroups:
- kubeflow.org
resources:
- scheduledworkflows
verbs:
- create
- get
- list
- update
- patch
- delete
- apiGroups:
- ""
resources:
- pods
- pods/log
verbs:
- get
- delete
- apiGroups:
- tekton.dev
resources:
- pipelineruns
- taskruns
- conditions
verbs:
- create
- get
- list
- watch
- update
- patch
- delete

View File

@ -0,0 +1,31 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: ml-pipeline-persistenceagent-role
rules:
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- get
- list
- watch
- apiGroups:
- kubeflow.org
resources:
- scheduledworkflows
verbs:
- get
- list
- watch
- apiGroups:
- tekton.dev
resources:
- pipelineruns
- taskruns
- conditions
verbs:
- get
- list
- watch

View File

@ -0,0 +1,51 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: ml-pipeline-ui
rules:
- apiGroups:
- ""
resources:
- pods
- pods/log
verbs:
- get
- apiGroups:
- ""
resources:
- events
verbs:
- list
- apiGroups:
- ""
resources:
- secrets
verbs:
- get
- list
- apiGroups:
- "kubeflow.org"
resources:
- viewers
verbs:
- create
- get
- list
- watch
- delete
- apiGroups:
- "argoproj.io"
resources:
- workflows
verbs:
- get
- list
- apiGroups:
- tekton.dev
resources:
- pipelineruns
- taskruns
- conditions
verbs:
- get
- list

View File

@ -0,0 +1,50 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
name: ml-pipeline-scheduledworkflow-role
rules:
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- create
- get
- list
- watch
- update
- patch
- delete
- apiGroups:
- kubeflow.org
resources:
- scheduledworkflows
verbs:
- create
- get
- list
- watch
- update
- patch
- delete
- apiGroups:
- ''
resources:
- events
verbs:
- create
- patch
- apiGroups:
- tekton.dev
resources:
- pipelineruns
- taskruns
- conditions
verbs:
- create
- get
- list
- watch
- update
- patch
- delete

View File

@ -0,0 +1,313 @@
# Copyright 2020 Google LLC
#
# 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 http.server import BaseHTTPRequestHandler, HTTPServer
import json
import os
import base64
kfp_version = os.environ["KFP_VERSION"]
disable_istio_sidecar = os.environ.get("DISABLE_ISTIO_SIDECAR") == "true"
mlpipeline_minio_access_key = base64.b64encode(
bytes(os.environ.get("MINIO_ACCESS_KEY"), 'utf-8')).decode('utf-8')
mlpipeline_minio_secret_key = base64.b64encode(
bytes(os.environ.get("MINIO_SECRET_KEY"), 'utf-8')).decode('utf-8')
class Controller(BaseHTTPRequestHandler):
def sync(self, parent, children):
# HACK: Currently using serving.kubeflow.org/inferenceservice to identify
# kubeflow user namespaces.
# TODO: let Kubeflow profile controller add a pipeline specific label to
# user namespaces and use that label instead.
pipeline_enabled = parent.get("metadata", {}).get(
"labels", {}).get("serving.kubeflow.org/inferenceservice")
if not pipeline_enabled:
return {"status": {}, "children": []}
# Compute status based on observed state.
desired_status = {
"kubeflow-pipelines-ready": \
len(children["Secret.v1"]) == 1 and \
len(children["ConfigMap.v1"]) == 1 and \
len(children["Deployment.apps/v1"]) == 2 and \
len(children["Service.v1"]) == 2 and \
len(children["DestinationRule.networking.istio.io/v1alpha3"]) == 1 and \
len(children["ServiceRole.rbac.istio.io/v1alpha1"]) == 1 and \
len(children["ServiceRoleBinding.rbac.istio.io/v1alpha1"]) == 1 and \
"True" or "False"
}
# Generate the desired child object(s).
# parent is a namespace
namespace = parent.get("metadata", {}).get("name")
desired_resources = [
{
"apiVersion": "v1",
"kind": "ConfigMap",
"metadata": {
"name": "metadata-grpc-configmap",
"namespace": namespace,
},
"data": {
"METADATA_GRPC_SERVICE_HOST":
"metadata-grpc-service.kubeflow",
"METADATA_GRPC_SERVICE_PORT": "8080",
},
},
# Visualization server related manifests below
{
"apiVersion": "apps/v1",
"kind": "Deployment",
"metadata": {
"labels": {
"app": "ml-pipeline-visualizationserver"
},
"name": "ml-pipeline-visualizationserver",
"namespace": namespace,
},
"spec": {
"selector": {
"matchLabels": {
"app": "ml-pipeline-visualizationserver"
},
},
"template": {
"metadata": {
"labels": {
"app": "ml-pipeline-visualizationserver"
},
"annotations": disable_istio_sidecar and {
"sidecar.istio.io/inject": "false"
} or {},
},
"spec": {
"containers": [{
"image":
"gcr.io/ml-pipeline/visualization-server:" +
kfp_version,
"imagePullPolicy":
"IfNotPresent",
"name":
"ml-pipeline-visualizationserver",
"ports": [{
"containerPort": 8888
}],
}],
"serviceAccountName":
"default-editor",
},
},
},
},
{
"apiVersion": "networking.istio.io/v1alpha3",
"kind": "DestinationRule",
"metadata": {
"name": "ml-pipeline-visualizationserver",
"namespace": namespace,
},
"spec": {
"host": "ml-pipeline-visualizationserver",
"trafficPolicy": {
"tls": {
"mode": "ISTIO_MUTUAL"
}
}
}
},
{
"apiVersion": "rbac.istio.io/v1alpha1",
"kind": "ServiceRole",
"metadata": {
"name": "ml-pipeline-visualizationserver",
"namespace": namespace,
},
"spec": {
"rules": [{
"services": ["ml-pipeline-visualizationserver.*"]
}]
}
},
{
"apiVersion": "rbac.istio.io/v1alpha1",
"kind": "ServiceRoleBinding",
"metadata": {
"name": "ml-pipeline-visualizationserver",
"namespace": namespace,
},
"spec": {
"subjects": [{
"properties": {
"source.principal":
"cluster.local/ns/kubeflow/sa/ml-pipeline"
}
}],
"roleRef": {
"kind": "ServiceRole",
"name": "ml-pipeline-visualizationserver"
}
}
},
{
"apiVersion": "v1",
"kind": "Service",
"metadata": {
"name": "ml-pipeline-visualizationserver",
"namespace": namespace,
},
"spec": {
"ports": [{
"name": "http",
"port": 8888,
"protocol": "TCP",
"targetPort": 8888,
}],
"selector": {
"app": "ml-pipeline-visualizationserver",
},
},
},
# Artifact fetcher related resources below.
{
"apiVersion": "apps/v1",
"kind": "Deployment",
"metadata": {
"labels": {
"app": "ml-pipeline-ui-artifact"
},
"name": "ml-pipeline-ui-artifact",
"namespace": namespace,
},
"spec": {
"selector": {
"matchLabels": {
"app": "ml-pipeline-ui-artifact"
}
},
"template": {
"metadata": {
"labels": {
"app": "ml-pipeline-ui-artifact"
},
"annotations": disable_istio_sidecar and {
"sidecar.istio.io/inject": "false"
} or {},
},
"spec": {
"containers": [{
"name":
"ml-pipeline-ui-artifact",
"image":
"gcr.io/ml-pipeline/frontend:" + kfp_version,
"imagePullPolicy":
"IfNotPresent",
"ports": [{
"containerPort": 3000
}]
}],
"serviceAccountName":
"default-editor"
}
}
}
},
{
"apiVersion": "v1",
"kind": "Service",
"metadata": {
"name": "ml-pipeline-ui-artifact",
"namespace": namespace,
"labels": {
"app": "ml-pipeline-ui-artifact"
}
},
"spec": {
"ports": [{
"name":
"http", # name is required to let istio understand request protocol
"port": 80,
"protocol": "TCP",
"targetPort": 3000
}],
"selector": {
"app": "ml-pipeline-ui-artifact"
}
}
},
{
"apiVersion": "tekton.dev/v1alpha1",
"kind": "Condition",
"metadata": {
"name": "super-condition",
"namespace": namespace,
},
"spec": {
"check": {
"image": "python:alpine3.6",
"script": ("python -c 'import sys\ninput1=str.rstrip(sys.argv[1])\n"
"input2=str.rstrip(sys.argv[2])\ntry:\n input1=int(input1)\n"
" input2=int(input2)\nexcept:\n input1=str(input1)\nsys.exit(0)"
" if (input1 $(params.operator) input2) else sys.exit(1)' "
"'$(params.operand1)' '$(params.operand2)'")
},
"params": [
{
"name": "operand1",
"type": "string"
},
{
"name": "operand2",
"type": "string"
},
{
"name": "operator",
"type": "string"
}
]
}
},
]
print('Received request:', parent)
print('Desired resources except secrets:', desired_resources)
# Moved after the print argument because this is sensitive data.
desired_resources.append({
"apiVersion": "v1",
"kind": "Secret",
"metadata": {
"name": "mlpipeline-minio-artifact",
"namespace": namespace,
},
"data": {
"accesskey": mlpipeline_minio_access_key,
"secretkey": mlpipeline_minio_secret_key,
},
})
return {"status": desired_status, "children": desired_resources}
def do_POST(self):
# Serve the sync() function as a JSON webhook.
observed = json.loads(
self.rfile.read(int(self.headers.get("content-length"))))
desired = self.sync(observed["parent"], observed["children"])
self.send_response(200)
self.send_header("Content-type", "application/json")
self.end_headers()
self.wfile.write(bytes(json.dumps(desired), 'utf-8'))
HTTPServer(("", 80), Controller).serve_forever()

View File

@ -0,0 +1,4 @@
approvers:
- animeshsingh
- pvaneck
- tomcli

View File

@ -0,0 +1,15 @@
apiVersion: tekton.dev/v1alpha1
kind: Condition
metadata:
name: super-condition
spec:
check:
image: python:alpine3.6
script: "python -c 'import sys\ninput1=str.rstrip(sys.argv[1])\ninput2=str.rstrip(sys.argv[2])\n\
try:\n input1=int(input1)\n input2=int(input2)\nexcept:\n input1=str(input1)\n\
sys.exit(0) if (input1 $(params.operator) input2) else sys.exit(1)' '$(params.operand1)'\
\ '$(params.operand2)'"
params:
- name: operand1
- name: operand2
- name: operator

View File

@ -0,0 +1,27 @@
apiVersion: v1
kind: ConfigMap
metadata:
name: kfp-tekton-config
data:
artifact_bucket: "mlpipeline"
artifact_endpoint: "minio-service.kubeflow:9000"
artifact_endpoint_scheme: "http://"
artifact_image: "minio/mc"
archive_logs: "false"
track_artifacts: "true"
strip_eof: "false"
inject_default_script: "true"
artifact_script: |-
#!/usr/bin/env sh
push_artifact() {
tar -cvzf $1.tgz $2
mc cp $1.tgz storage/$ARTIFACT_BUCKET/artifacts/$PIPELINERUN/$PIPELINETASK/$1.tgz
}
push_log() {
cat /var/log/containers/$PODNAME*$NAMESPACE*step-main*.log > step-main.log
push_artifact main-log step-main.log
}
strip_eof() {
awk 'NF' $2 | head -c -1 > $1_temp_save && cp $1_temp_save $2
}
mc config host add storage ${ARTIFACT_ENDPOINT_SCHEME}${ARTIFACT_ENDPOINT} $AWS_ACCESS_KEY_ID $AWS_SECRET_ACCESS_KEY

View File

@ -0,0 +1,17 @@
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
resources:
- ../../generic
- catalog-condition.yaml
- kfp-pipeline-config.yaml
patchesStrategicMerge:
- metadata-writer-role.yaml
- ml-pipeline-apiserver-role.yaml
- ml-pipeline-persistenceagent-role.yaml
- ml-pipeline-ui-role.yaml
- pipeline-runner-role.yaml
- scheduledworkflow-role.yaml
- ml-pipeline-deployment-patch.yaml
- metadata-writer-deployment-patch.yaml

View File

@ -0,0 +1,15 @@
apiVersion: apps/v1
kind: Deployment
metadata:
name: metadata-writer
spec:
template:
spec:
containers:
- name: main
env:
- name: ARCHIVE_LOGS
valueFrom:
configMapKeyRef:
name: kfp-tekton-config
key: archive_logs

View File

@ -0,0 +1,43 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
name: kubeflow-pipelines-metadata-writer-role
rules:
- apiGroups:
- tekton.dev
resources:
- pipelineruns
- taskruns
- conditions
verbs:
- get
- list
- watch
- update
- patch
- apiGroups:
- ""
resources:
- pods
verbs:
- get
- list
- watch
- update
- patch
- apiGroups:
- ""
resources:
- configmaps
verbs:
- get
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- get
- list
- watch
- update
- patch

View File

@ -0,0 +1,51 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
name: ml-pipeline
rules:
- apiGroups:
- tekton.dev
resources:
- pipelineruns
- taskruns
- conditions
verbs:
- create
- get
- list
- watch
- update
- patch
- delete
- apiGroups:
- ""
resources:
- pods
- pods/log
verbs:
- get
- list
- delete
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- create
- get
- list
- watch
- update
- patch
- delete
- apiGroups:
- kubeflow.org
resources:
- scheduledworkflows
verbs:
- create
- get
- list
- update
- patch
- delete

View File

@ -0,0 +1,55 @@
apiVersion: apps/v1
kind: Deployment
metadata:
name: ml-pipeline
spec:
template:
spec:
containers:
- name: ml-pipeline-api-server
env:
- name: ARTIFACT_BUCKET
valueFrom:
configMapKeyRef:
name: kfp-tekton-config
key: artifact_bucket
- name: ARTIFACT_ENDPOINT
valueFrom:
configMapKeyRef:
name: kfp-tekton-config
key: artifact_endpoint
- name: ARTIFACT_ENDPOINT_SCHEME
valueFrom:
configMapKeyRef:
name: kfp-tekton-config
key: artifact_endpoint_scheme
- name: ARCHIVE_LOGS
valueFrom:
configMapKeyRef:
name: kfp-tekton-config
key: archive_logs
- name: TRACK_ARTIFACTS
valueFrom:
configMapKeyRef:
name: kfp-tekton-config
key: track_artifacts
- name: STRIP_EOF
valueFrom:
configMapKeyRef:
name: kfp-tekton-config
key: strip_eof
- name: ARTIFACT_SCRIPT
valueFrom:
configMapKeyRef:
name: kfp-tekton-config
key: artifact_script
- name: ARTIFACT_IMAGE
valueFrom:
configMapKeyRef:
name: kfp-tekton-config
key: artifact_image
- name: INJECT_DEFAULT_SCRIPT
valueFrom:
configMapKeyRef:
name: kfp-tekton-config
key: inject_default_script

View File

@ -0,0 +1,31 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
name: ml-pipeline-persistenceagent-role
rules:
- apiGroups:
- tekton.dev
resources:
- pipelineruns
- taskruns
- conditions
verbs:
- get
- list
- watch
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- get
- list
- watch
- apiGroups:
- kubeflow.org
resources:
- scheduledworkflows
verbs:
- get
- list
- watch

View File

@ -0,0 +1,51 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
name: ml-pipeline-ui
rules:
- apiGroups:
- tekton.dev
resources:
- pipelineruns
- taskruns
- conditions
verbs:
- get
- list
- apiGroups:
- ""
resources:
- pods
- pods/log
verbs:
- get
- apiGroups:
- ""
resources:
- events
verbs:
- list
- apiGroups:
- ""
resources:
- secrets
verbs:
- get
- list
- apiGroups:
- "kubeflow.org"
resources:
- viewers
verbs:
- create
- get
- list
- watch
- delete
- apiGroups:
- "argoproj.io"
resources:
- workflows
verbs:
- get
- list

View File

@ -0,0 +1,92 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
name: pipeline-runner
rules:
- apiGroups:
- tekton.dev
resources:
- pipelineruns
- taskruns
- conditions
verbs:
- get
- list
- watch
- update
- patch
- apiGroups:
- ""
resources:
- secrets
verbs:
- get
- apiGroups:
- ""
resources:
- configmaps
verbs:
- get
- watch
- list
- apiGroups:
- ""
resources:
- persistentvolumes
- persistentvolumeclaims
verbs:
- '*'
- apiGroups:
- snapshot.storage.k8s.io
resources:
- volumesnapshots
verbs:
- create
- delete
- get
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- get
- list
- watch
- update
- patch
- apiGroups:
- ""
resources:
- pods
- pods/exec
- pods/log
- services
verbs:
- '*'
- apiGroups:
- ""
- apps
- extensions
resources:
- deployments
- replicasets
verbs:
- '*'
- apiGroups:
- kubeflow.org
resources:
- '*'
verbs:
- '*'
- apiGroups:
- batch
resources:
- jobs
verbs:
- '*'
- apiGroups:
- machinelearning.seldon.io
resources:
- seldondeployments
verbs:
- '*'

View File

@ -0,0 +1,51 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: Role
metadata:
name: ml-pipeline-scheduledworkflow-role
rules:
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- create
- get
- list
- watch
- update
- patch
- delete
- apiGroups:
- kubeflow.org
resources:
- scheduledworkflows
verbs:
- create
- get
- list
- watch
- update
- patch
- delete
- apiGroups:
- ''
resources:
- events
verbs:
- create
- patch
- apiGroups:
- tekton.dev
resources:
- pipelineruns
- taskruns
- conditions
verbs:
- create
- get
- list
- watch
- update
- patch
- delete

View File

@ -0,0 +1,39 @@
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
bases:
- ../../upstream/env/platform-agnostic/minio
- ../../upstream/env/platform-agnostic/mysql
- kfp-tekton
# Identifier for application manager to apply ownerReference.
# The ownerReference ensures the resources get garbage collected
# when application is deleted.
commonLabels:
app.kubernetes.io/name: kubeflow-pipelines
app.kubernetes.io/component: ml-pipeline
# !!! If you want to customize the namespace,
# please also update base/cache-deployer/cluster-scoped/cache-deployer-clusterrolebinding.yaml
namespace: kubeflow
images:
- name: mysql
newTag: "5.6"
- name: minio/minio
newTag: RELEASE.2018-02-09T22-40-05Z
- name: gcr.io/ml-pipeline/api-server
newName: docker.io/aipipeline/api-server
newTag: 0.4.0
- name: gcr.io/ml-pipeline/persistenceagent
newName: docker.io/aipipeline/persistenceagent
newTag: 0.4.0
- name: gcr.io/ml-pipeline/frontend
newName: docker.io/aipipeline/frontend
newTag: 0.4.0
- name: gcr.io/ml-pipeline/metadata-writer
newName: docker.io/aipipeline/metadata-writer
newTag: 0.4.0
- name: gcr.io/ml-pipeline/scheduledworkflow
newName: docker.io/aipipeline/scheduledworkflow
newTag: 0.4.0

View File

@ -2,6 +2,8 @@ apiVersion: apps/v1
kind: Deployment
metadata:
name: minio
annotations:
sidecar.istio.io/inject: "false"
spec:
template:
spec:

View File

@ -0,0 +1,36 @@
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
namespace: kubeflow
resources:
- ../../../../pipeline/minio/installs/ibm
- ../../../../pipeline/mysql/installs/ibm
- ../../../../pipeline/installs/multi-user
configMapGenerator:
- name: pipeline-mysql-parameters
behavior: merge
literals:
- mysqlPvcName=mysql-pv-claim
- name: pipeline-minio-parameters
behavior: merge
literals:
- minioPvcName=minio-pv-claim
- name: kubeflow-config
envs:
- ../../config/params.env
vars:
# We need to define vars at the top level otherwise we will get
# conflicts.
- fieldref:
fieldPath: data.clusterDomain
name: clusterDomain
objref:
apiVersion: v1
kind: ConfigMap
name: kubeflow-config
- fieldref:
fieldPath: metadata.namespace
name: namespace
objref:
apiVersion: v1
kind: ConfigMap
name: kubeflow-config

View File

@ -19,7 +19,7 @@ configMapGenerator:
- ../../config/params.env
vars:
# We need to define vars at the top level otherwise we will get
# conflicts.
# conflicts.
- fieldref:
fieldPath: data.clusterDomain
name: clusterDomain
@ -34,4 +34,3 @@ vars:
apiVersion: v1
kind: ConfigMap
name: kubeflow-config

View File

@ -0,0 +1,34 @@
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
namespace: kubeflow
resources:
- ../../../../pipeline/minio/installs/ibm
- ../../../../pipeline/mysql/installs/ibm
- ../../../../pipeline/installs/tekton-multi-user
configMapGenerator:
- name: pipeline-mysql-parameters
behavior: merge
literals:
- mysqlPvcName=mysql-pv-claim
- name: pipeline-minio-parameters
behavior: merge
literals:
- minioPvcName=minio-pv-claim
- name: kubeflow-config
envs:
- ../../config/params.env
vars:
- fieldref:
fieldPath: data.clusterDomain
name: clusterDomain
objref:
apiVersion: v1
kind: ConfigMap
name: kubeflow-config
- fieldref:
fieldPath: metadata.namespace
name: namespace
objref:
apiVersion: v1
kind: ConfigMap
name: kubeflow-config

View File

@ -0,0 +1,24 @@
apiVersion: kustomize.config.k8s.io/v1beta1
kind: Kustomization
namespace: kubeflow
resources:
- ../../../../pipeline/installs/tekton
configMapGenerator:
- name: kubeflow-config
envs:
- ../../config/params.env
vars:
- fieldref:
fieldPath: data.clusterDomain
name: clusterDomain
objref:
apiVersion: v1
kind: ConfigMap
name: kubeflow-config
- fieldref:
fieldPath: metadata.namespace
name: namespace
objref:
apiVersion: v1
kind: ConfigMap
name: kubeflow-config

View File

@ -1,3 +1,5 @@
clusterDomain=cluster.local
userid-header=kubeflow-userid
userid-prefix=
cluster-name=
istio-namespace=istio-system

View File

@ -1,9 +1,11 @@
apiVersion: v1
data:
cluster-name: ""
clusterDomain: cluster.local
istio-namespace: istio-system
userid-header: kubeflow-userid
userid-prefix: ""
kind: ConfigMap
metadata:
name: kubeflow-config-d7dttg89h2
name: kubeflow-config-bk4bc7m928
namespace: kubeflow

View File

@ -1,9 +1,11 @@
apiVersion: v1
data:
cluster-name: ""
clusterDomain: cluster.local
istio-namespace: istio-system
userid-header: kubeflow-userid
userid-prefix: ""
kind: ConfigMap
metadata:
name: kubeflow-config-d7dttg89h2
name: kubeflow-config-bk4bc7m928
namespace: kubeflow

View File

@ -1,9 +1,11 @@
apiVersion: v1
data:
cluster-name: ""
clusterDomain: cluster.local
istio-namespace: istio-system
userid-header: kubeflow-userid
userid-prefix: ""
kind: ConfigMap
metadata:
name: kubeflow-config-d7dttg89h2
name: kubeflow-config-bk4bc7m928
namespace: kubeflow

View File

@ -0,0 +1,15 @@
package kfp_argo_multi_user
import (
"github.com/kubeflow/manifests/tests"
"testing"
)
func TestKustomize(t *testing.T) {
testCase := &tests.KustomizeTestCase{
Package: "../../../../../stacks/ibm/application/kfp-argo-multi-user",
Expected: "test_data/expected",
}
tests.RunTestCase(t, testCase)
}

View File

@ -0,0 +1,52 @@
apiVersion: app.k8s.io/v1beta1
kind: Application
metadata:
annotations:
kubernetes-engine.cloud.google.com/icon: 
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: kubeflow-pipelines
namespace: kubeflow
spec:
addOwnerRef: true
componentKinds:
- group: networking.istio.io/v1alpha3
kind: DestinationRule
- group: rbac.istio.io/v1alpha1
kind: ServiceRoleBinding
- group: rbac.istio.io/v1alpha1
kind: ServiceRole
- group: metacontroller.k8s.io/v1alpha1
kind: CompositeController
- group: v1
kind: ServiceAccount
- group: rbac.authorization.k8s.io/v1
kind: Role
- group: rbac.authorization.k8s.io/v1
kind: RoleBinding
- group: v1
kind: Service
- group: v1
kind: PersistentVolumeClaim
- group: v1
kind: ConfigMap
- group: v1
kind: Secret
- group: apps/v1
kind: Deployment
- group: networking.istio.io/v1alpha3
kind: VirtualService
descriptor:
description: Reusable end-to-end ML workflow
links:
- description: Kubeflow Pipelines Documentation
url: https://www.kubeflow.org/docs/pipelines/
maintainers:
- name: Kubeflow Pipelines
url: https://github.com/kubeflow/pipelines
type: Kubeflow Pipelines
version: 1.0.4
selector:
matchLabels:
app.kubernetes.io/application: kubeflow-pipelines

View File

@ -0,0 +1,77 @@
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: cache-server
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: cache-server
namespace: kubeflow
spec:
replicas: 1
selector:
matchLabels:
app: cache-server
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
template:
metadata:
labels:
app: cache-server
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
spec:
containers:
- args:
- --db_driver=$(DBCONFIG_DRIVER)
- --db_host=$(DBCONFIG_HOST_NAME)
- --db_port=$(DBCONFIG_PORT)
- --db_name=$(DBCONFIG_DB_NAME)
- --db_user=$(DBCONFIG_USER)
- --db_password=$(DBCONFIG_PASSWORD)
- --namespace_to_watch=$(NAMESPACE_TO_WATCH)
env:
- name: DBCONFIG_DRIVER
value: mysql
- name: DBCONFIG_DB_NAME
valueFrom:
configMapKeyRef:
key: cacheDb
name: pipeline-install-config-2829cc67f8
- name: DBCONFIG_HOST_NAME
valueFrom:
configMapKeyRef:
key: dbHost
name: pipeline-install-config-2829cc67f8
- name: DBCONFIG_PORT
valueFrom:
configMapKeyRef:
key: dbPort
name: pipeline-install-config-2829cc67f8
- name: DBCONFIG_USER
valueFrom:
secretKeyRef:
key: username
name: mysql-secret-fd5gktm75t
- name: DBCONFIG_PASSWORD
valueFrom:
secretKeyRef:
key: password
name: mysql-secret-fd5gktm75t
- name: NAMESPACE_TO_WATCH
value: ""
image: gcr.io/ml-pipeline/cache-server:1.0.4
imagePullPolicy: Always
name: server
ports:
- containerPort: 8443
name: webhook-api
volumeMounts:
- mountPath: /etc/webhook/certs
name: webhook-tls-certs
readOnly: true
serviceAccountName: kubeflow-pipelines-cache
volumes:
- name: webhook-tls-certs
secret:
secretName: webhook-server-tls

View File

@ -0,0 +1,59 @@
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: kubeflow-pipelines-profile-controller
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: kubeflow-pipelines-profile-controller
namespace: kubeflow
spec:
replicas: 1
selector:
matchLabels:
app: kubeflow-pipelines-profile-controller
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
template:
metadata:
annotations:
sidecar.istio.io/inject: "false"
labels:
app: kubeflow-pipelines-profile-controller
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
spec:
containers:
- command:
- python
- /hooks/sync.py
env:
- name: KFP_VERSION
valueFrom:
configMapKeyRef:
key: appVersion
name: pipeline-upstream-install-config-d7hkh24mdg
- name: MINIO_ACCESS_KEY
valueFrom:
secretKeyRef:
key: accesskey
name: mlpipeline-minio-artifact
- name: MINIO_SECRET_KEY
valueFrom:
secretKeyRef:
key: secretkey
name: mlpipeline-minio-artifact
envFrom:
- configMapRef:
name: kubeflow-pipelines-profile-controller-env-mgh6th2gff
image: python:3.7
name: profile-controller
ports:
- containerPort: 80
volumeMounts:
- mountPath: /hooks
name: hooks
volumes:
- configMap:
name: kubeflow-pipelines-profile-controller-code-gd97t2m5f5
name: hooks

View File

@ -0,0 +1,30 @@
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: metadata-writer
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: metadata-writer
namespace: kubeflow
spec:
replicas: 1
selector:
matchLabels:
app: metadata-writer
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
template:
metadata:
labels:
app: metadata-writer
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
spec:
containers:
- env:
- name: NAMESPACE_TO_WATCH
value: ""
image: gcr.io/ml-pipeline/metadata-writer:1.0.4
name: main
serviceAccountName: kubeflow-pipelines-metadata-writer

View File

@ -1,6 +1,8 @@
apiVersion: apps/v1
kind: Deployment
metadata:
annotations:
sidecar.istio.io/inject: "false"
labels:
app: minio
app.kubernetes.io/component: minio

View File

@ -0,0 +1,32 @@
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: ml-pipeline-persistenceagent
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-persistenceagent
namespace: kubeflow
spec:
selector:
matchLabels:
app: ml-pipeline-persistenceagent
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
template:
metadata:
labels:
app: ml-pipeline-persistenceagent
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
spec:
containers:
- env:
- name: NAMESPACE
value: ""
- name: TTL_SECONDS_AFTER_WORKFLOW_FINISH
value: "86400"
image: gcr.io/ml-pipeline/persistenceagent:1.0.4
imagePullPolicy: IfNotPresent
name: ml-pipeline-persistenceagent
serviceAccountName: ml-pipeline-persistenceagent

View File

@ -0,0 +1,30 @@
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: ml-pipeline-scheduledworkflow
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-scheduledworkflow
namespace: kubeflow
spec:
selector:
matchLabels:
app: ml-pipeline-scheduledworkflow
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
template:
metadata:
labels:
app: ml-pipeline-scheduledworkflow
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
spec:
containers:
- env:
- name: NAMESPACE
value: ""
image: gcr.io/ml-pipeline/scheduledworkflow:1.0.4
imagePullPolicy: IfNotPresent
name: ml-pipeline-scheduledworkflow
serviceAccountName: ml-pipeline-scheduledworkflow

View File

@ -0,0 +1,100 @@
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: ml-pipeline-ui
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-ui
namespace: kubeflow
spec:
selector:
matchLabels:
app: ml-pipeline-ui
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
template:
metadata:
labels:
app: ml-pipeline-ui
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
spec:
containers:
- env:
- name: VIEWER_TENSORBOARD_POD_TEMPLATE_SPEC_PATH
value: /etc/config/viewer-pod-template.json
- name: DEPLOYMENT
value: KUBEFLOW
- name: ARTIFACTS_SERVICE_PROXY_NAME
value: ml-pipeline-ui-artifact
- name: ARTIFACTS_SERVICE_PROXY_PORT
value: "80"
- name: ARTIFACTS_SERVICE_PROXY_ENABLED
value: "true"
- name: ENABLE_AUTHZ
value: "true"
- name: KUBEFLOW_USERID_HEADER
valueFrom:
configMapKeyRef:
key: userid-header
name: kubeflow-config-bk4bc7m928
- name: KUBEFLOW_USERID_PREFIX
valueFrom:
configMapKeyRef:
key: userid-prefix
name: kubeflow-config-bk4bc7m928
- name: MINIO_NAMESPACE
valueFrom:
fieldRef:
fieldPath: metadata.namespace
- name: MINIO_ACCESS_KEY
valueFrom:
secretKeyRef:
key: accesskey
name: mlpipeline-minio-artifact
- name: MINIO_SECRET_KEY
valueFrom:
secretKeyRef:
key: secretkey
name: mlpipeline-minio-artifact
- name: ALLOW_CUSTOM_VISUALIZATIONS
value: "true"
image: gcr.io/ml-pipeline/frontend:1.0.4
imagePullPolicy: IfNotPresent
livenessProbe:
exec:
command:
- wget
- -q
- -S
- -O
- '-'
- http://localhost:3000/apis/v1beta1/healthz
initialDelaySeconds: 3
periodSeconds: 5
timeoutSeconds: 2
name: ml-pipeline-ui
ports:
- containerPort: 3000
readinessProbe:
exec:
command:
- wget
- -q
- -S
- -O
- '-'
- http://localhost:3000/apis/v1beta1/healthz
initialDelaySeconds: 3
periodSeconds: 5
timeoutSeconds: 2
volumeMounts:
- mountPath: /etc/config
name: config-volume
readOnly: true
serviceAccountName: ml-pipeline-ui
volumes:
- configMap:
name: ml-pipeline-ui-configmap
name: config-volume

View File

@ -0,0 +1,37 @@
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: ml-pipeline-viewer-crd
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-viewer-crd
namespace: kubeflow
spec:
selector:
matchLabels:
app: ml-pipeline-viewer-crd
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
template:
metadata:
labels:
app: ml-pipeline-viewer-crd
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
spec:
containers:
- env:
- name: NAMESPACE
value: ""
valueFrom: null
- name: MAX_NUM_VIEWERS
value: "50"
- name: MINIO_NAMESPACE
valueFrom:
fieldRef:
fieldPath: metadata.namespace
image: gcr.io/ml-pipeline/viewer-crd-controller:1.0.4
imagePullPolicy: Always
name: ml-pipeline-viewer-crd
serviceAccountName: ml-pipeline-viewer-crd-service-account

View File

@ -0,0 +1,116 @@
apiVersion: apps/v1
kind: Deployment
metadata:
labels:
app: ml-pipeline
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline
namespace: kubeflow
spec:
selector:
matchLabels:
app: ml-pipeline
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
template:
metadata:
labels:
app: ml-pipeline
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
spec:
containers:
- env:
- name: KUBEFLOW_USERID_HEADER
valueFrom:
configMapKeyRef:
key: userid-header
name: kubeflow-config-bk4bc7m928
- name: KUBEFLOW_USERID_PREFIX
valueFrom:
configMapKeyRef:
key: userid-prefix
name: kubeflow-config-bk4bc7m928
- name: POD_NAMESPACE
valueFrom:
fieldRef:
fieldPath: metadata.namespace
- name: OBJECTSTORECONFIG_SECURE
value: "false"
- name: OBJECTSTORECONFIG_BUCKETNAME
valueFrom:
configMapKeyRef:
key: bucketName
name: pipeline-install-config-2829cc67f8
- name: DBCONFIG_USER
valueFrom:
secretKeyRef:
key: username
name: mysql-secret-fd5gktm75t
- name: DBCONFIG_PASSWORD
valueFrom:
secretKeyRef:
key: password
name: mysql-secret-fd5gktm75t
- name: DBCONFIG_DBNAME
valueFrom:
configMapKeyRef:
key: pipelineDb
name: pipeline-install-config-2829cc67f8
- name: DBCONFIG_HOST
valueFrom:
configMapKeyRef:
key: dbHost
name: pipeline-install-config-2829cc67f8
- name: DBCONFIG_PORT
valueFrom:
configMapKeyRef:
key: dbPort
name: pipeline-install-config-2829cc67f8
- name: OBJECTSTORECONFIG_ACCESSKEY
valueFrom:
secretKeyRef:
key: accesskey
name: mlpipeline-minio-artifact
- name: OBJECTSTORECONFIG_SECRETACCESSKEY
valueFrom:
secretKeyRef:
key: secretkey
name: mlpipeline-minio-artifact
envFrom:
- configMapRef:
name: pipeline-api-server-config-f4t72426kt
image: gcr.io/ml-pipeline/api-server:1.0.4
imagePullPolicy: IfNotPresent
livenessProbe:
exec:
command:
- wget
- -q
- -S
- -O
- '-'
- http://localhost:8888/apis/v1beta1/healthz
initialDelaySeconds: 3
periodSeconds: 5
timeoutSeconds: 2
name: ml-pipeline-api-server
ports:
- containerPort: 8888
name: http
- containerPort: 8887
name: grpc
readinessProbe:
exec:
command:
- wget
- -q
- -S
- -O
- '-'
- http://localhost:8888/apis/v1beta1/healthz
initialDelaySeconds: 3
periodSeconds: 5
timeoutSeconds: 2
serviceAccountName: ml-pipeline

View File

@ -0,0 +1,48 @@
apiVersion: metacontroller.k8s.io/v1alpha1
kind: CompositeController
metadata:
labels:
app: kubeflow-pipelines-profile-controller
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: kubeflow-pipelines-profile-controller
namespace: kubeflow
spec:
childResources:
- apiVersion: v1
resource: secrets
updateStrategy:
method: OnDelete
- apiVersion: v1
resource: configmaps
updateStrategy:
method: OnDelete
- apiVersion: apps/v1
resource: deployments
updateStrategy:
method: InPlace
- apiVersion: v1
resource: services
updateStrategy:
method: InPlace
- apiVersion: networking.istio.io/v1alpha3
resource: destinationrules
updateStrategy:
method: InPlace
- apiVersion: rbac.istio.io/v1alpha1
resource: serviceroles
updateStrategy:
method: InPlace
- apiVersion: rbac.istio.io/v1alpha1
resource: servicerolebindings
updateStrategy:
method: InPlace
generateSelector: true
hooks:
sync:
webhook:
url: http://kubeflow-pipelines-profile-controller/sync
parentResource:
apiVersion: v1
resource: namespaces
resyncPeriodSeconds: 10

View File

@ -0,0 +1,13 @@
apiVersion: networking.istio.io/v1alpha3
kind: DestinationRule
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-mysql
namespace: kubeflow
spec:
host: mysql.kubeflow.svc.cluster.local
trafficPolicy:
tls:
mode: ISTIO_MUTUAL

View File

@ -0,0 +1,13 @@
apiVersion: networking.istio.io/v1alpha3
kind: DestinationRule
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-ui
namespace: kubeflow
spec:
host: ml-pipeline-ui.kubeflow.svc.cluster.local
trafficPolicy:
tls:
mode: ISTIO_MUTUAL

View File

@ -0,0 +1,13 @@
apiVersion: networking.istio.io/v1alpha3
kind: DestinationRule
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-visualizationserver
namespace: kubeflow
spec:
host: ml-pipeline-visualizationserver.kubeflow.svc.cluster.local
trafficPolicy:
tls:
mode: ISTIO_MUTUAL

View File

@ -0,0 +1,13 @@
apiVersion: networking.istio.io/v1alpha3
kind: DestinationRule
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline
namespace: kubeflow
spec:
host: ml-pipeline.kubeflow.svc.cluster.local
trafficPolicy:
tls:
mode: ISTIO_MUTUAL

View File

@ -0,0 +1,34 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: kubeflow-pipelines-cache-role
rules:
- apiGroups:
- ""
resources:
- pods
verbs:
- get
- list
- watch
- update
- patch
- apiGroups:
- ""
resources:
- configmaps
verbs:
- get
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- get
- list
- watch
- update
- patch

View File

@ -0,0 +1,34 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: kubeflow-pipelines-metadata-writer-role
rules:
- apiGroups:
- ""
resources:
- pods
verbs:
- get
- list
- watch
- update
- patch
- apiGroups:
- ""
resources:
- configmaps
verbs:
- get
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- get
- list
- watch
- update
- patch

View File

@ -0,0 +1,24 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-persistenceagent-role
rules:
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- get
- list
- watch
- apiGroups:
- kubeflow.org
resources:
- scheduledworkflows
verbs:
- get
- list
- watch

View File

@ -0,0 +1,39 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-scheduledworkflow-role
rules:
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- create
- get
- list
- watch
- update
- patch
- delete
- apiGroups:
- kubeflow.org
resources:
- scheduledworkflows
verbs:
- create
- get
- list
- watch
- update
- patch
- delete
- apiGroups:
- ""
resources:
- events
verbs:
- create
- patch

View File

@ -0,0 +1,46 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
labels:
app: ml-pipeline-ui
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-ui
rules:
- apiGroups:
- ""
resources:
- pods
- pods/log
verbs:
- get
- apiGroups:
- ""
resources:
- events
verbs:
- list
- apiGroups:
- ""
resources:
- secrets
verbs:
- get
- list
- apiGroups:
- kubeflow.org
resources:
- viewers
verbs:
- create
- get
- list
- watch
- delete
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- get
- list

View File

@ -0,0 +1,33 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRole
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-viewer-controller-role
rules:
- apiGroups:
- '*'
resources:
- deployments
- services
verbs:
- create
- get
- list
- watch
- update
- patch
- delete
- apiGroups:
- kubeflow.org
resources:
- viewers
verbs:
- create
- get
- list
- watch
- update
- patch
- delete

View File

@ -0,0 +1,15 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: kubeflow-pipelines-cache-binding
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: kubeflow-pipelines-cache-role
subjects:
- kind: ServiceAccount
name: kubeflow-pipelines-cache
namespace: kubeflow

View File

@ -0,0 +1,15 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: kubeflow-pipelines-metadata-writer-binding
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: kubeflow-pipelines-metadata-writer-role
subjects:
- kind: ServiceAccount
name: kubeflow-pipelines-metadata-writer
namespace: kubeflow

View File

@ -0,0 +1,15 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-persistenceagent-binding
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: ml-pipeline-persistenceagent-role
subjects:
- kind: ServiceAccount
name: ml-pipeline-persistenceagent
namespace: kubeflow

View File

@ -0,0 +1,15 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-scheduledworkflow-binding
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: ml-pipeline-scheduledworkflow-role
subjects:
- kind: ServiceAccount
name: ml-pipeline-scheduledworkflow
namespace: kubeflow

View File

@ -0,0 +1,16 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
labels:
app: ml-pipeline-ui
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-ui
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: ml-pipeline-ui
subjects:
- kind: ServiceAccount
name: ml-pipeline-ui
namespace: kubeflow

View File

@ -0,0 +1,15 @@
apiVersion: rbac.authorization.k8s.io/v1
kind: ClusterRoleBinding
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-viewer-crd-binding
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: ml-pipeline-viewer-controller-role
subjects:
- kind: ServiceAccount
name: ml-pipeline-viewer-crd-service-account
namespace: kubeflow

View File

@ -0,0 +1,37 @@
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRole
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline
rules:
- apiGroups:
- argoproj.io
resources:
- workflows
verbs:
- create
- get
- list
- watch
- update
- patch
- delete
- apiGroups:
- kubeflow.org
resources:
- scheduledworkflows
verbs:
- create
- get
- list
- update
- patch
- delete
- apiGroups:
- ""
resources:
- pods
verbs:
- delete

View File

@ -0,0 +1,15 @@
apiVersion: rbac.authorization.k8s.io/v1beta1
kind: ClusterRoleBinding
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline
roleRef:
apiGroup: rbac.authorization.k8s.io
kind: ClusterRole
name: ml-pipeline
subjects:
- kind: ServiceAccount
name: ml-pipeline
namespace: kubeflow

View File

@ -0,0 +1,12 @@
apiVersion: rbac.istio.io/v1alpha1
kind: ServiceRole
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: cache-server
namespace: kubeflow
spec:
rules:
- services:
- cache-server.kubeflow.svc.cluster.local

View File

@ -0,0 +1,15 @@
apiVersion: rbac.istio.io/v1alpha1
kind: ServiceRole
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-services
namespace: kubeflow
spec:
rules:
- services:
- ml-pipeline.kubeflow.svc.cluster.local
- ml-pipeline-ui.kubeflow.svc.cluster.local
- ml-pipeline-visualizationserver.kubeflow.svc.cluster.local
- mysql.kubeflow.svc.cluster.local

View File

@ -0,0 +1,12 @@
apiVersion: rbac.istio.io/v1alpha1
kind: ServiceRole
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: ml-pipeline-ui
namespace: kubeflow
spec:
rules:
- services:
- ml-pipeline-ui.kubeflow.svc.cluster.local

View File

@ -0,0 +1,14 @@
apiVersion: rbac.istio.io/v1alpha1
kind: ServiceRoleBinding
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: bind-cache-server-admission-webhook
namespace: kubeflow
spec:
roleRef:
kind: ServiceRole
name: cache-server
subjects:
- user: '*'

View File

@ -0,0 +1,15 @@
apiVersion: rbac.istio.io/v1alpha1
kind: ServiceRoleBinding
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: bind-gateway-ml-pipeline-ui
namespace: kubeflow
spec:
roleRef:
kind: ServiceRole
name: ml-pipeline-ui
subjects:
- properties:
source.namespace: istio-system

View File

@ -0,0 +1,25 @@
apiVersion: rbac.istio.io/v1alpha1
kind: ServiceRoleBinding
metadata:
labels:
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: bind-ml-pipeline-internal
namespace: kubeflow
spec:
roleRef:
kind: ServiceRole
name: ml-pipeline-services
subjects:
- properties:
source.principal: cluster.local/ns/kubeflow/sa/ml-pipeline
- properties:
source.principal: cluster.local/ns/kubeflow/sa/ml-pipeline-ui
- properties:
source.principal: cluster.local/ns/kubeflow/sa/ml-pipeline-persistenceagent
- properties:
source.principal: cluster.local/ns/kubeflow/sa/ml-pipeline-scheduledworkflow
- properties:
source.principal: cluster.local/ns/kubeflow/sa/ml-pipeline-viewer-crd-service-account
- properties:
source.principal: cluster.local/ns/kubeflow/sa/kubeflow-pipelines-cache

View File

@ -1,9 +1,11 @@
apiVersion: v1
data:
cluster-name: ""
clusterDomain: cluster.local
istio-namespace: istio-system
userid-header: kubeflow-userid
userid-prefix: ""
kind: ConfigMap
metadata:
name: kubeflow-config-d7dttg89h2
name: kubeflow-config-bk4bc7m928
namespace: kubeflow

View File

@ -0,0 +1,292 @@
apiVersion: v1
data:
sync.py: |
# Copyright 2020 Google LLC
#
# 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 http.server import BaseHTTPRequestHandler, HTTPServer
import json
import os
import base64
kfp_version = os.environ["KFP_VERSION"]
disable_istio_sidecar = os.environ.get("DISABLE_ISTIO_SIDECAR") == "true"
mlpipeline_minio_access_key = base64.b64encode(
bytes(os.environ.get("MINIO_ACCESS_KEY"), 'utf-8')).decode('utf-8')
mlpipeline_minio_secret_key = base64.b64encode(
bytes(os.environ.get("MINIO_SECRET_KEY"), 'utf-8')).decode('utf-8')
class Controller(BaseHTTPRequestHandler):
def sync(self, parent, children):
# HACK: Currently using serving.kubeflow.org/inferenceservice to identify
# kubeflow user namespaces.
# TODO: let Kubeflow profile controller add a pipeline specific label to
# user namespaces and use that label instead.
pipeline_enabled = parent.get("metadata", {}).get(
"labels", {}).get("serving.kubeflow.org/inferenceservice")
if not pipeline_enabled:
return {"status": {}, "children": []}
# Compute status based on observed state.
desired_status = {
"kubeflow-pipelines-ready": \
len(children["Secret.v1"]) == 1 and \
len(children["ConfigMap.v1"]) == 1 and \
len(children["Deployment.apps/v1"]) == 2 and \
len(children["Service.v1"]) == 2 and \
len(children["DestinationRule.networking.istio.io/v1alpha3"]) == 1 and \
len(children["ServiceRole.rbac.istio.io/v1alpha1"]) == 1 and \
len(children["ServiceRoleBinding.rbac.istio.io/v1alpha1"]) == 1 and \
"True" or "False"
}
# Generate the desired child object(s).
# parent is a namespace
namespace = parent.get("metadata", {}).get("name")
desired_resources = [
{
"apiVersion": "v1",
"kind": "ConfigMap",
"metadata": {
"name": "metadata-grpc-configmap",
"namespace": namespace,
},
"data": {
"METADATA_GRPC_SERVICE_HOST":
"metadata-grpc-service.kubeflow",
"METADATA_GRPC_SERVICE_PORT": "8080",
},
},
# Visualization server related manifests below
{
"apiVersion": "apps/v1",
"kind": "Deployment",
"metadata": {
"labels": {
"app": "ml-pipeline-visualizationserver"
},
"name": "ml-pipeline-visualizationserver",
"namespace": namespace,
},
"spec": {
"selector": {
"matchLabels": {
"app": "ml-pipeline-visualizationserver"
},
},
"template": {
"metadata": {
"labels": {
"app": "ml-pipeline-visualizationserver"
},
"annotations": disable_istio_sidecar and {
"sidecar.istio.io/inject": "false"
} or {},
},
"spec": {
"containers": [{
"image":
"gcr.io/ml-pipeline/visualization-server:" +
kfp_version,
"imagePullPolicy":
"IfNotPresent",
"name":
"ml-pipeline-visualizationserver",
"ports": [{
"containerPort": 8888
}],
}],
"serviceAccountName":
"default-editor",
},
},
},
},
{
"apiVersion": "networking.istio.io/v1alpha3",
"kind": "DestinationRule",
"metadata": {
"name": "ml-pipeline-visualizationserver",
"namespace": namespace,
},
"spec": {
"host": "ml-pipeline-visualizationserver",
"trafficPolicy": {
"tls": {
"mode": "ISTIO_MUTUAL"
}
}
}
},
{
"apiVersion": "rbac.istio.io/v1alpha1",
"kind": "ServiceRole",
"metadata": {
"name": "ml-pipeline-visualizationserver",
"namespace": namespace,
},
"spec": {
"rules": [{
"services": ["ml-pipeline-visualizationserver.*"]
}]
}
},
{
"apiVersion": "rbac.istio.io/v1alpha1",
"kind": "ServiceRoleBinding",
"metadata": {
"name": "ml-pipeline-visualizationserver",
"namespace": namespace,
},
"spec": {
"subjects": [{
"properties": {
"source.principal":
"cluster.local/ns/kubeflow/sa/ml-pipeline"
}
}],
"roleRef": {
"kind": "ServiceRole",
"name": "ml-pipeline-visualizationserver"
}
}
},
{
"apiVersion": "v1",
"kind": "Service",
"metadata": {
"name": "ml-pipeline-visualizationserver",
"namespace": namespace,
},
"spec": {
"ports": [{
"name": "http",
"port": 8888,
"protocol": "TCP",
"targetPort": 8888,
}],
"selector": {
"app": "ml-pipeline-visualizationserver",
},
},
},
# Artifact fetcher related resources below.
{
"apiVersion": "apps/v1",
"kind": "Deployment",
"metadata": {
"labels": {
"app": "ml-pipeline-ui-artifact"
},
"name": "ml-pipeline-ui-artifact",
"namespace": namespace,
},
"spec": {
"selector": {
"matchLabels": {
"app": "ml-pipeline-ui-artifact"
}
},
"template": {
"metadata": {
"labels": {
"app": "ml-pipeline-ui-artifact"
},
"annotations": disable_istio_sidecar and {
"sidecar.istio.io/inject": "false"
} or {},
},
"spec": {
"containers": [{
"name":
"ml-pipeline-ui-artifact",
"image":
"gcr.io/ml-pipeline/frontend:" + kfp_version,
"imagePullPolicy":
"IfNotPresent",
"ports": [{
"containerPort": 3000
}]
}],
"serviceAccountName":
"default-editor"
}
}
}
},
{
"apiVersion": "v1",
"kind": "Service",
"metadata": {
"name": "ml-pipeline-ui-artifact",
"namespace": namespace,
"labels": {
"app": "ml-pipeline-ui-artifact"
}
},
"spec": {
"ports": [{
"name":
"http", # name is required to let istio understand request protocol
"port": 80,
"protocol": "TCP",
"targetPort": 3000
}],
"selector": {
"app": "ml-pipeline-ui-artifact"
}
}
},
]
print('Received request:', parent)
print('Desired resources except secrets:', desired_resources)
# Moved after the print argument because this is sensitive data.
desired_resources.append({
"apiVersion": "v1",
"kind": "Secret",
"metadata": {
"name": "mlpipeline-minio-artifact",
"namespace": namespace,
},
"data": {
"accesskey": mlpipeline_minio_access_key,
"secretkey": mlpipeline_minio_secret_key,
},
})
return {"status": desired_status, "children": desired_resources}
def do_POST(self):
# Serve the sync() function as a JSON webhook.
observed = json.loads(
self.rfile.read(int(self.headers.get("content-length"))))
desired = self.sync(observed["parent"], observed["children"])
self.send_response(200)
self.send_header("Content-type", "application/json")
self.end_headers()
self.wfile.write(bytes(json.dumps(desired), 'utf-8'))
HTTPServer(("", 80), Controller).serve_forever()
kind: ConfigMap
metadata:
labels:
app: kubeflow-pipelines-profile-controller
app.kubernetes.io/component: ml-pipeline
app.kubernetes.io/name: kubeflow-pipelines
name: kubeflow-pipelines-profile-controller-code-gd97t2m5f5
namespace: kubeflow

Some files were not shown because too many files have changed in this diff Show More