From d447355a9d0ac177d3c7a0e18a61b2fbb1a2e5c4 Mon Sep 17 00:00:00 2001 From: "Yuan (Bob) Gong" Date: Mon, 7 Sep 2020 13:39:41 +0800 Subject: [PATCH] feat: GCP marketplace - preserve install config in configmap and secret (#4471) * tools for comparing gcp marketplace manifests * commit snapshots * feat: GCP marketplace - preserve install config snapshot in a configmap and secret * commit updated snapshots * update syntax --- .../kubeflow-pipelines/templates/cache.yaml | 10 +- .../templates/config-snapshot.yaml | 34 + .../templates/metadata.yaml | 6 +- .../templates/pipeline.yaml | 6 +- .../chart/kubeflow-pipelines/values.yaml | 3 +- manifests/gcp_marketplace/hack/snapshots.sh | 31 + .../gcp_marketplace/test/snapshot-base.yaml | 1828 ++++++++++++++++ ...apshot-managed-storage-with-db-prefix.yaml | 1858 +++++++++++++++++ .../test/snapshot-managed-storage.yaml | 1858 +++++++++++++++++ .../gcp_marketplace/test/values-base.yaml | 9 + ...values-managed-storage-with-db-prefix.yaml | 9 + .../test/values-managed-storage.yaml | 9 + 12 files changed, 5642 insertions(+), 19 deletions(-) create mode 100644 manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/config-snapshot.yaml create mode 100755 manifests/gcp_marketplace/hack/snapshots.sh create mode 100644 manifests/gcp_marketplace/test/snapshot-base.yaml create mode 100644 manifests/gcp_marketplace/test/snapshot-managed-storage-with-db-prefix.yaml create mode 100644 manifests/gcp_marketplace/test/snapshot-managed-storage.yaml create mode 100644 manifests/gcp_marketplace/test/values-base.yaml create mode 100644 manifests/gcp_marketplace/test/values-managed-storage-with-db-prefix.yaml create mode 100644 manifests/gcp_marketplace/test/values-managed-storage.yaml diff --git a/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/cache.yaml b/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/cache.yaml index 97103f58eda..4bf6e249dd0 100644 --- a/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/cache.yaml +++ b/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/cache.yaml @@ -186,14 +186,10 @@ metadata: labels: component: cache-server data: - {{ if .Values.managedstorage.databaseNamePrefix }} - mysql_database: '{{ .Values.managedstorage.databaseNamePrefix }}_cachedb' - {{ else }} - mysql_database: '{{ .Release.Name | replace "-" "_" | replace "." "_"}}_cachedb' - {{ end }} + mysql_database: '{{ tpl .Values.managedstorage.databaseNamePrefix . }}_cachedb' mysql_driver: "mysql" mysql_host: "mysql" - mysql_port: "3306" + mysql_port: "3306" --- apiVersion: apps/v1 kind: Deployment @@ -283,7 +279,7 @@ apiVersion: v1 kind: Service metadata: name: cache-server - labels: + labels: app: cache-server app.kubernetes.io/name: {{ .Release.Name }} spec: diff --git a/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/config-snapshot.yaml b/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/config-snapshot.yaml new file mode 100644 index 00000000000..e12063ae4c6 --- /dev/null +++ b/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/config-snapshot.yaml @@ -0,0 +1,34 @@ +apiVersion: v1 +kind: ConfigMap +metadata: + name: ml-pipeline-install-config-snapshot + labels: + app.kubernetes.io/name: '{{ .Release.Name }}' + annotations: + pipelines.kubeflow.org/comment: |- + This is a snapshot of install parameters. There's no effect modifying this. +data: + appName: '{{ .Release.Name }}' + namespace: '{{ .Release.Namespace }}' + managedStorageEnabled: '{{ .Values.managedstorage.enabled }}' + #{{ if .Values.managedstorage.enabled }} + managedStorageCloudSqlInstanceConnectionName: '{{ .Values.managedstorage.cloudsqlInstanceConnectionName }}' + managedStorageGcsBucketName: '{{ .Values.managedstorage.gcsBucketName }}' + managedStorageDatabasePrefix: '{{ tpl .Values.managedstorage.databaseNamePrefix . }}' + managedstorageDbUserName: '{{ .Values.managedstorage.dbUsername }}' + #{{ end }} +--- +apiVersion: v1 +kind: Secret +metadata: + name: ml-pipeline-install-secret-snapshot + labels: + app.kubernetes.io/name: '{{ .Release.Name }}' + annotations: + pipelines.kubeflow.org/comment: |- + This is a snapshot of install secrets. There's no effect modifying this. +type: Opaque +#{{ if .Values.managedstorage.enabled }} +data: + managedStorageDbPassword: '{{ .Values.managedstorage.dbPassword | b64enc }}' +#{{ end }} diff --git a/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/metadata.yaml b/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/metadata.yaml index cdbf687f93d..d7b0ec266de 100644 --- a/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/metadata.yaml +++ b/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/metadata.yaml @@ -144,11 +144,7 @@ metadata: labels: component: metadata-server data: - {{ if .Values.managedstorage.databaseNamePrefix }} - MYSQL_DATABASE: '{{ .Values.managedstorage.databaseNamePrefix }}_metadata' - {{ else }} - MYSQL_DATABASE: '{{ .Release.Name | replace "-" "_" | replace "." "_"}}_metadata' - {{ end }} + MYSQL_DATABASE: '{{ tpl .Values.managedstorage.databaseNamePrefix . }}_metadata' MYSQL_HOST: "mysql" MYSQL_PORT: "3306" --- diff --git a/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/pipeline.yaml b/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/pipeline.yaml index 512f66211ba..6cf6a5264b8 100644 --- a/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/pipeline.yaml +++ b/manifests/gcp_marketplace/chart/kubeflow-pipelines/templates/pipeline.yaml @@ -737,11 +737,7 @@ spec: - name: OBJECTSTORECONFIG_BUCKETNAME value: "{{ .Values.managedstorage.gcsBucketName }}" - name: DBCONFIG_DBNAME - {{ if .Values.managedstorage.databaseNamePrefix }} - value: '{{ .Values.managedstorage.databaseNamePrefix }}_pipeline' - {{ else }} - value: '{{ .Release.Name | replace "-" "_" | replace "." "_" }}_pipeline' - {{ end }} + value: '{{ tpl .Values.managedstorage.databaseNamePrefix . }}_pipeline' - name: DBCONFIG_USER valueFrom: secretKeyRef: diff --git a/manifests/gcp_marketplace/chart/kubeflow-pipelines/values.yaml b/manifests/gcp_marketplace/chart/kubeflow-pipelines/values.yaml index a772dd4a6f7..2b5f33e0c15 100644 --- a/manifests/gcp_marketplace/chart/kubeflow-pipelines/values.yaml +++ b/manifests/gcp_marketplace/chart/kubeflow-pipelines/values.yaml @@ -24,7 +24,6 @@ managedstorage: enabled: false cloudsqlInstanceConnectionName: null gcsBucketName: null - databaseNamePrefix: null + databaseNamePrefix: '{{ .Release.Name | replace "-" "_" | replace "." "_" }}' dbUsername: 'root' dbPassword: '' - gcsProjectId: '' diff --git a/manifests/gcp_marketplace/hack/snapshots.sh b/manifests/gcp_marketplace/hack/snapshots.sh new file mode 100755 index 00000000000..8d83ed423b8 --- /dev/null +++ b/manifests/gcp_marketplace/hack/snapshots.sh @@ -0,0 +1,31 @@ +#!/bin/bash +# +# 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. + +CASES=( + "base" + "managed-storage" + "managed-storage-with-db-prefix" +) + +for case in "${CASES[@]}" +do + echo "Generating helm template for ./test/values-$case.yaml" + helm template chart/kubeflow-pipelines \ + --name "my-release" \ + --namespace "kubeflow" \ + --values "./test/values-$case.yaml" \ + > "./test/snapshot-$case.yaml" +done diff --git a/manifests/gcp_marketplace/test/snapshot-base.yaml b/manifests/gcp_marketplace/test/snapshot-base.yaml new file mode 100644 index 00000000000..182e3953fe2 --- /dev/null +++ b/manifests/gcp_marketplace/test/snapshot-base.yaml @@ -0,0 +1,1828 @@ +--- +# Source: kubeflow-pipelines/templates/config-snapshot.yaml +apiVersion: v1 +kind: ConfigMap +metadata: + name: ml-pipeline-install-config-snapshot + labels: + app.kubernetes.io/name: 'my-release' + annotations: + pipelines.kubeflow.org/comment: |- + This is a snapshot of install parameters. There's no effect modifying this. +data: + appName: 'my-release' + namespace: 'kubeflow' + managedStorageEnabled: 'false' + # +--- +apiVersion: v1 +kind: Secret +metadata: + name: ml-pipeline-install-secret-snapshot + labels: + app.kubernetes.io/name: 'my-release' + annotations: + pipelines.kubeflow.org/comment: |- + This is a snapshot of install secrets. There's no effect modifying this. +type: Opaque +# + +--- +# Source: kubeflow-pipelines/templates/cache.yaml +apiVersion: v1 +kind: ServiceAccount +metadata: + name: kubeflow-pipelines-cache-deployer-sa + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: kubeflow-pipelines-cache + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + labels: + app: kubeflow-pipelines-cache-deployer-clusterrole + app.kubernetes.io/name: my-release + name: kubeflow-pipelines-cache-deployer-clusterrole +rules: +- apiGroups: + - certificates.k8s.io + resources: + - certificatesigningrequests + - certificatesigningrequests/approval + verbs: + - create + - delete + - get + - update +- apiGroups: + - admissionregistration.k8s.io + resources: + - mutatingwebhookconfigurations + verbs: + - create + - delete + - get + - list + - patch +- apiGroups: + - certificates.k8s.io + resources: + - signers + resourceNames: + - kubernetes.io/* + verbs: + - approve +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app: kubeflow-pipelines-cache-deployer-role + app.kubernetes.io/name: my-release + name: kubeflow-pipelines-cache-deployer-role +rules: +- apiGroups: + - "" + resources: + - secrets + verbs: + - create + - delete + - get + - patch + - list +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app: kubeflow-pipelines-cache-role + app.kubernetes.io/name: my-release + 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: kubeflow-pipelines-cache-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: kubeflow-pipelines-cache-role +subjects: +- kind: ServiceAccount + name: kubeflow-pipelines-cache + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: kubeflow-pipelines-cache-deployer-clusterrolebinding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: kubeflow-pipelines-cache-deployer-clusterrole +subjects: +- kind: ServiceAccount + name: kubeflow-pipelines-cache-deployer-sa + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: kubeflow-pipelines-cache-deployer-rolebinding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: kubeflow-pipelines-cache-deployer-role +subjects: +- kind: ServiceAccount + name: kubeflow-pipelines-cache-deployer-sa + namespace: kubeflow +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: cache-deployer-deployment + labels: + app: cache-deployer + app.kubernetes.io/name: my-release +spec: + replicas: 1 + selector: + matchLabels: + app: cache-deployer + app.kubernetes.io/name: my-release + strategy: + type: Recreate + template: + metadata: + labels: + app: cache-deployer + app.kubernetes.io/name: my-release + spec: + containers: + - name: main + image: gcr.io/ml-pipeline/google/pipelines/cachedeployer:dummy + imagePullPolicy: Always + env: + - name: NAMESPACE_TO_WATCH + value: kubeflow + serviceAccountName: kubeflow-pipelines-cache-deployer-sa + restartPolicy: Always +--- +apiVersion: v1 +kind: ConfigMap +metadata: + name: cache-configmap + labels: + component: cache-server +data: + mysql_database: 'my_release_cachedb' + mysql_driver: "mysql" + mysql_host: "mysql" + mysql_port: "3306" +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: cache-server + labels: + app: cache-server + app.kubernetes.io/name: my-release +spec: + replicas: 1 + selector: + matchLabels: + app: cache-server + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: cache-server + app.kubernetes.io/name: my-release + spec: + containers: + - name: server + image: gcr.io/ml-pipeline/google/pipelines/cacheserver:dummy + env: + + - name: DBCONFIG_USER + value: 'root' + - name: DBCONFIG_PASSWORD + value: '' + + - name: DBCONFIG_DRIVER + valueFrom: + configMapKeyRef: + name: cache-configmap + key: mysql_driver + - name: DBCONFIG_DB_NAME + valueFrom: + configMapKeyRef: + name: cache-configmap + key: mysql_database + - name: DBCONFIG_HOST_NAME + valueFrom: + configMapKeyRef: + name: cache-configmap + key: mysql_host + - name: DBCONFIG_PORT + valueFrom: + configMapKeyRef: + name: cache-configmap + key: mysql_port + - name: NAMESPACE_TO_WATCH + value: kubeflow + 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)", + ] + imagePullPolicy: Always + ports: + - containerPort: 8443 + name: webhook-api + volumeMounts: + - name: webhook-tls-certs + mountPath: /etc/webhook/certs + readOnly: true + volumes: + - name: webhook-tls-certs + secret: + secretName: webhook-server-tls + serviceAccountName: kubeflow-pipelines-cache +--- +apiVersion: v1 +kind: Service +metadata: + name: cache-server + labels: + app: cache-server + app.kubernetes.io/name: my-release +spec: + selector: + app: cache-server + app.kubernetes.io/name: my-release + ports: + - port: 443 + targetPort: webhook-api + +--- +# Source: kubeflow-pipelines/templates/proxy.yaml +apiVersion: v1 +kind: ServiceAccount +metadata: + name: proxy-agent-runner + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app: proxy-agent-runner + app.kubernetes.io/name: my-release + name: proxy-agent-runner +rules: + - apiGroups: + - "" + resources: + - configmaps + verbs: + - '*' +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + app.kubernetes.io/name: my-release + app: proxy-agent-runner + name: proxy-agent-runner +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: proxy-agent-runner +subjects: + - kind: ServiceAccount + name: proxy-agent-runner + namespace: kubeflow +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: proxy-agent + app.kubernetes.io/name: my-release + name: proxy-agent +spec: + selector: + matchLabels: + app: proxy-agent + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: proxy-agent + app.kubernetes.io/name: my-release + spec: + hostNetwork: true + containers: + - image: gcr.io/ml-pipeline/google/pipelines/proxyagent:dummy + imagePullPolicy: IfNotPresent + name: proxy-agent + serviceAccountName: proxy-agent-runner +--- +apiVersion: v1 +kind: ConfigMap +metadata: + name: inverse-proxy-config + labels: + app.kubernetes.io/name: my-release + +--- +# Source: kubeflow-pipelines/templates/argo.yaml +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: workflows.argoproj.io + labels: + app.kubernetes.io/name: my-release +spec: + group: argoproj.io + names: + kind: Workflow + plural: workflows + shortNames: + - wf + scope: Namespaced + version: v1alpha1 +--- +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: clusterworkflowtemplates.argoproj.io + labels: + app.kubernetes.io/name: my-release +spec: + group: argoproj.io + names: + kind: ClusterWorkflowTemplate + plural: clusterworkflowtemplates + shortNames: + - clusterwftmpl + - cwft + scope: Cluster + version: v1alpha1 +--- +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: cronworkflows.argoproj.io + labels: + app.kubernetes.io/name: my-release +spec: + group: argoproj.io + names: + kind: CronWorkflow + plural: cronworkflows + shortNames: + - cronwf + - cwf + scope: Namespaced + version: v1alpha1 +--- +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: workflowtemplates.argoproj.io + labels: + app.kubernetes.io/name: my-release +spec: + group: argoproj.io + names: + kind: WorkflowTemplate + plural: workflowtemplates + shortNames: + - wftmpl + scope: Namespaced + version: v1alpha1 +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: argo + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: argo-role + labels: + app.kubernetes.io/name: my-release +rules: + - apiGroups: + - "" + resources: + - pods + - pods/exec + verbs: + - create + - get + - list + - watch + - update + - patch + - delete + - apiGroups: + - "" + resources: + - configmaps + verbs: + - get + - watch + - list + - apiGroups: + - "" + resources: + - persistentvolumeclaims + - events + verbs: + - create + - delete + - apiGroups: + - argoproj.io + resources: + - workflows + - workflows/finalizers + - workflowtemplates + - workflowtemplates/finalizers + - cronworkflows + verbs: + - get + - list + - watch + - update + - patch + - delete +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: argo-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: argo-role +subjects: + - kind: ServiceAccount + name: argo + namespace: kubeflow +--- +apiVersion: v1 +data: + config: | + { + namespace: kubeflow, + executorImage: gcr.io/ml-pipeline/google/pipelines/argoexecutor:dummy, + artifactRepository: + { + s3: { + bucket: 'mlpipeline', + keyPrefix: artifacts, + endpoint: minio-service.kubeflow:9000, + insecure: true, + accessKeySecret: { + name: mlpipeline-minio-artifact, + key: accesskey + }, + secretKeySecret: { + name: mlpipeline-minio-artifact, + key: secretkey + } + }, + archiveLogs: true + } + } +kind: ConfigMap +metadata: + name: workflow-controller-configmap + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +data: + accesskey: bWluaW8= + secretkey: bWluaW8xMjM= +kind: Secret +metadata: + name: mlpipeline-minio-artifact + labels: + app.kubernetes.io/name: my-release +type: Opaque +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: workflow-controller + app.kubernetes.io/name: my-release + name: workflow-controller +spec: + progressDeadlineSeconds: 600 + replicas: 1 + revisionHistoryLimit: 10 + selector: + matchLabels: + app: workflow-controller + app.kubernetes.io/name: my-release + strategy: + rollingUpdate: + maxSurge: 25% + maxUnavailable: 25% + type: RollingUpdate + template: + metadata: + creationTimestamp: null + labels: + app: workflow-controller + app.kubernetes.io/name: my-release + spec: + containers: + - args: + - --configmap + - workflow-controller-configmap + - --executor-image + - gcr.io/ml-pipeline/google/pipelines/argoexecutor:dummy + command: + - workflow-controller + env: + - name: ARGO_NAMESPACE + valueFrom: + fieldRef: + apiVersion: v1 + fieldPath: metadata.namespace + image: gcr.io/ml-pipeline/google/pipelines/argoworkflowcontroller:dummy + imagePullPolicy: IfNotPresent + name: workflow-controller + resources: {} + terminationMessagePath: /dev/termination-log + terminationMessagePolicy: File + dnsPolicy: ClusterFirst + restartPolicy: Always + schedulerName: default-scheduler + serviceAccountName: argo + terminationGracePeriodSeconds: 30 + +--- +# Source: kubeflow-pipelines/templates/pipeline.yaml +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: scheduledworkflows.kubeflow.org + labels: + app.kubernetes.io/name: my-release +spec: + group: kubeflow.org + names: + kind: ScheduledWorkflow + listKind: ScheduledWorkflowList + plural: scheduledworkflows + shortNames: + - swf + singular: scheduledworkflow + scope: Namespaced + versions: + - name: v1beta1 + served: true + storage: true +--- +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + labels: + app.kubernetes.io/name: my-release + name: viewers.kubeflow.org +spec: + group: kubeflow.org + names: + kind: Viewer + listKind: ViewerList + plural: viewers + shortNames: + - vi + singular: viewer + scope: Namespaced + versions: + - name: v1beta1 + served: true + storage: true +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-persistenceagent + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-scheduledworkflow + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-ui + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-viewer-crd-service-account + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-visualizationserver + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: pipeline-runner + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: ml-pipeline-persistenceagent-role + labels: + app.kubernetes.io/name: my-release +rules: + - apiGroups: + - argoproj.io + resources: + - workflows + verbs: + - get + - list + - watch + - apiGroups: + - kubeflow.org + resources: + - scheduledworkflows + verbs: + - get + - list + - watch + - apiGroups: + - '' + resources: + - events + verbs: + - create + - patch +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline-scheduledworkflow-role + 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline-ui + name: ml-pipeline-ui +rules: + - apiGroups: + - "" + resources: + - pods + - pods/log + verbs: + - create + - get + - list + - 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: ml-pipeline-viewer-controller-role + labels: + app.kubernetes.io/name: my-release +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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline + name: ml-pipeline +rules: + - apiGroups: + - "" + resources: + - pods + 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: pipeline-runner + labels: + app.kubernetes.io/name: my-release +rules: + - 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: + - '*' +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: ml-pipeline-persistenceagent-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline-persistenceagent-role +subjects: + - kind: ServiceAccount + name: ml-pipeline-persistenceagent + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: ml-pipeline-scheduledworkflow-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline-scheduledworkflow-role +subjects: + - kind: ServiceAccount + name: ml-pipeline-scheduledworkflow + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline-ui + name: ml-pipeline-ui +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline-ui +subjects: + - kind: ServiceAccount + name: ml-pipeline-ui + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline + name: ml-pipeline +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline +subjects: + - kind: ServiceAccount + name: ml-pipeline + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: pipeline-runner-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: pipeline-runner +subjects: + - kind: ServiceAccount + name: pipeline-runner + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: ml-pipeline-viewer-crd-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline-viewer-controller-role +subjects: + - kind: ServiceAccount + name: ml-pipeline-viewer-crd-service-account + namespace: kubeflow +--- +apiVersion: v1 +kind: Service +metadata: + labels: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release + name: ml-pipeline-ui +spec: + ports: + - port: 80 + targetPort: 3000 + selector: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: Service +metadata: + name: ml-pipeline-visualizationserver +spec: + ports: + - name: http + port: 8888 + protocol: TCP + targetPort: 8888 + selector: + app: ml-pipeline-visualizationserver + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: Service +metadata: + name: ml-pipeline + labels: + app.kubernetes.io/name: my-release +spec: + ports: + - name: http + port: 8888 + protocol: TCP + targetPort: 8888 + - name: grpc + port: 8887 + protocol: TCP + targetPort: 8887 + selector: + app: ml-pipeline + app.kubernetes.io/name: my-release +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-persistenceagent + app.kubernetes.io/name: my-release + name: ml-pipeline-persistenceagent +spec: + selector: + matchLabels: + app: ml-pipeline-persistenceagent + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-persistenceagent + app.kubernetes.io/name: my-release + spec: + containers: + - env: + - name: NAMESPACE + value: kubeflow + - name: TTL_SECONDS_AFTER_WORKFLOW_FINISH + value: "86400" + image: gcr.io/ml-pipeline/google/pipelines/persistenceagent:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-persistenceagent + serviceAccountName: ml-pipeline-persistenceagent +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-scheduledworkflow + app.kubernetes.io/name: my-release + name: ml-pipeline-scheduledworkflow +spec: + selector: + matchLabels: + app: ml-pipeline-scheduledworkflow + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-scheduledworkflow + app.kubernetes.io/name: my-release + spec: + containers: + - env: + - name: NAMESPACE + value: kubeflow + image: gcr.io/ml-pipeline/google/pipelines/scheduledworkflow:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-scheduledworkflow + serviceAccountName: ml-pipeline-scheduledworkflow +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release + name: ml-pipeline-ui +spec: + selector: + matchLabels: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release + spec: + containers: + - env: + - name: MINIO_NAMESPACE + value: kubeflow + - name: ALLOW_CUSTOM_VISUALIZATIONS + value: "true" + - name: DEPLOYMENT + value: MARKETPLACE + image: gcr.io/ml-pipeline/google/pipelines/frontend:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-ui + ports: + - containerPort: 3000 + readinessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:3000/apis/v1beta1/healthz + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + livenessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:3000/apis/v1beta1/healthz + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + serviceAccountName: ml-pipeline-ui +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-viewer-crd + app.kubernetes.io/name: my-release + name: ml-pipeline-viewer-crd +spec: + selector: + matchLabels: + app: ml-pipeline-viewer-crd + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-viewer-crd + app.kubernetes.io/name: my-release + spec: + containers: + - env: + - name: MAX_NUM_VIEWERS + value: "50" + - name: NAMESPACE + value: kubeflow + image: gcr.io/ml-pipeline/google/pipelines/viewercrd:dummy + imagePullPolicy: Always + name: ml-pipeline-viewer-crd + serviceAccountName: ml-pipeline-viewer-crd-service-account +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-visualizationserver + app.kubernetes.io/name: my-release + name: ml-pipeline-visualizationserver +spec: + selector: + matchLabels: + app: ml-pipeline-visualizationserver + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-visualizationserver + app.kubernetes.io/name: my-release + spec: + containers: + - image: gcr.io/ml-pipeline/google/pipelines/visualizationserver:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-visualizationserver + ports: + - name: http + containerPort: 8888 + readinessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:8888/ + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + livenessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:8888/ + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + serviceAccountName: ml-pipeline-visualizationserver +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline + app.kubernetes.io/name: my-release + name: ml-pipeline +spec: + selector: + matchLabels: + app: ml-pipeline + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline + app.kubernetes.io/name: my-release + spec: + containers: + - env: + + - name: HAS_DEFAULT_BUCKET + valueFrom: + configMapKeyRef: + name: "gcp-default-config" + key: "has_default_bucket" + - name: BUCKET_NAME + valueFrom: + configMapKeyRef: + name: "gcp-default-config" + key: "bucket_name" + + - name: PROJECT_ID + valueFrom: + configMapKeyRef: + name: "gcp-default-config" + key: "project_id" + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + - name: DEFAULTPIPELINERUNNERSERVICEACCOUNT + value: 'pipeline-runner' + - name: OBJECTSTORECONFIG_SECURE + value: "false" + + image: gcr.io/ml-pipeline/google/pipelines/apiserver:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-api-server + ports: + - name: http + containerPort: 8888 + - name: grpc + containerPort: 8887 + readinessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:8888/apis/v1beta1/healthz + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + livenessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:8888/apis/v1beta1/healthz + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + serviceAccountName: ml-pipeline +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: kubeflow-pipelines-container-builder + +--- +# Source: kubeflow-pipelines/templates/metadata.yaml +apiVersion: v1 +kind: Service +metadata: + labels: + app: metadata + app.kubernetes.io/name: my-release + name: metadata-grpc-service +spec: + ports: + - name: grpc-api + port: 8080 + protocol: TCP + selector: + component: metadata-grpc-server + app.kubernetes.io/name: my-release +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + component: metadata-grpc-server + app.kubernetes.io/name: my-release + name: metadata-grpc-deployment +spec: + replicas: 1 + selector: + matchLabels: + component: metadata-grpc-server + app.kubernetes.io/name: my-release + template: + metadata: + labels: + component: metadata-grpc-server + app.kubernetes.io/name: my-release + spec: + containers: + - name: container + image: gcr.io/ml-pipeline/google/pipelines/metadataserver:dummy + imagePullPolicy: 'Always' + env: + # TODO: merge all into mysql-credential + + - name: DBCONFIG_USER + value: 'root' + - name: DBCONFIG_PASSWORD + value: '' + + - name: MYSQL_DATABASE + valueFrom: + configMapKeyRef: + name: metadata-mysql-configmap + key: MYSQL_DATABASE + - name: MYSQL_HOST + valueFrom: + configMapKeyRef: + name: metadata-mysql-configmap + key: MYSQL_HOST + - name: MYSQL_PORT + valueFrom: + configMapKeyRef: + name: metadata-mysql-configmap + key: MYSQL_PORT + command: ["/bin/metadata_store_server"] + args: ["--grpc_port=8080", + "--mysql_config_database=$(MYSQL_DATABASE)", + "--mysql_config_host=$(MYSQL_HOST)", + "--mysql_config_port=$(MYSQL_PORT)", + "--mysql_config_user=$(DBCONFIG_USER)", + "--mysql_config_password=$(DBCONFIG_PASSWORD)", + "--enable_database_upgrade=true" + ] + ports: + - containerPort: 8080 + name: grpc-api + livenessProbe: + tcpSocket: + port: grpc-api + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + readinessProbe: + tcpSocket: + port: grpc-api + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 +--- +kind: Service +apiVersion: v1 +metadata: + labels: + app: metadata + app.kubernetes.io/name: my-release + name: metadata-envoy-service +spec: + selector: + component: metadata-envoy + type: ClusterIP + ports: + - port: 9090 + protocol: TCP + name: md-envoy +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: metadata-envoy + labels: + component: metadata-envoy + app.kubernetes.io/name: my-release +spec: + replicas: 1 + selector: + matchLabels: + component: metadata-envoy + template: + metadata: + labels: + component: metadata-envoy + spec: + containers: + - name: container + image: gcr.io/ml-pipeline/google/pipelines/metadataenvoy:dummy + ports: + - name: md-envoy + containerPort: 9090 + - name: envoy-admin + containerPort: 9901 +--- +apiVersion: v1 +kind: ConfigMap +metadata: + name: metadata-mysql-configmap + labels: + component: metadata-server +data: + MYSQL_DATABASE: 'my_release_metadata' + MYSQL_HOST: "mysql" + MYSQL_PORT: "3306" +--- +apiVersion: v1 +kind: ConfigMap +metadata: + name: metadata-grpc-configmap + labels: + component: metadata-grpc-server +data: + METADATA_GRPC_SERVICE_HOST: "metadata-grpc-service" + METADATA_GRPC_SERVICE_PORT: "8080" +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: metadata-writer + labels: + app: metadata-writer + app.kubernetes.io/name: my-release +spec: + replicas: 1 + selector: + matchLabels: + app: metadata-writer + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: metadata-writer + app.kubernetes.io/name: my-release + spec: + containers: + - name: main + image: gcr.io/ml-pipeline/google/pipelines/metadatawriter:dummy + env: + - name: NAMESPACE_TO_WATCH + valueFrom: + fieldRef: + fieldPath: metadata.namespace + serviceAccountName: kubeflow-pipelines-metadata-writer +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app: kubeflow-pipelines-metadata-writer-role + app.kubernetes.io/name: my-release + 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: kubeflow-pipelines-metadata-writer-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: kubeflow-pipelines-metadata-writer-role +subjects: +- kind: ServiceAccount + name: kubeflow-pipelines-metadata-writer + namespace: kubeflow +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: kubeflow-pipelines-metadata-writer + labels: + app.kubernetes.io/name: my-release + +--- +# Source: kubeflow-pipelines/templates/minio.yaml +apiVersion: v1 +kind: Service +metadata: + name: minio-service + labels: + app.kubernetes.io/name: my-release +spec: + ports: + - port: 9000 + protocol: TCP + targetPort: 9000 + selector: + app: minio + app.kubernetes.io/name: my-release +--- + +--- + +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: minio-pvc + labels: + app.kubernetes.io/name: my-release +spec: + accessModes: + - ReadWriteOnce + resources: + requests: + storage: 20Gi +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: minio + labels: + app: minio + app.kubernetes.io/name: my-release +spec: + selector: + matchLabels: + app: minio + app.kubernetes.io/name: my-release + strategy: + type: Recreate + template: + metadata: + labels: + app: minio + app.kubernetes.io/name: my-release + spec: + containers: + - args: + - server + - /data + env: + - name: MINIO_ACCESS_KEY + value: minio + - name: MINIO_SECRET_KEY + value: minio123 + image: gcr.io/ml-pipeline/google/pipelines/minio:dummy + name: minio + ports: + - containerPort: 9000 + volumeMounts: + - mountPath: /data + name: data + subPath: minio + volumes: + - name: data + persistentVolumeClaim: + claimName: minio-pvc + + +--- +# Source: kubeflow-pipelines/templates/mysql.yaml +apiVersion: v1 +kind: Service +metadata: + name: mysql + labels: + app.kubernetes.io/name: my-release +spec: + ports: + - port: 3306 + selector: + + app: mysql + + app.kubernetes.io/name: my-release +--- + +apiVersion: v1 +kind: PersistentVolumeClaim +metadata: + name: mysql-pv-claim + labels: + app.kubernetes.io/name: my-release +spec: + accessModes: + - ReadWriteOnce + resources: + requests: + storage: 20Gi +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: mysql + labels: + app.kubernetes.io/name: my-release +spec: + selector: + matchLabels: + app: mysql + app.kubernetes.io/name: my-release + strategy: + type: Recreate + template: + metadata: + labels: + app: mysql + app.kubernetes.io/name: my-release + spec: + containers: + - env: + - name: MYSQL_ALLOW_EMPTY_PASSWORD + value: "true" + image: gcr.io/ml-pipeline/google/pipelines/mysql:dummy + name: mysql + ports: + - containerPort: 3306 + name: mysql + volumeMounts: + - mountPath: /var/lib/mysql + name: mysql-persistent-storage + volumes: + - name: mysql-persistent-storage + persistentVolumeClaim: + claimName: mysql-pv-claim + + +--- +# Source: kubeflow-pipelines/templates/application.yaml +apiVersion: app.k8s.io/v1beta1 +kind: Application +metadata: + name: "my-release" + namespace: "kubeflow" + annotations: + kubernetes-engine.cloud.google.com/icon: >- +  + marketplace.cloud.google.com/deploy-info: '{"partner_id": "google-cloud-ai-platform", + "product_id": "kubeflow-pipelines", "partner_name": "Google Cloud AI Platform"}' + labels: + app.kubernetes.io/name: "my-release" +spec: + descriptor: + type: Kubeflow Pipelines + version: 1.0.0 + description: |- + Reusable end-to-end ML workflow + maintainers: + - name: Google Cloud AI Platform + url: https://cloud.google.com/ai-platform/ + - name: Kubeflow Pipelines + url: https://github.com/kubeflow/pipelines + links: + - description: 'Kubeflow Pipelines Documentation' + url: https://www.kubeflow.org/docs/pipelines/ + notes: |- + Please go to [Hosted Kubeflow Pipelines Console](https://console.cloud.google.com/ai-platform/pipelines/clusters). + info: + - name: Application Namespace + value: "kubeflow" + - name: Console + value: 'https://console.cloud.google.com/ai-platform/pipelines/clusters' + componentKinds: + - 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: ConfigMap + - group: v1 + kind: Secret + - group: apps/v1 + kind: Deployment + diff --git a/manifests/gcp_marketplace/test/snapshot-managed-storage-with-db-prefix.yaml b/manifests/gcp_marketplace/test/snapshot-managed-storage-with-db-prefix.yaml new file mode 100644 index 00000000000..ceae7d05ed6 --- /dev/null +++ b/manifests/gcp_marketplace/test/snapshot-managed-storage-with-db-prefix.yaml @@ -0,0 +1,1858 @@ +--- +# Source: kubeflow-pipelines/templates/config-snapshot.yaml +apiVersion: v1 +kind: ConfigMap +metadata: + name: ml-pipeline-install-config-snapshot + labels: + app.kubernetes.io/name: 'my-release' + annotations: + pipelines.kubeflow.org/comment: |- + This is a snapshot of install parameters. There's no effect modifying this. +data: + appName: 'my-release' + namespace: 'kubeflow' + managedStorageEnabled: 'true' + # + managedStorageCloudSqlInstanceConnectionName: 'myproject:us-central1:myinstance' + managedStorageGcsBucketName: 'mybucket' + managedStorageDatabasePrefix: 'my_kfp' + managedstorageDbUserName: 'root' + # +--- +apiVersion: v1 +kind: Secret +metadata: + name: ml-pipeline-install-secret-snapshot + labels: + app.kubernetes.io/name: 'my-release' + annotations: + pipelines.kubeflow.org/comment: |- + This is a snapshot of install secrets. There's no effect modifying this. +type: Opaque +# +data: + managedStorageDbPassword: 'MTIzNA==' +# + +--- +# Source: kubeflow-pipelines/templates/cache.yaml +apiVersion: v1 +kind: ServiceAccount +metadata: + name: kubeflow-pipelines-cache-deployer-sa + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: kubeflow-pipelines-cache + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + labels: + app: kubeflow-pipelines-cache-deployer-clusterrole + app.kubernetes.io/name: my-release + name: kubeflow-pipelines-cache-deployer-clusterrole +rules: +- apiGroups: + - certificates.k8s.io + resources: + - certificatesigningrequests + - certificatesigningrequests/approval + verbs: + - create + - delete + - get + - update +- apiGroups: + - admissionregistration.k8s.io + resources: + - mutatingwebhookconfigurations + verbs: + - create + - delete + - get + - list + - patch +- apiGroups: + - certificates.k8s.io + resources: + - signers + resourceNames: + - kubernetes.io/* + verbs: + - approve +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app: kubeflow-pipelines-cache-deployer-role + app.kubernetes.io/name: my-release + name: kubeflow-pipelines-cache-deployer-role +rules: +- apiGroups: + - "" + resources: + - secrets + verbs: + - create + - delete + - get + - patch + - list +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app: kubeflow-pipelines-cache-role + app.kubernetes.io/name: my-release + 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: kubeflow-pipelines-cache-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: kubeflow-pipelines-cache-role +subjects: +- kind: ServiceAccount + name: kubeflow-pipelines-cache + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: kubeflow-pipelines-cache-deployer-clusterrolebinding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: kubeflow-pipelines-cache-deployer-clusterrole +subjects: +- kind: ServiceAccount + name: kubeflow-pipelines-cache-deployer-sa + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: kubeflow-pipelines-cache-deployer-rolebinding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: kubeflow-pipelines-cache-deployer-role +subjects: +- kind: ServiceAccount + name: kubeflow-pipelines-cache-deployer-sa + namespace: kubeflow +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: cache-deployer-deployment + labels: + app: cache-deployer + app.kubernetes.io/name: my-release +spec: + replicas: 1 + selector: + matchLabels: + app: cache-deployer + app.kubernetes.io/name: my-release + strategy: + type: Recreate + template: + metadata: + labels: + app: cache-deployer + app.kubernetes.io/name: my-release + spec: + containers: + - name: main + image: gcr.io/ml-pipeline/google/pipelines/cachedeployer:dummy + imagePullPolicy: Always + env: + - name: NAMESPACE_TO_WATCH + value: kubeflow + serviceAccountName: kubeflow-pipelines-cache-deployer-sa + restartPolicy: Always +--- +apiVersion: v1 +kind: ConfigMap +metadata: + name: cache-configmap + labels: + component: cache-server +data: + mysql_database: 'my_kfp_cachedb' + mysql_driver: "mysql" + mysql_host: "mysql" + mysql_port: "3306" +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: cache-server + labels: + app: cache-server + app.kubernetes.io/name: my-release +spec: + replicas: 1 + selector: + matchLabels: + app: cache-server + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: cache-server + app.kubernetes.io/name: my-release + spec: + containers: + - name: server + image: gcr.io/ml-pipeline/google/pipelines/cacheserver:dummy + env: + + - name: DBCONFIG_USER + valueFrom: + secretKeyRef: + name: mysql-credential + key: username + - name: DBCONFIG_PASSWORD + valueFrom: + secretKeyRef: + name: mysql-credential + key: password + + - name: DBCONFIG_DRIVER + valueFrom: + configMapKeyRef: + name: cache-configmap + key: mysql_driver + - name: DBCONFIG_DB_NAME + valueFrom: + configMapKeyRef: + name: cache-configmap + key: mysql_database + - name: DBCONFIG_HOST_NAME + valueFrom: + configMapKeyRef: + name: cache-configmap + key: mysql_host + - name: DBCONFIG_PORT + valueFrom: + configMapKeyRef: + name: cache-configmap + key: mysql_port + - name: NAMESPACE_TO_WATCH + value: kubeflow + 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)", + ] + imagePullPolicy: Always + ports: + - containerPort: 8443 + name: webhook-api + volumeMounts: + - name: webhook-tls-certs + mountPath: /etc/webhook/certs + readOnly: true + volumes: + - name: webhook-tls-certs + secret: + secretName: webhook-server-tls + serviceAccountName: kubeflow-pipelines-cache +--- +apiVersion: v1 +kind: Service +metadata: + name: cache-server + labels: + app: cache-server + app.kubernetes.io/name: my-release +spec: + selector: + app: cache-server + app.kubernetes.io/name: my-release + ports: + - port: 443 + targetPort: webhook-api + +--- +# Source: kubeflow-pipelines/templates/proxy.yaml +apiVersion: v1 +kind: ServiceAccount +metadata: + name: proxy-agent-runner + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app: proxy-agent-runner + app.kubernetes.io/name: my-release + name: proxy-agent-runner +rules: + - apiGroups: + - "" + resources: + - configmaps + verbs: + - '*' +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + app.kubernetes.io/name: my-release + app: proxy-agent-runner + name: proxy-agent-runner +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: proxy-agent-runner +subjects: + - kind: ServiceAccount + name: proxy-agent-runner + namespace: kubeflow +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: proxy-agent + app.kubernetes.io/name: my-release + name: proxy-agent +spec: + selector: + matchLabels: + app: proxy-agent + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: proxy-agent + app.kubernetes.io/name: my-release + spec: + hostNetwork: true + containers: + - image: gcr.io/ml-pipeline/google/pipelines/proxyagent:dummy + imagePullPolicy: IfNotPresent + name: proxy-agent + serviceAccountName: proxy-agent-runner +--- +apiVersion: v1 +kind: ConfigMap +metadata: + name: inverse-proxy-config + labels: + app.kubernetes.io/name: my-release + +--- +# Source: kubeflow-pipelines/templates/argo.yaml +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: workflows.argoproj.io + labels: + app.kubernetes.io/name: my-release +spec: + group: argoproj.io + names: + kind: Workflow + plural: workflows + shortNames: + - wf + scope: Namespaced + version: v1alpha1 +--- +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: clusterworkflowtemplates.argoproj.io + labels: + app.kubernetes.io/name: my-release +spec: + group: argoproj.io + names: + kind: ClusterWorkflowTemplate + plural: clusterworkflowtemplates + shortNames: + - clusterwftmpl + - cwft + scope: Cluster + version: v1alpha1 +--- +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: cronworkflows.argoproj.io + labels: + app.kubernetes.io/name: my-release +spec: + group: argoproj.io + names: + kind: CronWorkflow + plural: cronworkflows + shortNames: + - cronwf + - cwf + scope: Namespaced + version: v1alpha1 +--- +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: workflowtemplates.argoproj.io + labels: + app.kubernetes.io/name: my-release +spec: + group: argoproj.io + names: + kind: WorkflowTemplate + plural: workflowtemplates + shortNames: + - wftmpl + scope: Namespaced + version: v1alpha1 +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: argo + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: argo-role + labels: + app.kubernetes.io/name: my-release +rules: + - apiGroups: + - "" + resources: + - pods + - pods/exec + verbs: + - create + - get + - list + - watch + - update + - patch + - delete + - apiGroups: + - "" + resources: + - configmaps + verbs: + - get + - watch + - list + - apiGroups: + - "" + resources: + - persistentvolumeclaims + - events + verbs: + - create + - delete + - apiGroups: + - argoproj.io + resources: + - workflows + - workflows/finalizers + - workflowtemplates + - workflowtemplates/finalizers + - cronworkflows + verbs: + - get + - list + - watch + - update + - patch + - delete +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: argo-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: argo-role +subjects: + - kind: ServiceAccount + name: argo + namespace: kubeflow +--- +apiVersion: v1 +data: + config: | + { + namespace: kubeflow, + executorImage: gcr.io/ml-pipeline/google/pipelines/argoexecutor:dummy, + artifactRepository: + { + s3: { + bucket: 'mybucket', + keyPrefix: artifacts, + endpoint: minio-service.kubeflow:9000, + insecure: true, + accessKeySecret: { + name: mlpipeline-minio-artifact, + key: accesskey + }, + secretKeySecret: { + name: mlpipeline-minio-artifact, + key: secretkey + } + }, + archiveLogs: true + } + } +kind: ConfigMap +metadata: + name: workflow-controller-configmap + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +data: + accesskey: bWluaW8= + secretkey: bWluaW8xMjM= +kind: Secret +metadata: + name: mlpipeline-minio-artifact + labels: + app.kubernetes.io/name: my-release +type: Opaque +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: workflow-controller + app.kubernetes.io/name: my-release + name: workflow-controller +spec: + progressDeadlineSeconds: 600 + replicas: 1 + revisionHistoryLimit: 10 + selector: + matchLabels: + app: workflow-controller + app.kubernetes.io/name: my-release + strategy: + rollingUpdate: + maxSurge: 25% + maxUnavailable: 25% + type: RollingUpdate + template: + metadata: + creationTimestamp: null + labels: + app: workflow-controller + app.kubernetes.io/name: my-release + spec: + containers: + - args: + - --configmap + - workflow-controller-configmap + - --executor-image + - gcr.io/ml-pipeline/google/pipelines/argoexecutor:dummy + command: + - workflow-controller + env: + - name: ARGO_NAMESPACE + valueFrom: + fieldRef: + apiVersion: v1 + fieldPath: metadata.namespace + image: gcr.io/ml-pipeline/google/pipelines/argoworkflowcontroller:dummy + imagePullPolicy: IfNotPresent + name: workflow-controller + resources: {} + terminationMessagePath: /dev/termination-log + terminationMessagePolicy: File + dnsPolicy: ClusterFirst + restartPolicy: Always + schedulerName: default-scheduler + serviceAccountName: argo + terminationGracePeriodSeconds: 30 + +--- +# Source: kubeflow-pipelines/templates/pipeline.yaml +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: scheduledworkflows.kubeflow.org + labels: + app.kubernetes.io/name: my-release +spec: + group: kubeflow.org + names: + kind: ScheduledWorkflow + listKind: ScheduledWorkflowList + plural: scheduledworkflows + shortNames: + - swf + singular: scheduledworkflow + scope: Namespaced + versions: + - name: v1beta1 + served: true + storage: true +--- +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + labels: + app.kubernetes.io/name: my-release + name: viewers.kubeflow.org +spec: + group: kubeflow.org + names: + kind: Viewer + listKind: ViewerList + plural: viewers + shortNames: + - vi + singular: viewer + scope: Namespaced + versions: + - name: v1beta1 + served: true + storage: true +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-persistenceagent + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-scheduledworkflow + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-ui + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-viewer-crd-service-account + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-visualizationserver + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: pipeline-runner + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: ml-pipeline-persistenceagent-role + labels: + app.kubernetes.io/name: my-release +rules: + - apiGroups: + - argoproj.io + resources: + - workflows + verbs: + - get + - list + - watch + - apiGroups: + - kubeflow.org + resources: + - scheduledworkflows + verbs: + - get + - list + - watch + - apiGroups: + - '' + resources: + - events + verbs: + - create + - patch +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline-scheduledworkflow-role + 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline-ui + name: ml-pipeline-ui +rules: + - apiGroups: + - "" + resources: + - pods + - pods/log + verbs: + - create + - get + - list + - 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: ml-pipeline-viewer-controller-role + labels: + app.kubernetes.io/name: my-release +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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline + name: ml-pipeline +rules: + - apiGroups: + - "" + resources: + - pods + 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: pipeline-runner + labels: + app.kubernetes.io/name: my-release +rules: + - 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: + - '*' +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: ml-pipeline-persistenceagent-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline-persistenceagent-role +subjects: + - kind: ServiceAccount + name: ml-pipeline-persistenceagent + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: ml-pipeline-scheduledworkflow-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline-scheduledworkflow-role +subjects: + - kind: ServiceAccount + name: ml-pipeline-scheduledworkflow + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline-ui + name: ml-pipeline-ui +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline-ui +subjects: + - kind: ServiceAccount + name: ml-pipeline-ui + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline + name: ml-pipeline +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline +subjects: + - kind: ServiceAccount + name: ml-pipeline + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: pipeline-runner-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: pipeline-runner +subjects: + - kind: ServiceAccount + name: pipeline-runner + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: ml-pipeline-viewer-crd-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline-viewer-controller-role +subjects: + - kind: ServiceAccount + name: ml-pipeline-viewer-crd-service-account + namespace: kubeflow +--- +apiVersion: v1 +kind: Service +metadata: + labels: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release + name: ml-pipeline-ui +spec: + ports: + - port: 80 + targetPort: 3000 + selector: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: Service +metadata: + name: ml-pipeline-visualizationserver +spec: + ports: + - name: http + port: 8888 + protocol: TCP + targetPort: 8888 + selector: + app: ml-pipeline-visualizationserver + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: Service +metadata: + name: ml-pipeline + labels: + app.kubernetes.io/name: my-release +spec: + ports: + - name: http + port: 8888 + protocol: TCP + targetPort: 8888 + - name: grpc + port: 8887 + protocol: TCP + targetPort: 8887 + selector: + app: ml-pipeline + app.kubernetes.io/name: my-release +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-persistenceagent + app.kubernetes.io/name: my-release + name: ml-pipeline-persistenceagent +spec: + selector: + matchLabels: + app: ml-pipeline-persistenceagent + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-persistenceagent + app.kubernetes.io/name: my-release + spec: + containers: + - env: + - name: NAMESPACE + value: kubeflow + - name: TTL_SECONDS_AFTER_WORKFLOW_FINISH + value: "86400" + image: gcr.io/ml-pipeline/google/pipelines/persistenceagent:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-persistenceagent + serviceAccountName: ml-pipeline-persistenceagent +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-scheduledworkflow + app.kubernetes.io/name: my-release + name: ml-pipeline-scheduledworkflow +spec: + selector: + matchLabels: + app: ml-pipeline-scheduledworkflow + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-scheduledworkflow + app.kubernetes.io/name: my-release + spec: + containers: + - env: + - name: NAMESPACE + value: kubeflow + image: gcr.io/ml-pipeline/google/pipelines/scheduledworkflow:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-scheduledworkflow + serviceAccountName: ml-pipeline-scheduledworkflow +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release + name: ml-pipeline-ui +spec: + selector: + matchLabels: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release + spec: + containers: + - env: + - name: MINIO_NAMESPACE + value: kubeflow + - name: ALLOW_CUSTOM_VISUALIZATIONS + value: "true" + - name: DEPLOYMENT + value: MARKETPLACE + image: gcr.io/ml-pipeline/google/pipelines/frontend:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-ui + ports: + - containerPort: 3000 + readinessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:3000/apis/v1beta1/healthz + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + livenessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:3000/apis/v1beta1/healthz + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + serviceAccountName: ml-pipeline-ui +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-viewer-crd + app.kubernetes.io/name: my-release + name: ml-pipeline-viewer-crd +spec: + selector: + matchLabels: + app: ml-pipeline-viewer-crd + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-viewer-crd + app.kubernetes.io/name: my-release + spec: + containers: + - env: + - name: MAX_NUM_VIEWERS + value: "50" + - name: NAMESPACE + value: kubeflow + image: gcr.io/ml-pipeline/google/pipelines/viewercrd:dummy + imagePullPolicy: Always + name: ml-pipeline-viewer-crd + serviceAccountName: ml-pipeline-viewer-crd-service-account +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-visualizationserver + app.kubernetes.io/name: my-release + name: ml-pipeline-visualizationserver +spec: + selector: + matchLabels: + app: ml-pipeline-visualizationserver + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-visualizationserver + app.kubernetes.io/name: my-release + spec: + containers: + - image: gcr.io/ml-pipeline/google/pipelines/visualizationserver:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-visualizationserver + ports: + - name: http + containerPort: 8888 + readinessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:8888/ + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + livenessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:8888/ + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + serviceAccountName: ml-pipeline-visualizationserver +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline + app.kubernetes.io/name: my-release + name: ml-pipeline +spec: + selector: + matchLabels: + app: ml-pipeline + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline + app.kubernetes.io/name: my-release + spec: + containers: + - env: + + - name: HAS_DEFAULT_BUCKET + value: "true" + - name: BUCKET_NAME + value: "mybucket" + + - name: PROJECT_ID + valueFrom: + configMapKeyRef: + name: "gcp-default-config" + key: "project_id" + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + - name: DEFAULTPIPELINERUNNERSERVICEACCOUNT + value: 'pipeline-runner' + - name: OBJECTSTORECONFIG_SECURE + value: "false" + + - name: OBJECTSTORECONFIG_BUCKETNAME + value: "mybucket" + - name: DBCONFIG_DBNAME + value: 'my_kfp_pipeline' + - name: DBCONFIG_USER + valueFrom: + secretKeyRef: + name: mysql-credential + key: username + - name: DBCONFIG_PASSWORD + valueFrom: + secretKeyRef: + name: mysql-credential + key: password + + image: gcr.io/ml-pipeline/google/pipelines/apiserver:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-api-server + ports: + - name: http + containerPort: 8888 + - name: grpc + containerPort: 8887 + readinessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:8888/apis/v1beta1/healthz + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + livenessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:8888/apis/v1beta1/healthz + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + serviceAccountName: ml-pipeline +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: kubeflow-pipelines-container-builder + +--- +# Source: kubeflow-pipelines/templates/metadata.yaml +apiVersion: v1 +kind: Service +metadata: + labels: + app: metadata + app.kubernetes.io/name: my-release + name: metadata-grpc-service +spec: + ports: + - name: grpc-api + port: 8080 + protocol: TCP + selector: + component: metadata-grpc-server + app.kubernetes.io/name: my-release +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + component: metadata-grpc-server + app.kubernetes.io/name: my-release + name: metadata-grpc-deployment +spec: + replicas: 1 + selector: + matchLabels: + component: metadata-grpc-server + app.kubernetes.io/name: my-release + template: + metadata: + labels: + component: metadata-grpc-server + app.kubernetes.io/name: my-release + spec: + containers: + - name: container + image: gcr.io/ml-pipeline/google/pipelines/metadataserver:dummy + imagePullPolicy: 'Always' + env: + # TODO: merge all into mysql-credential + + - name: DBCONFIG_USER + valueFrom: + secretKeyRef: + name: mysql-credential + key: username + - name: DBCONFIG_PASSWORD + valueFrom: + secretKeyRef: + name: mysql-credential + key: password + + - name: MYSQL_DATABASE + valueFrom: + configMapKeyRef: + name: metadata-mysql-configmap + key: MYSQL_DATABASE + - name: MYSQL_HOST + valueFrom: + configMapKeyRef: + name: metadata-mysql-configmap + key: MYSQL_HOST + - name: MYSQL_PORT + valueFrom: + configMapKeyRef: + name: metadata-mysql-configmap + key: MYSQL_PORT + command: ["/bin/metadata_store_server"] + args: ["--grpc_port=8080", + "--mysql_config_database=$(MYSQL_DATABASE)", + "--mysql_config_host=$(MYSQL_HOST)", + "--mysql_config_port=$(MYSQL_PORT)", + "--mysql_config_user=$(DBCONFIG_USER)", + "--mysql_config_password=$(DBCONFIG_PASSWORD)", + "--enable_database_upgrade=true" + ] + ports: + - containerPort: 8080 + name: grpc-api + livenessProbe: + tcpSocket: + port: grpc-api + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + readinessProbe: + tcpSocket: + port: grpc-api + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 +--- +kind: Service +apiVersion: v1 +metadata: + labels: + app: metadata + app.kubernetes.io/name: my-release + name: metadata-envoy-service +spec: + selector: + component: metadata-envoy + type: ClusterIP + ports: + - port: 9090 + protocol: TCP + name: md-envoy +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: metadata-envoy + labels: + component: metadata-envoy + app.kubernetes.io/name: my-release +spec: + replicas: 1 + selector: + matchLabels: + component: metadata-envoy + template: + metadata: + labels: + component: metadata-envoy + spec: + containers: + - name: container + image: gcr.io/ml-pipeline/google/pipelines/metadataenvoy:dummy + ports: + - name: md-envoy + containerPort: 9090 + - name: envoy-admin + containerPort: 9901 +--- +apiVersion: v1 +kind: ConfigMap +metadata: + name: metadata-mysql-configmap + labels: + component: metadata-server +data: + MYSQL_DATABASE: 'my_kfp_metadata' + MYSQL_HOST: "mysql" + MYSQL_PORT: "3306" +--- +apiVersion: v1 +kind: ConfigMap +metadata: + name: metadata-grpc-configmap + labels: + component: metadata-grpc-server +data: + METADATA_GRPC_SERVICE_HOST: "metadata-grpc-service" + METADATA_GRPC_SERVICE_PORT: "8080" +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: metadata-writer + labels: + app: metadata-writer + app.kubernetes.io/name: my-release +spec: + replicas: 1 + selector: + matchLabels: + app: metadata-writer + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: metadata-writer + app.kubernetes.io/name: my-release + spec: + containers: + - name: main + image: gcr.io/ml-pipeline/google/pipelines/metadatawriter:dummy + env: + - name: NAMESPACE_TO_WATCH + valueFrom: + fieldRef: + fieldPath: metadata.namespace + serviceAccountName: kubeflow-pipelines-metadata-writer +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app: kubeflow-pipelines-metadata-writer-role + app.kubernetes.io/name: my-release + 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: kubeflow-pipelines-metadata-writer-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: kubeflow-pipelines-metadata-writer-role +subjects: +- kind: ServiceAccount + name: kubeflow-pipelines-metadata-writer + namespace: kubeflow +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: kubeflow-pipelines-metadata-writer + labels: + app.kubernetes.io/name: my-release + +--- +# Source: kubeflow-pipelines/templates/minio.yaml +apiVersion: v1 +kind: Service +metadata: + name: minio-service + labels: + app.kubernetes.io/name: my-release +spec: + ports: + - port: 9000 + protocol: TCP + targetPort: 9000 + selector: + app: minio + app.kubernetes.io/name: my-release +--- + +apiVersion: apps/v1 +kind: Deployment +metadata: + name: minio + labels: + app: minio + app.kubernetes.io/name: my-release +spec: + selector: + matchLabels: + app: minio + app.kubernetes.io/name: my-release + strategy: + type: Recreate + template: + metadata: + labels: + app: minio + app.kubernetes.io/name: my-release + spec: + containers: + - args: + - gateway + - gcs + - $(PROJECT_ID) + env: + - name: PROJECT_ID + valueFrom: + configMapKeyRef: + name: "gcp-default-config" + key: "project_id" + - name: MINIO_ACCESS_KEY + value: minio + - name: MINIO_SECRET_KEY + value: minio123 + # Minio is KFP system workload and we use GCE's default service account + # or later Workload Identity's corresponding service account. + # So here no need to setup GOOGLE_APPLICATION_CREDENTIALS. + # - name: GOOGLE_APPLICATION_CREDENTIALS + # value: "/etc/credentials/application_default_credentials.json" + image: gcr.io/ml-pipeline/google/pipelines/minio:dummy + name: minio + ports: + - containerPort: 9000 + +--- + + +--- +# Source: kubeflow-pipelines/templates/mysql.yaml +apiVersion: v1 +kind: Service +metadata: + name: mysql + labels: + app.kubernetes.io/name: my-release +spec: + ports: + - port: 3306 + selector: + + app: cloudsqlproxy + + app.kubernetes.io/name: my-release +--- + +apiVersion: apps/v1 +kind: Deployment +metadata: + name: cloudsqlproxy + labels: + app: cloudsqlproxy + app.kubernetes.io/name: my-release +spec: + selector: + matchLabels: + app: cloudsqlproxy + app.kubernetes.io/name: my-release + replicas: 1 + template: + metadata: + labels: + app: cloudsqlproxy + app.kubernetes.io/name: my-release + spec: + containers: + - image: gcr.io/ml-pipeline/google/pipelines/cloudsqlproxy:dummy + name: cloudsqlproxy + env: + command: ["/cloud_sql_proxy", + "-dir=/cloudsql", + # Replace with your own CloudSQL instance ID + "-instances=myproject:us-central1:myinstance=tcp:0.0.0.0:3306", + # System workload uses GCE default service account or Workload Identity's service account + # "-credential_file=/credentials/application_default_credentials.json", + "term_timeout=10s"] + # set term_timeout if require graceful handling of shutdown + # NOTE: proxy will stop accepting new connections; only wait on existing connections + lifecycle: + preStop: + exec: + # (optional) add a preStop hook so that termination is delayed + # this is required if your server still require new connections (e.g., connection pools) + command: ['sleep', '10'] + ports: + - name: mysql + containerPort: 3306 + volumeMounts: + - mountPath: /cloudsql + name: cloudsql + volumes: + - name: cloudsql + emptyDir: +--- +apiVersion: v1 +kind: Secret +metadata: + name: mysql-credential + labels: + app: mysql-credential + app.kubernetes.io/name: my-release +type: Opaque +data: + username: "cm9vdA==" + password: "MTIzNA==" + + +--- +# Source: kubeflow-pipelines/templates/application.yaml +apiVersion: app.k8s.io/v1beta1 +kind: Application +metadata: + name: "my-release" + namespace: "kubeflow" + annotations: + kubernetes-engine.cloud.google.com/icon: >- +  + marketplace.cloud.google.com/deploy-info: '{"partner_id": "google-cloud-ai-platform", + "product_id": "kubeflow-pipelines", "partner_name": "Google Cloud AI Platform"}' + labels: + app.kubernetes.io/name: "my-release" +spec: + descriptor: + type: Kubeflow Pipelines + version: 1.0.0 + description: |- + Reusable end-to-end ML workflow + maintainers: + - name: Google Cloud AI Platform + url: https://cloud.google.com/ai-platform/ + - name: Kubeflow Pipelines + url: https://github.com/kubeflow/pipelines + links: + - description: 'Kubeflow Pipelines Documentation' + url: https://www.kubeflow.org/docs/pipelines/ + notes: |- + Please go to [Hosted Kubeflow Pipelines Console](https://console.cloud.google.com/ai-platform/pipelines/clusters). + info: + - name: Application Namespace + value: "kubeflow" + - name: Console + value: 'https://console.cloud.google.com/ai-platform/pipelines/clusters' + componentKinds: + - 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: ConfigMap + - group: v1 + kind: Secret + - group: apps/v1 + kind: Deployment + diff --git a/manifests/gcp_marketplace/test/snapshot-managed-storage.yaml b/manifests/gcp_marketplace/test/snapshot-managed-storage.yaml new file mode 100644 index 00000000000..d0b6b4a5661 --- /dev/null +++ b/manifests/gcp_marketplace/test/snapshot-managed-storage.yaml @@ -0,0 +1,1858 @@ +--- +# Source: kubeflow-pipelines/templates/config-snapshot.yaml +apiVersion: v1 +kind: ConfigMap +metadata: + name: ml-pipeline-install-config-snapshot + labels: + app.kubernetes.io/name: 'my-release' + annotations: + pipelines.kubeflow.org/comment: |- + This is a snapshot of install parameters. There's no effect modifying this. +data: + appName: 'my-release' + namespace: 'kubeflow' + managedStorageEnabled: 'true' + # + managedStorageCloudSqlInstanceConnectionName: 'myproject:us-central1:myinstance' + managedStorageGcsBucketName: 'mybucket' + managedStorageDatabasePrefix: 'my_release' + managedstorageDbUserName: 'root' + # +--- +apiVersion: v1 +kind: Secret +metadata: + name: ml-pipeline-install-secret-snapshot + labels: + app.kubernetes.io/name: 'my-release' + annotations: + pipelines.kubeflow.org/comment: |- + This is a snapshot of install secrets. There's no effect modifying this. +type: Opaque +# +data: + managedStorageDbPassword: 'MTIzNA==' +# + +--- +# Source: kubeflow-pipelines/templates/cache.yaml +apiVersion: v1 +kind: ServiceAccount +metadata: + name: kubeflow-pipelines-cache-deployer-sa + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: kubeflow-pipelines-cache + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRole +metadata: + labels: + app: kubeflow-pipelines-cache-deployer-clusterrole + app.kubernetes.io/name: my-release + name: kubeflow-pipelines-cache-deployer-clusterrole +rules: +- apiGroups: + - certificates.k8s.io + resources: + - certificatesigningrequests + - certificatesigningrequests/approval + verbs: + - create + - delete + - get + - update +- apiGroups: + - admissionregistration.k8s.io + resources: + - mutatingwebhookconfigurations + verbs: + - create + - delete + - get + - list + - patch +- apiGroups: + - certificates.k8s.io + resources: + - signers + resourceNames: + - kubernetes.io/* + verbs: + - approve +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app: kubeflow-pipelines-cache-deployer-role + app.kubernetes.io/name: my-release + name: kubeflow-pipelines-cache-deployer-role +rules: +- apiGroups: + - "" + resources: + - secrets + verbs: + - create + - delete + - get + - patch + - list +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app: kubeflow-pipelines-cache-role + app.kubernetes.io/name: my-release + 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: kubeflow-pipelines-cache-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: kubeflow-pipelines-cache-role +subjects: +- kind: ServiceAccount + name: kubeflow-pipelines-cache + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: ClusterRoleBinding +metadata: + name: kubeflow-pipelines-cache-deployer-clusterrolebinding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: ClusterRole + name: kubeflow-pipelines-cache-deployer-clusterrole +subjects: +- kind: ServiceAccount + name: kubeflow-pipelines-cache-deployer-sa + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: kubeflow-pipelines-cache-deployer-rolebinding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: kubeflow-pipelines-cache-deployer-role +subjects: +- kind: ServiceAccount + name: kubeflow-pipelines-cache-deployer-sa + namespace: kubeflow +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: cache-deployer-deployment + labels: + app: cache-deployer + app.kubernetes.io/name: my-release +spec: + replicas: 1 + selector: + matchLabels: + app: cache-deployer + app.kubernetes.io/name: my-release + strategy: + type: Recreate + template: + metadata: + labels: + app: cache-deployer + app.kubernetes.io/name: my-release + spec: + containers: + - name: main + image: gcr.io/ml-pipeline/google/pipelines/cachedeployer:dummy + imagePullPolicy: Always + env: + - name: NAMESPACE_TO_WATCH + value: kubeflow + serviceAccountName: kubeflow-pipelines-cache-deployer-sa + restartPolicy: Always +--- +apiVersion: v1 +kind: ConfigMap +metadata: + name: cache-configmap + labels: + component: cache-server +data: + mysql_database: 'my_release_cachedb' + mysql_driver: "mysql" + mysql_host: "mysql" + mysql_port: "3306" +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: cache-server + labels: + app: cache-server + app.kubernetes.io/name: my-release +spec: + replicas: 1 + selector: + matchLabels: + app: cache-server + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: cache-server + app.kubernetes.io/name: my-release + spec: + containers: + - name: server + image: gcr.io/ml-pipeline/google/pipelines/cacheserver:dummy + env: + + - name: DBCONFIG_USER + valueFrom: + secretKeyRef: + name: mysql-credential + key: username + - name: DBCONFIG_PASSWORD + valueFrom: + secretKeyRef: + name: mysql-credential + key: password + + - name: DBCONFIG_DRIVER + valueFrom: + configMapKeyRef: + name: cache-configmap + key: mysql_driver + - name: DBCONFIG_DB_NAME + valueFrom: + configMapKeyRef: + name: cache-configmap + key: mysql_database + - name: DBCONFIG_HOST_NAME + valueFrom: + configMapKeyRef: + name: cache-configmap + key: mysql_host + - name: DBCONFIG_PORT + valueFrom: + configMapKeyRef: + name: cache-configmap + key: mysql_port + - name: NAMESPACE_TO_WATCH + value: kubeflow + 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)", + ] + imagePullPolicy: Always + ports: + - containerPort: 8443 + name: webhook-api + volumeMounts: + - name: webhook-tls-certs + mountPath: /etc/webhook/certs + readOnly: true + volumes: + - name: webhook-tls-certs + secret: + secretName: webhook-server-tls + serviceAccountName: kubeflow-pipelines-cache +--- +apiVersion: v1 +kind: Service +metadata: + name: cache-server + labels: + app: cache-server + app.kubernetes.io/name: my-release +spec: + selector: + app: cache-server + app.kubernetes.io/name: my-release + ports: + - port: 443 + targetPort: webhook-api + +--- +# Source: kubeflow-pipelines/templates/proxy.yaml +apiVersion: v1 +kind: ServiceAccount +metadata: + name: proxy-agent-runner + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app: proxy-agent-runner + app.kubernetes.io/name: my-release + name: proxy-agent-runner +rules: + - apiGroups: + - "" + resources: + - configmaps + verbs: + - '*' +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + app.kubernetes.io/name: my-release + app: proxy-agent-runner + name: proxy-agent-runner +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: proxy-agent-runner +subjects: + - kind: ServiceAccount + name: proxy-agent-runner + namespace: kubeflow +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: proxy-agent + app.kubernetes.io/name: my-release + name: proxy-agent +spec: + selector: + matchLabels: + app: proxy-agent + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: proxy-agent + app.kubernetes.io/name: my-release + spec: + hostNetwork: true + containers: + - image: gcr.io/ml-pipeline/google/pipelines/proxyagent:dummy + imagePullPolicy: IfNotPresent + name: proxy-agent + serviceAccountName: proxy-agent-runner +--- +apiVersion: v1 +kind: ConfigMap +metadata: + name: inverse-proxy-config + labels: + app.kubernetes.io/name: my-release + +--- +# Source: kubeflow-pipelines/templates/argo.yaml +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: workflows.argoproj.io + labels: + app.kubernetes.io/name: my-release +spec: + group: argoproj.io + names: + kind: Workflow + plural: workflows + shortNames: + - wf + scope: Namespaced + version: v1alpha1 +--- +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: clusterworkflowtemplates.argoproj.io + labels: + app.kubernetes.io/name: my-release +spec: + group: argoproj.io + names: + kind: ClusterWorkflowTemplate + plural: clusterworkflowtemplates + shortNames: + - clusterwftmpl + - cwft + scope: Cluster + version: v1alpha1 +--- +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: cronworkflows.argoproj.io + labels: + app.kubernetes.io/name: my-release +spec: + group: argoproj.io + names: + kind: CronWorkflow + plural: cronworkflows + shortNames: + - cronwf + - cwf + scope: Namespaced + version: v1alpha1 +--- +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: workflowtemplates.argoproj.io + labels: + app.kubernetes.io/name: my-release +spec: + group: argoproj.io + names: + kind: WorkflowTemplate + plural: workflowtemplates + shortNames: + - wftmpl + scope: Namespaced + version: v1alpha1 +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: argo + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: argo-role + labels: + app.kubernetes.io/name: my-release +rules: + - apiGroups: + - "" + resources: + - pods + - pods/exec + verbs: + - create + - get + - list + - watch + - update + - patch + - delete + - apiGroups: + - "" + resources: + - configmaps + verbs: + - get + - watch + - list + - apiGroups: + - "" + resources: + - persistentvolumeclaims + - events + verbs: + - create + - delete + - apiGroups: + - argoproj.io + resources: + - workflows + - workflows/finalizers + - workflowtemplates + - workflowtemplates/finalizers + - cronworkflows + verbs: + - get + - list + - watch + - update + - patch + - delete +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: argo-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: argo-role +subjects: + - kind: ServiceAccount + name: argo + namespace: kubeflow +--- +apiVersion: v1 +data: + config: | + { + namespace: kubeflow, + executorImage: gcr.io/ml-pipeline/google/pipelines/argoexecutor:dummy, + artifactRepository: + { + s3: { + bucket: 'mybucket', + keyPrefix: artifacts, + endpoint: minio-service.kubeflow:9000, + insecure: true, + accessKeySecret: { + name: mlpipeline-minio-artifact, + key: accesskey + }, + secretKeySecret: { + name: mlpipeline-minio-artifact, + key: secretkey + } + }, + archiveLogs: true + } + } +kind: ConfigMap +metadata: + name: workflow-controller-configmap + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +data: + accesskey: bWluaW8= + secretkey: bWluaW8xMjM= +kind: Secret +metadata: + name: mlpipeline-minio-artifact + labels: + app.kubernetes.io/name: my-release +type: Opaque +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: workflow-controller + app.kubernetes.io/name: my-release + name: workflow-controller +spec: + progressDeadlineSeconds: 600 + replicas: 1 + revisionHistoryLimit: 10 + selector: + matchLabels: + app: workflow-controller + app.kubernetes.io/name: my-release + strategy: + rollingUpdate: + maxSurge: 25% + maxUnavailable: 25% + type: RollingUpdate + template: + metadata: + creationTimestamp: null + labels: + app: workflow-controller + app.kubernetes.io/name: my-release + spec: + containers: + - args: + - --configmap + - workflow-controller-configmap + - --executor-image + - gcr.io/ml-pipeline/google/pipelines/argoexecutor:dummy + command: + - workflow-controller + env: + - name: ARGO_NAMESPACE + valueFrom: + fieldRef: + apiVersion: v1 + fieldPath: metadata.namespace + image: gcr.io/ml-pipeline/google/pipelines/argoworkflowcontroller:dummy + imagePullPolicy: IfNotPresent + name: workflow-controller + resources: {} + terminationMessagePath: /dev/termination-log + terminationMessagePolicy: File + dnsPolicy: ClusterFirst + restartPolicy: Always + schedulerName: default-scheduler + serviceAccountName: argo + terminationGracePeriodSeconds: 30 + +--- +# Source: kubeflow-pipelines/templates/pipeline.yaml +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + name: scheduledworkflows.kubeflow.org + labels: + app.kubernetes.io/name: my-release +spec: + group: kubeflow.org + names: + kind: ScheduledWorkflow + listKind: ScheduledWorkflowList + plural: scheduledworkflows + shortNames: + - swf + singular: scheduledworkflow + scope: Namespaced + versions: + - name: v1beta1 + served: true + storage: true +--- +apiVersion: apiextensions.k8s.io/v1beta1 +kind: CustomResourceDefinition +metadata: + labels: + app.kubernetes.io/name: my-release + name: viewers.kubeflow.org +spec: + group: kubeflow.org + names: + kind: Viewer + listKind: ViewerList + plural: viewers + shortNames: + - vi + singular: viewer + scope: Namespaced + versions: + - name: v1beta1 + served: true + storage: true +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-persistenceagent + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-scheduledworkflow + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-ui + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-viewer-crd-service-account + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline-visualizationserver + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: ml-pipeline + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: pipeline-runner + labels: + app.kubernetes.io/name: my-release +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: ml-pipeline-persistenceagent-role + labels: + app.kubernetes.io/name: my-release +rules: + - apiGroups: + - argoproj.io + resources: + - workflows + verbs: + - get + - list + - watch + - apiGroups: + - kubeflow.org + resources: + - scheduledworkflows + verbs: + - get + - list + - watch + - apiGroups: + - '' + resources: + - events + verbs: + - create + - patch +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline-scheduledworkflow-role + 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline-ui + name: ml-pipeline-ui +rules: + - apiGroups: + - "" + resources: + - pods + - pods/log + verbs: + - create + - get + - list + - 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: ml-pipeline-viewer-controller-role + labels: + app.kubernetes.io/name: my-release +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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline + name: ml-pipeline +rules: + - apiGroups: + - "" + resources: + - pods + 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + name: pipeline-runner + labels: + app.kubernetes.io/name: my-release +rules: + - 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: + - '*' +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: ml-pipeline-persistenceagent-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline-persistenceagent-role +subjects: + - kind: ServiceAccount + name: ml-pipeline-persistenceagent + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: ml-pipeline-scheduledworkflow-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline-scheduledworkflow-role +subjects: + - kind: ServiceAccount + name: ml-pipeline-scheduledworkflow + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline-ui + name: ml-pipeline-ui +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline-ui +subjects: + - kind: ServiceAccount + name: ml-pipeline-ui + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + labels: + app.kubernetes.io/name: my-release + app: ml-pipeline + name: ml-pipeline +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline +subjects: + - kind: ServiceAccount + name: ml-pipeline + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: pipeline-runner-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: pipeline-runner +subjects: + - kind: ServiceAccount + name: pipeline-runner + namespace: kubeflow +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: ml-pipeline-viewer-crd-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: ml-pipeline-viewer-controller-role +subjects: + - kind: ServiceAccount + name: ml-pipeline-viewer-crd-service-account + namespace: kubeflow +--- +apiVersion: v1 +kind: Service +metadata: + labels: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release + name: ml-pipeline-ui +spec: + ports: + - port: 80 + targetPort: 3000 + selector: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: Service +metadata: + name: ml-pipeline-visualizationserver +spec: + ports: + - name: http + port: 8888 + protocol: TCP + targetPort: 8888 + selector: + app: ml-pipeline-visualizationserver + app.kubernetes.io/name: my-release +--- +apiVersion: v1 +kind: Service +metadata: + name: ml-pipeline + labels: + app.kubernetes.io/name: my-release +spec: + ports: + - name: http + port: 8888 + protocol: TCP + targetPort: 8888 + - name: grpc + port: 8887 + protocol: TCP + targetPort: 8887 + selector: + app: ml-pipeline + app.kubernetes.io/name: my-release +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-persistenceagent + app.kubernetes.io/name: my-release + name: ml-pipeline-persistenceagent +spec: + selector: + matchLabels: + app: ml-pipeline-persistenceagent + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-persistenceagent + app.kubernetes.io/name: my-release + spec: + containers: + - env: + - name: NAMESPACE + value: kubeflow + - name: TTL_SECONDS_AFTER_WORKFLOW_FINISH + value: "86400" + image: gcr.io/ml-pipeline/google/pipelines/persistenceagent:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-persistenceagent + serviceAccountName: ml-pipeline-persistenceagent +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-scheduledworkflow + app.kubernetes.io/name: my-release + name: ml-pipeline-scheduledworkflow +spec: + selector: + matchLabels: + app: ml-pipeline-scheduledworkflow + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-scheduledworkflow + app.kubernetes.io/name: my-release + spec: + containers: + - env: + - name: NAMESPACE + value: kubeflow + image: gcr.io/ml-pipeline/google/pipelines/scheduledworkflow:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-scheduledworkflow + serviceAccountName: ml-pipeline-scheduledworkflow +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release + name: ml-pipeline-ui +spec: + selector: + matchLabels: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-ui + app.kubernetes.io/name: my-release + spec: + containers: + - env: + - name: MINIO_NAMESPACE + value: kubeflow + - name: ALLOW_CUSTOM_VISUALIZATIONS + value: "true" + - name: DEPLOYMENT + value: MARKETPLACE + image: gcr.io/ml-pipeline/google/pipelines/frontend:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-ui + ports: + - containerPort: 3000 + readinessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:3000/apis/v1beta1/healthz + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + livenessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:3000/apis/v1beta1/healthz + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + serviceAccountName: ml-pipeline-ui +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-viewer-crd + app.kubernetes.io/name: my-release + name: ml-pipeline-viewer-crd +spec: + selector: + matchLabels: + app: ml-pipeline-viewer-crd + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-viewer-crd + app.kubernetes.io/name: my-release + spec: + containers: + - env: + - name: MAX_NUM_VIEWERS + value: "50" + - name: NAMESPACE + value: kubeflow + image: gcr.io/ml-pipeline/google/pipelines/viewercrd:dummy + imagePullPolicy: Always + name: ml-pipeline-viewer-crd + serviceAccountName: ml-pipeline-viewer-crd-service-account +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline-visualizationserver + app.kubernetes.io/name: my-release + name: ml-pipeline-visualizationserver +spec: + selector: + matchLabels: + app: ml-pipeline-visualizationserver + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline-visualizationserver + app.kubernetes.io/name: my-release + spec: + containers: + - image: gcr.io/ml-pipeline/google/pipelines/visualizationserver:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-visualizationserver + ports: + - name: http + containerPort: 8888 + readinessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:8888/ + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + livenessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:8888/ + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + serviceAccountName: ml-pipeline-visualizationserver +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + app: ml-pipeline + app.kubernetes.io/name: my-release + name: ml-pipeline +spec: + selector: + matchLabels: + app: ml-pipeline + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: ml-pipeline + app.kubernetes.io/name: my-release + spec: + containers: + - env: + + - name: HAS_DEFAULT_BUCKET + value: "true" + - name: BUCKET_NAME + value: "mybucket" + + - name: PROJECT_ID + valueFrom: + configMapKeyRef: + name: "gcp-default-config" + key: "project_id" + - name: POD_NAMESPACE + valueFrom: + fieldRef: + fieldPath: metadata.namespace + - name: DEFAULTPIPELINERUNNERSERVICEACCOUNT + value: 'pipeline-runner' + - name: OBJECTSTORECONFIG_SECURE + value: "false" + + - name: OBJECTSTORECONFIG_BUCKETNAME + value: "mybucket" + - name: DBCONFIG_DBNAME + value: 'my_release_pipeline' + - name: DBCONFIG_USER + valueFrom: + secretKeyRef: + name: mysql-credential + key: username + - name: DBCONFIG_PASSWORD + valueFrom: + secretKeyRef: + name: mysql-credential + key: password + + image: gcr.io/ml-pipeline/google/pipelines/apiserver:dummy + imagePullPolicy: IfNotPresent + name: ml-pipeline-api-server + ports: + - name: http + containerPort: 8888 + - name: grpc + containerPort: 8887 + readinessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:8888/apis/v1beta1/healthz + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + livenessProbe: + exec: + command: + - wget + - -q # quiet + - -S # show server response + - -O + - "-" # Redirect output to stdout + - http://localhost:8888/apis/v1beta1/healthz + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + serviceAccountName: ml-pipeline +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: kubeflow-pipelines-container-builder + +--- +# Source: kubeflow-pipelines/templates/metadata.yaml +apiVersion: v1 +kind: Service +metadata: + labels: + app: metadata + app.kubernetes.io/name: my-release + name: metadata-grpc-service +spec: + ports: + - name: grpc-api + port: 8080 + protocol: TCP + selector: + component: metadata-grpc-server + app.kubernetes.io/name: my-release +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + labels: + component: metadata-grpc-server + app.kubernetes.io/name: my-release + name: metadata-grpc-deployment +spec: + replicas: 1 + selector: + matchLabels: + component: metadata-grpc-server + app.kubernetes.io/name: my-release + template: + metadata: + labels: + component: metadata-grpc-server + app.kubernetes.io/name: my-release + spec: + containers: + - name: container + image: gcr.io/ml-pipeline/google/pipelines/metadataserver:dummy + imagePullPolicy: 'Always' + env: + # TODO: merge all into mysql-credential + + - name: DBCONFIG_USER + valueFrom: + secretKeyRef: + name: mysql-credential + key: username + - name: DBCONFIG_PASSWORD + valueFrom: + secretKeyRef: + name: mysql-credential + key: password + + - name: MYSQL_DATABASE + valueFrom: + configMapKeyRef: + name: metadata-mysql-configmap + key: MYSQL_DATABASE + - name: MYSQL_HOST + valueFrom: + configMapKeyRef: + name: metadata-mysql-configmap + key: MYSQL_HOST + - name: MYSQL_PORT + valueFrom: + configMapKeyRef: + name: metadata-mysql-configmap + key: MYSQL_PORT + command: ["/bin/metadata_store_server"] + args: ["--grpc_port=8080", + "--mysql_config_database=$(MYSQL_DATABASE)", + "--mysql_config_host=$(MYSQL_HOST)", + "--mysql_config_port=$(MYSQL_PORT)", + "--mysql_config_user=$(DBCONFIG_USER)", + "--mysql_config_password=$(DBCONFIG_PASSWORD)", + "--enable_database_upgrade=true" + ] + ports: + - containerPort: 8080 + name: grpc-api + livenessProbe: + tcpSocket: + port: grpc-api + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 + readinessProbe: + tcpSocket: + port: grpc-api + initialDelaySeconds: 3 + periodSeconds: 5 + timeoutSeconds: 2 +--- +kind: Service +apiVersion: v1 +metadata: + labels: + app: metadata + app.kubernetes.io/name: my-release + name: metadata-envoy-service +spec: + selector: + component: metadata-envoy + type: ClusterIP + ports: + - port: 9090 + protocol: TCP + name: md-envoy +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: metadata-envoy + labels: + component: metadata-envoy + app.kubernetes.io/name: my-release +spec: + replicas: 1 + selector: + matchLabels: + component: metadata-envoy + template: + metadata: + labels: + component: metadata-envoy + spec: + containers: + - name: container + image: gcr.io/ml-pipeline/google/pipelines/metadataenvoy:dummy + ports: + - name: md-envoy + containerPort: 9090 + - name: envoy-admin + containerPort: 9901 +--- +apiVersion: v1 +kind: ConfigMap +metadata: + name: metadata-mysql-configmap + labels: + component: metadata-server +data: + MYSQL_DATABASE: 'my_release_metadata' + MYSQL_HOST: "mysql" + MYSQL_PORT: "3306" +--- +apiVersion: v1 +kind: ConfigMap +metadata: + name: metadata-grpc-configmap + labels: + component: metadata-grpc-server +data: + METADATA_GRPC_SERVICE_HOST: "metadata-grpc-service" + METADATA_GRPC_SERVICE_PORT: "8080" +--- +apiVersion: apps/v1 +kind: Deployment +metadata: + name: metadata-writer + labels: + app: metadata-writer + app.kubernetes.io/name: my-release +spec: + replicas: 1 + selector: + matchLabels: + app: metadata-writer + app.kubernetes.io/name: my-release + template: + metadata: + labels: + app: metadata-writer + app.kubernetes.io/name: my-release + spec: + containers: + - name: main + image: gcr.io/ml-pipeline/google/pipelines/metadatawriter:dummy + env: + - name: NAMESPACE_TO_WATCH + valueFrom: + fieldRef: + fieldPath: metadata.namespace + serviceAccountName: kubeflow-pipelines-metadata-writer +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: Role +metadata: + labels: + app: kubeflow-pipelines-metadata-writer-role + app.kubernetes.io/name: my-release + 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 +--- +apiVersion: rbac.authorization.k8s.io/v1 +kind: RoleBinding +metadata: + name: kubeflow-pipelines-metadata-writer-binding + labels: + app.kubernetes.io/name: my-release +roleRef: + apiGroup: rbac.authorization.k8s.io + kind: Role + name: kubeflow-pipelines-metadata-writer-role +subjects: +- kind: ServiceAccount + name: kubeflow-pipelines-metadata-writer + namespace: kubeflow +--- +apiVersion: v1 +kind: ServiceAccount +metadata: + name: kubeflow-pipelines-metadata-writer + labels: + app.kubernetes.io/name: my-release + +--- +# Source: kubeflow-pipelines/templates/minio.yaml +apiVersion: v1 +kind: Service +metadata: + name: minio-service + labels: + app.kubernetes.io/name: my-release +spec: + ports: + - port: 9000 + protocol: TCP + targetPort: 9000 + selector: + app: minio + app.kubernetes.io/name: my-release +--- + +apiVersion: apps/v1 +kind: Deployment +metadata: + name: minio + labels: + app: minio + app.kubernetes.io/name: my-release +spec: + selector: + matchLabels: + app: minio + app.kubernetes.io/name: my-release + strategy: + type: Recreate + template: + metadata: + labels: + app: minio + app.kubernetes.io/name: my-release + spec: + containers: + - args: + - gateway + - gcs + - $(PROJECT_ID) + env: + - name: PROJECT_ID + valueFrom: + configMapKeyRef: + name: "gcp-default-config" + key: "project_id" + - name: MINIO_ACCESS_KEY + value: minio + - name: MINIO_SECRET_KEY + value: minio123 + # Minio is KFP system workload and we use GCE's default service account + # or later Workload Identity's corresponding service account. + # So here no need to setup GOOGLE_APPLICATION_CREDENTIALS. + # - name: GOOGLE_APPLICATION_CREDENTIALS + # value: "/etc/credentials/application_default_credentials.json" + image: gcr.io/ml-pipeline/google/pipelines/minio:dummy + name: minio + ports: + - containerPort: 9000 + +--- + + +--- +# Source: kubeflow-pipelines/templates/mysql.yaml +apiVersion: v1 +kind: Service +metadata: + name: mysql + labels: + app.kubernetes.io/name: my-release +spec: + ports: + - port: 3306 + selector: + + app: cloudsqlproxy + + app.kubernetes.io/name: my-release +--- + +apiVersion: apps/v1 +kind: Deployment +metadata: + name: cloudsqlproxy + labels: + app: cloudsqlproxy + app.kubernetes.io/name: my-release +spec: + selector: + matchLabels: + app: cloudsqlproxy + app.kubernetes.io/name: my-release + replicas: 1 + template: + metadata: + labels: + app: cloudsqlproxy + app.kubernetes.io/name: my-release + spec: + containers: + - image: gcr.io/ml-pipeline/google/pipelines/cloudsqlproxy:dummy + name: cloudsqlproxy + env: + command: ["/cloud_sql_proxy", + "-dir=/cloudsql", + # Replace with your own CloudSQL instance ID + "-instances=myproject:us-central1:myinstance=tcp:0.0.0.0:3306", + # System workload uses GCE default service account or Workload Identity's service account + # "-credential_file=/credentials/application_default_credentials.json", + "term_timeout=10s"] + # set term_timeout if require graceful handling of shutdown + # NOTE: proxy will stop accepting new connections; only wait on existing connections + lifecycle: + preStop: + exec: + # (optional) add a preStop hook so that termination is delayed + # this is required if your server still require new connections (e.g., connection pools) + command: ['sleep', '10'] + ports: + - name: mysql + containerPort: 3306 + volumeMounts: + - mountPath: /cloudsql + name: cloudsql + volumes: + - name: cloudsql + emptyDir: +--- +apiVersion: v1 +kind: Secret +metadata: + name: mysql-credential + labels: + app: mysql-credential + app.kubernetes.io/name: my-release +type: Opaque +data: + username: "cm9vdA==" + password: "MTIzNA==" + + +--- +# Source: kubeflow-pipelines/templates/application.yaml +apiVersion: app.k8s.io/v1beta1 +kind: Application +metadata: + name: "my-release" + namespace: "kubeflow" + annotations: + kubernetes-engine.cloud.google.com/icon: >- +  + marketplace.cloud.google.com/deploy-info: '{"partner_id": "google-cloud-ai-platform", + "product_id": "kubeflow-pipelines", "partner_name": "Google Cloud AI Platform"}' + labels: + app.kubernetes.io/name: "my-release" +spec: + descriptor: + type: Kubeflow Pipelines + version: 1.0.0 + description: |- + Reusable end-to-end ML workflow + maintainers: + - name: Google Cloud AI Platform + url: https://cloud.google.com/ai-platform/ + - name: Kubeflow Pipelines + url: https://github.com/kubeflow/pipelines + links: + - description: 'Kubeflow Pipelines Documentation' + url: https://www.kubeflow.org/docs/pipelines/ + notes: |- + Please go to [Hosted Kubeflow Pipelines Console](https://console.cloud.google.com/ai-platform/pipelines/clusters). + info: + - name: Application Namespace + value: "kubeflow" + - name: Console + value: 'https://console.cloud.google.com/ai-platform/pipelines/clusters' + componentKinds: + - 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: ConfigMap + - group: v1 + kind: Secret + - group: apps/v1 + kind: Deployment + diff --git a/manifests/gcp_marketplace/test/values-base.yaml b/manifests/gcp_marketplace/test/values-base.yaml new file mode 100644 index 00000000000..16e6f671db0 --- /dev/null +++ b/manifests/gcp_marketplace/test/values-base.yaml @@ -0,0 +1,9 @@ +gcpDefaultConfigName: "gcp-default-config" + +managedstorage: + enabled: false + cloudsqlInstanceConnectionName: null + gcsBucketName: null + databaseNamePrefix: '{{ .Release.Name | replace "-" "_" | replace "." "_" }}' + dbUsername: 'root' + dbPassword: '' diff --git a/manifests/gcp_marketplace/test/values-managed-storage-with-db-prefix.yaml b/manifests/gcp_marketplace/test/values-managed-storage-with-db-prefix.yaml new file mode 100644 index 00000000000..60f75187719 --- /dev/null +++ b/manifests/gcp_marketplace/test/values-managed-storage-with-db-prefix.yaml @@ -0,0 +1,9 @@ +gcpDefaultConfigName: "gcp-default-config" + +managedstorage: + enabled: true + cloudsqlInstanceConnectionName: 'myproject:us-central1:myinstance' + gcsBucketName: 'mybucket' + databaseNamePrefix: 'my_kfp' + dbUsername: 'root' + dbPassword: '1234' diff --git a/manifests/gcp_marketplace/test/values-managed-storage.yaml b/manifests/gcp_marketplace/test/values-managed-storage.yaml new file mode 100644 index 00000000000..45879692b2a --- /dev/null +++ b/manifests/gcp_marketplace/test/values-managed-storage.yaml @@ -0,0 +1,9 @@ +gcpDefaultConfigName: "gcp-default-config" + +managedstorage: + enabled: true + cloudsqlInstanceConnectionName: 'myproject:us-central1:myinstance' + gcsBucketName: 'mybucket' + databaseNamePrefix: '{{ .Release.Name | replace "-" "_" | replace "." "_" }}' + dbUsername: 'root' + dbPassword: '1234'