Learning Environment
Install Seldon Core 2 in a local learning environment.
You can install Seldon Core 2 on your local computer that is running a Kubernetes cluster using kind.
Seldon publishes the Helm charts that are required to install Seldon Core 2. For more information about the Helm charts and the related dependencies,see Helm charts and Dependencies.
Prerequisites
- Install a Kubernetes cluster that is running version 1.27 or later. 
- Install kubectl, the Kubernetes command-line tool. 
Installing Seldon Core 2
- Create a namespace to contain the main components of Seldon Core 2. For example, create the - seldon-meshnamespace.- kubectl create ns seldon-mesh || echo "Namespace seldon-mesh already exists"
- Add and update the Helm charts, - seldon-charts, to the repository.- helm repo add seldon-charts https://seldonio.github.io/helm-charts/ helm repo update seldon-charts
- Install Custom resource definitions for Seldon Core 2. - helm upgrade seldon-core-v2-crds seldon-charts/seldon-core-v2-crds \ --namespace default \ --install
- Install Seldon Core 2 operator in the - seldon-meshnamespace.- helm upgrade seldon-core-v2-setup seldon-charts/seldon-core-v2-setup \ --namespace seldon-mesh --set controller.clusterwide=true \ --install- This configuration installs the Seldon Core 2 operator across an entire Kubernetes cluster. To perform cluster-wide operations, create - ClusterRolesand ensure your user has the necessary permissions during deployment. With cluster-wide operations, you can create- SeldonRuntimesin any namespace.- You can configure the installation to deploy the Seldon Core 2 operator in a specific namespace so that it control resources in the provided namespace. To do this, set - controller.clusterwideto- false.
- Install Seldon Core 2 runtimes in the - seldon-meshnamespace.- helm upgrade seldon-core-v2-runtime seldon-charts/seldon-core-v2-runtime \ --namespace seldon-mesh \ --install
- Install Seldon Core 2 servers in the - seldon-meshnamespace. Two example servers named- mlserver-0, and- triton-0are installed so that you can load the models to these servers after installation.- helm upgrade seldon-core-v2-servers seldon-charts/seldon-core-v2-servers \ --namespace seldon-mesh \ --install
- Check Seldon Core 2 operator, runtimes, servers, and CRDS are installed in the - seldon-meshnamespace. It might take a couple of minutes for all the Pods to be ready. To check the status of the Pods in real time use this command:- kubectl get pods -w -n seldon-mesh.- kubectl get pods -n seldon-mesh- The output should be similar to this: - NAME READY STATUS RESTARTS AGE hodometer-749d7c6875-4d4vw 1/1 Running 0 4m33s mlserver-0 3/3 Running 0 4m10s seldon-dataflow-engine-7b98c76d67-v2ztq 0/1 CrashLoopBackOff 5 (49s ago) 4m33s seldon-envoy-bb99f6c6b-4mpjd 1/1 Running 0 4m33s seldon-modelgateway-5c76c7695b-bhfj5 1/1 Running 0 4m34s seldon-pipelinegateway-584c7d95c-bs8c9 1/1 Running 0 4m34s seldon-scheduler-0 1/1 Running 0 4m34s seldon-v2-controller-manager-5dd676c7b7-xq5sm 1/1 Running 0 4m52s triton-0 2/3 Running 0 4m10s
You can install Seldon Core 2 and its components using Ansible in one of the following methods:
Single command
To install Seldon Core 2 into a new local kind Kubernetes cluster, you can use the seldon-all playbook with a single command:
ansible-playbook playbooks/seldon-all.yamlThis creates a kind cluster and installs ecosystem dependencies such kafka, Prometheus, OpenTelemetry, and Jaeger as well as all the seldon-specific components. The seldon components are installed using helm-charts from the current git checkout (../k8s/helm-charts/).
Internally this runs, in order, the following playbooks:
- kind-cluster.yaml 
- setup-ecosystem.yaml 
- setup-seldon.yaml 
You may pass any of the additonal variables which are configurable for those playbooks to seldon-all.
For example:
ansible-playbook playbooks/seldon-all.yaml -e seldon_mesh_namespace=my-seldon-mesh -e install_prometheus=no -e @playbooks/vars/set-custom-images.yamlRunning the playbooks individually gives you more control over what and when it runs. For example, if you want to install into an existing k8s cluster.
Multiple commands
- Create a kind cluster. - ansible-playbook playbooks/kind-cluster.yaml
- Setup ecosystem. - ansible-playbook playbooks/setup-ecosystem.yaml- Seldon runs by default in the - seldon-meshnamespace and a Jaeger pod and OpenTelemetry collector are installed in the namespace. To install in a different- <mynamespace>namespace:- ansible-playbook playbooks/setup-ecosystem.yaml -e seldon_mesh_namespace=<mynamespace>
- Install Seldon Core 2 in the - ansible/folder.- ansible-playbook playbooks/setup-seldon.yaml- To install in a different namespace, - <mynamespace>.- ansible-playbook playbooks/setup-seldon.yaml -e seldon_mesh_namespace=<mynamespace>
Next Steps
If you installed Seldon Core 2 using Helm, you need to complete the installation of other components in the following order:
Last updated
Was this helpful?

