Using AI models
Using AI models with MicroShift
Abstract
Chapter 1. Using Red Hat OpenShift AI with MicroShift
Learn how to serve artificial intelligence and machine learning (AI/ML) models with artificial intelligence (AI) on your MicroShift edge deployments.
Red Hat OpenShift AI is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
1.1. How Red Hat OpenShift AI works in MicroShift
Edge deployments are where data happens and decisions need to be made. You can use Red Hat OpenShift AI (Red Hat OpenShift AI Self-Managed) to integrate a fleet of MicroShift-driven edge devices into the artificial intelligence and machine learning (AI/ML) operations cycle. MicroShift is compatible with a single-model serving platform based on the KServe component of Kubernetes. KServe is a platform that orchestrates model serving.
Red Hat OpenShift AI Self-Managed is a platform for data scientists and developers of AI/ML applications. First, use Red Hat OpenShift AI Self-Managed in the cloud or data center to develop, train, and test an AI model. Then, run your model in your edge deployments on MicroShift.
After you deploy your AI model, application data can be sent to the model where the model can make data-driven decisions without a human user. This is an ideal scenario for edge applications where interaction with an administrator is naturally limited.
- Implemented with KServe
- The KServe component includes model-serving runtimes that implement the loading of various types of model servers. These runtimes are configured with custom resources (CRs). KServe custom resource definitions (CRDs) also define the lifecycle of the deployment object, storage access, and networking setup.
- Specifics of using Red Hat OpenShift AI Self-Managed with MicroShift
- As an edge-optimized Kubernetes deployment, MicroShift has the following limitations when using Red Hat OpenShift AI Self-Managed: - AI model serving on MicroShift is only available on the x86_64 architecture.
- A subset of Red Hat OpenShift AI Self-Managed Operator components are supported on MicroShift.
- As a single-node Kubernetes distribution, MicroShift does not support multi-model deployments. You must use the single-model serving platform.
- You must develop the AI models you want to run on the MicroShift model-serving platform in the cloud or your data center. Using MicroShift as a development platform for AI models is not supported.
- You must plan for any additional RAM, disk space, and storage configurations required to serve your AI model.
- Not all model servers support the IPv6 networking protocol. Check each model server’s documentation to verify that your networking configuration is supported.
- You must secure the exposed model server endpoint, for example, with OAUTH2.
- 
									ClusterServingRuntimesCRDs are not supported by Red Hat OpenShift AI Self-Managed, which means that you must copy theServingRuntimeCR shipped within themicroshift-ai-model-servingRPM to your workload namespace.
- To administer model serving on MicroShift, you must use the CLI. The Red Hat OpenShift AI Self-Managed dashboard is not supported.
 
1.2. Workflow for using Red Hat OpenShift AI Self-Managed with MicroShift
Using Red Hat OpenShift AI Self-Managed with MicroShift requires the following general workflow:
- Getting your AI model ready
- Choose the artificial intelligence (AI) model that best aligns with your edge application and the decisions that need to be made at MicroShift deployment sites.
- In the cloud or data center, develop, train, and test your model.
- Plan for the system requirements and additional resources your AI model requires to run.
 
- Setting up the deployment environment
- Configure your Red Hat Device Edge for the specific hardware your deployment runs on, including driver and device plugins.
- To enable GPU or other hardware accelerators for MicroShift, follow the guidance specific for your edge device about what you need to install. For example, to use an NVIDIA GPU accelerator, begin by reading the following NVIDIA documentation: Running a GPU-Accelerated Workload on Red Hat Device Edge (NVIDIA documentation).
- For troubleshooting, consult the device documentation or product support. Tip- Using only a driver and device plugin instead of an Operator might be more resource efficient. 
 
- Installing the MicroShift Red Hat OpenShift AI Self-Managed RPM
- 
									Install the microshift-ai-model-servingRPM package.
- Restart MicroShift if you are adding the RPM while MicroShift is running.
 
- 
									Install the 
- Getting ready to deploy
- Package your AI model into an OCI image, otherwise known as the ModelCar format. If you already have S3-compatible storage or a persistent volume claim set up, you can skip this step, but only the ModelCar format is tested and supported for MicroShift.
- Select a model-serving runtime, which acts as your model server. Configure the runtime with the serving runtime and inference service. - 
											Copy the ServingRuntimecustom resource (CR) from the defaultredhat-ods-applicationsnamespace to your own namespace.
- 
											Create the InferenceServiceCR.
 
- 
											Copy the 
- 
									Optional: Create a Routeobject so that your model can connect outside the node.
 
- Using your model
- Make requests against the model server. For example, another pod running in your MicroShift deployment that is attached to a camera can stream an image back to the model-serving runtime. The model-serving runtime prepares that image as data for model inferencing. If the model was trained in the binary identification of a bee, the AI model outputs the likelihood that the image data is a bee.
 
1.3. Installing the Red Hat OpenShift AI RPM
To use AI models in MicroShift deployments, install the Red Hat OpenShift AI (Red Hat OpenShift AI Self-Managed) RPM with a new MicroShift installation. You can also install the RPM on an existing MicroShift instance if you restart the system.
					The microshift-ai-model-serving RPM contains manifests that deploy kserve, with the raw deployment mode enabled, and ServingRuntimes objects in the redhat-ods-applications namespace.
				
Red Hat OpenShift AI is a Technology Preview feature only. Technology Preview features are not supported with Red Hat production service level agreements (SLAs) and might not be functionally complete. Red Hat does not recommend using them in production. These features provide early access to upcoming product features, enabling customers to test functionality and provide feedback during the development process.
For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
Prerequisites
- The system requirements for installing MicroShift have been met.
- You have root user access to your machine.
- 
						The OpenShift CLI (oc) is installed.
- You configured your LVM VG with the capacity needed for the PVs of your workload.
- You have the RAM and disk space required for your AI model.
- You configured the required accelerators, hardware, operating system, and MicroShift to provide the resources your model needs.
- Your AI model is ready to use.
Procedure
- Install the MicroShift AI-model-serving RPM package by running the following command: - sudo dnf install microshift-ai-model-serving - $ sudo dnf install microshift-ai-model-serving- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- As a root user, restart the MicroShift service by entering the following command: - sudo systemctl restart microshift - $ sudo systemctl restart microshift- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Optional: Install the release information package by running the following command: - sudo dnf install microshift-ai-model-serving-release-info - $ sudo dnf install microshift-ai-model-serving-release-info- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- The - microshift-ai-model-serving-release-infoRPM contains a JSON file with image references useful for offline procedures or deploying a copy of a- ServingRuntimeCustom Resource to your namespace during a bootc image build.
Verification
- Verify that the - kservepod is running in the- redhat-ods-applicationsnamespace by entering the following command:- oc get pods -n redhat-ods-applications - $ oc get pods -n redhat-ods-applications- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME READY STATUS RESTARTS AGE kserve-controller-manager-7fc9fc688-kttmm 1/1 Running 0 1h - NAME READY STATUS RESTARTS AGE kserve-controller-manager-7fc9fc688-kttmm 1/1 Running 0 1h- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Next steps
- Create a namespace for your AI model.
- Package your model into an OCI image.
- Configure a model-serving runtime.
- Verify that your model is ready for inferencing.
- Make requests against the model server.
1.4. Creating a namespace for your AI model on MicroShift
Create a namespace for your AI model and all other resources.
Prerequisites
- You have root user access to your machine.
- 
						The OpenShift CLI (oc) is installed.
Procedure
- Create a new namespace by running the following command: - oc create ns <namespace_name> - $ oc create ns <namespace_name>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Replace<namespace_name>with the namespace name you want to use. In the following examples,ai-demois used.
 
Verification
- Verify that you created the desired namespace by running the following command: - oc get ns <namespace_name> - $ oc get ns <namespace_name>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Replace<namespace_name>with the namespace name you want to use. In the following examples,ai-demois used.
 - Example output - NAME STATUS AGE ai-demo Active 1h - NAME STATUS AGE ai-demo Active 1h- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
1.5. Packaging your AI model into an OCI image
You can package your model into an OCI image and use the ModelCar approach to help you set up offline environments. With the ModelCar approach, your model can be embedded just like any other container image.
If you already have S3-compatible object storage or a configured persistent volume claim, you can upload your AI model to those resources, but only the ModelCar approach is tested and supported.
Prerequisites
- You have root user access to your machine.
- 
						The OpenShift CLI (oc) is installed.
- Podman is installed.
- Your model is ready to use.
- You understand the concepts in the "How to build a ModelCar container" section of the following article about building an OCI image suitable for an vLLM model server, Build and deploy a ModelCar container in OpenShift AI. Note- The exact directory structure depends on the model server. The following example uses a Containerfile with a ResNet-50 model that is compatible with the OpenVINO Model Server OVMS. OVMS generally does not require an additional hardware accelerator. 
Procedure
- Prepare a Containerfile with a compatible model and model server. - Example Containerfile with a ResNet-50 model used with the OVMS - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Set the - IMAGE_REFenvironment variable to simplify your process by running the following command:- IMAGE_REF=<ovms-resnet50:test> - $ IMAGE_REF=<ovms-resnet50:test>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Replace<ovms-resnet50:test>with the name of your image reference. In this example, the<repo:tag>format is used. Your image reference name is specific to your use case.
 
- Build the Containerfile by running the following command: - sudo podman build -t $IMAGE_REF - $ sudo podman build -t $IMAGE_REF- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Because CRI-O and Podman share storage, usingsudois required to make the image part of the root’s container storage and usable by MicroShift.
 - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Optional: Push the Containerfile to your registry by running the following command: - sudo podman push $IMAGE_REF - $ sudo podman push $IMAGE_REF- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Important- For offline use cases, include a tag other than - latest. If the- latesttag is used, the container that fetches and sets up the model is configured with the- imagePullPolicy:parameter set to- Alwaysand the local image is ignored. If you use any other tag than- latest, the- imagePullPolicy:parameter is set to- IfNotPresent.
Verification
- Verify that the image exists by running the following command: - sudo podman images ovms-resnet50 - $ sudo podman images ovms-resnet50- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - REPOSITORY TAG IMAGE ID CREATED SIZE localhost/ovms-resnet50 test 375b265c1c4b 3 minutes ago 136 MB - REPOSITORY TAG IMAGE ID CREATED SIZE localhost/ovms-resnet50 test 375b265c1c4b 3 minutes ago 136 MB- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Next steps
- Configure a model-serving runtime.
- Confirm that your AI model is ready for inferencing.
- Make requests against the model server.
1.6. Serving AI models on MicroShift
				You can serve models on the Red Hat OpenShift AI Self-Managed single-model serving platform in MicroShift by configuring a model-serving runtime using the ServingRuntime and InferenceService custom resource (CRs).
			
- Model-serving runtimes for AI models in MicroShift
- A model-serving runtime is an environment for deploying and managing an AI model, providing integration with a specified model server and the model frameworks that it supports. Creating the model-serving runtime means configuring the objects that select the right model format for the AI model and serve the queries, among other detailed functions specific your deployment.
- The ServingRuntimecustom resource
- 
							The ServingRuntimeCR is a YAML file that defines the templates for pods that can dynamically load and unload AI model formats and exposes a service endpoint for querying the model through the API. EachServingRuntimeCR contains the information needed to run AI models, including the container image of the runtime and a list of the model formats that the model-serving runtime supports. Other configuration settings for the model-serving runtime can be set with environment variables defined in the container specification.
- The InferenceServicecustom resource
- 
							The InferenceServiceCR is a YAML file that creates a server or inference service to process inference queries, pass them to the model, then return the inference output. In MicroShift, the output is returned in the CLI. This inference service configuration file can also include many other options, such as specifying a hardware accelerator.
As a single-node Kubernetes distribution, MicroShift does not support multi-model deployments. You must use the single-model serving platform. In each MicroShift deployment, you can use one AI model, but potentially more than one model runtime.
- Workflow for configuring a model-serving runtime
- Select the model-serving runtime that supports the format of your AI model.
- 
									Create the ServingRuntimeCR in your workload namespace.
- 
									If the MicroShift node is already running, you can export the required ServingRuntimeCR to a file and edit it.
- 
									If the MicroShift node is not running, or if you want to manually prepare a manifest, you can use the original definition on the disk, which is part of the microshift-ai-model-servingRPM.
- 
									Create the InferenceServiceCR in your workload namespace.
 
1.6.1. Supported Red Hat OpenShift AI Self-Managed custom resource definitions
The following Red Hat OpenShift AI Self-Managed custom resource definitions (CRDs) are supported:
- 
							InferenceServices
- 
							TrainedModels
- 
							ServingRuntimes
- 
							InferenceGraphs
- 
							ClusterStorageContainers
- 
							ClusterLocalModels
- 
							LocalModelNodeGroups
1.6.2. Supported Red Hat OpenShift AI Self-Managed model-serving runtimes
The following Red Hat OpenShift AI Self-Managed model-serving runtimes are verified for MicroShift deployments:
- vLLM ServingRuntime for KServe
- OpenVINO Model Server Important- The OpenVINO Model Server does not support the IPv6 networking protocol. Check each model server before use to ensure that it supports your networking configuration. 
The following runtimes are available for development purposes with MicroShift:
- Caikit Text Generation Inference Server (Caikit-TGIS) ServingRuntime for KServe
- Caikit Standalone ServingRuntime for KServe
- Text Generation Inference Server (TGIS) Standalone ServingRuntime for KServe
- vLLM ServingRuntime with Gaudi accelerators support for KServe
- vLLM ROCm ServingRuntime for KServe
- Custom runtimes that you create and test
1.7. Creating a ServingRuntime CR for use in MicroShift
				Create a ServingRuntime custom resource (CR) based on installed manifests and release information. The included steps are an example of reusing the included microshift-ai-model-serving manifest files to re-create the OpenVINO Model Server (OVMS) model-serving runtime in the workload namespace.
			
This approach does not require a live node, so it can be part of CI/CD automation.
Prerequisites
- 
						Both the microshift-ai-model-servingandmicroshift-ai-model-serving-release-infoRPMs are installed.
- You have root user access to your machine.
- 
						The OpenShift CLI (oc) is installed.
Procedure
- Extract the image reference of the - ServingRuntimeCR you want to use from the MicroShift release information file by running the following command:- OVMS_IMAGE="$(jq -r '.images | with_entries(select(.key == "ovms-image")) | .[]' /usr/share/microshift/release/release-ai-model-serving-"$(uname -i)".json)" - $ OVMS_IMAGE="$(jq -r '.images | with_entries(select(.key == "ovms-image")) | .[]' /usr/share/microshift/release/release-ai-model-serving-"$(uname -i)".json)"- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- In this example, the image reference for the OVMS model-serving runtime is extracted.
 
- Copy the original - ServingRuntimeYAML file by running the following command:- cp /usr/lib/microshift/manifests.d/050-microshift-ai-model-serving-runtimes/ovms-kserve.yaml ./ovms-kserve.yaml - $ cp /usr/lib/microshift/manifests.d/050-microshift-ai-model-serving-runtimes/ovms-kserve.yaml ./ovms-kserve.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add the actual image reference to the - image:parameter field value of the- ServingRuntimeYAML by running the following command:- sed -i "s,image: ovms-image,image: ${OVMS_IMAGE}," ./ovms-kserve.yaml- $ sed -i "s,image: ovms-image,image: ${OVMS_IMAGE}," ./ovms-kserve.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - ServingRuntimeobject in a custom namespace using the YAML file by running the following command:- oc create -n <ai_demo> -f ./ovms-kserve.yaml - $ oc create -n <ai_demo> -f ./ovms-kserve.yaml- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Replace<ai_demo>with the name of your namespace.
 
					If the ServingRuntime CR is part of a new manifest, set the namespace in the kustomization.yaml file, for example:
				
Example Kustomize manifest namespace value
Next steps
- 
						Create the InferenceServiceobject.
- Verify that your model is ready for inferencing.
- Query the model.
- Optional: examine the model metrics.
1.8. Creating an InferenceService custom resource
				Create an InferenceService custom resource (CR) to instruct KServe how to create a deployment for serving your AI model. KServe uses the ServingRuntime based on the modelFormat value specified in the InferenceService CR.
			
Prerequisites
- 
						You configured the ServingRuntimesCR.
- You have root user access to your machine.
- 
						The OpenShift CLI (oc) is installed.
Procedure
- Create the - InferenceServiceCR.- Example - InferenceServiceobject with an- openvino_irmodel format- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- An additional argument to make OpenVINO Model Server (OVMS) accept the request input data in a different layout than the model was originally exported with. Extra arguments are passed through to the OVMS container.
 
- Save the - InferenceServiceexample to a file, then create it on the cluster by running the following command:- oc create -n <ai_demo> -f ./FILE.yaml - $ oc create -n <ai_demo> -f ./FILE.yaml- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Replace <ai_demo> with your namespace name.
 - Example output - inferenceservice.serving.kserve.io/ovms-resnet50 created - inferenceservice.serving.kserve.io/ovms-resnet50 created- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- A deployment and a pod are expected to appear in the specified namespace. Depending on the size of the image specified in the - ServingRuntimeCR and the size of the ModelCar OCI image, it might take several minutes for the pod to be ready.
Next step
- Verify that the model-serving runtime is ready.
1.8.1. Exporting model-server metrics by using Open Telemetry
					You can export model-server metrics by using Open Telemetry if you installed the microshift-observability RPM for MicroShift.
				
						You can alternatively get the Prometheus-format metrics of the model server by making a request on the /metrics endpoint. See "Getting the model-server metrics" for more information.
					
Prerequisites
- 
							You configured the ServingRuntimesCR.
- You have root user access to your machine.
- 
							The OpenShift CLI (oc) is installed.
- 
							You installed the microshift-observabilityRPM.
- Your MicroShift Open Telemetry configuration includes the Prometheus Receiver. For more information, see Prometheus Receiver.
Procedure
- Add the following Open Telemetry annotation to your - InferenceServicecustom resource:- Example - InferenceServiceobject with Open Telemetry- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
1.8.2. More InferenceService CR options
					The inference service YAML file can include many different options. For example, you can include a resources section that is passed first to the deployment and then to the pod, so that the model server gets access to your hardware through the device plugin.
				
Example NVIDIA device resources snippet in an InferenceService CR
					For complete InferenceService specifications, see the Control Plane API Reference (KServe documentation).
				
1.9. Verifying that the model-serving runtime is ready
Verify that your model-serving runtime is ready for use by checking that the downstream generation activities are complete.
Prerequisites
- 
						You configured the ServingRuntimesCR.
- 
						You created the InferenceServiceCR.
- You have root user access to your machine.
- 
						The OpenShift CLI (oc) is installed.
Procedure
- Check that the AI model is deployed in your custom namespace by running the following command: - oc get -n ai-demo deployment - $ oc get -n ai-demo deployment- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME READY UP-TO-DATE AVAILABLE AGE ovms-resnet50-predictor 1/1 1 1 72s - NAME READY UP-TO-DATE AVAILABLE AGE ovms-resnet50-predictor 1/1 1 1 72s- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Confirm that your deployment is in progress by running the following command: - oc rollout status -n ai-demo deployment ovms-resnet50-predictor - $ oc rollout status -n ai-demo deployment ovms-resnet50-predictor- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - deployment "ovms-resnet50-predictor" successfully rolled out - deployment "ovms-resnet50-predictor" successfully rolled out- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Check that the AI model workload pod is deployed in your custom namespace by running the following command: - oc get -n ai-demo pod - $ oc get -n ai-demo pod- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME READY STATUS RESTARTS AGE ovms-resnet50-predictor-6fdb566b7f-bc9k5 2/2 Running 1 (72s ago) 74s - NAME READY STATUS RESTARTS AGE ovms-resnet50-predictor-6fdb566b7f-bc9k5 2/2 Running 1 (72s ago) 74s- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Check for the service KServe created by running the following command: - oc get svc -n ai-demo - $ oc get svc -n ai-demo- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE ovms-resnet50-predictor ClusterIP None <none> 80/TCP 119s - NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE ovms-resnet50-predictor ClusterIP None <none> 80/TCP 119s- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Next step
- 
						Create a Routeobject so that your applications can reach the MicroShift node.
Additional resources
- InferenceService (Red Hat OpenShift AI documentation)
1.10. Creating a route to use for AI queries in MicroShift
				Create a route so that your AI model can receive queries and give output. You can either use the oc expose svc command or create a definition in a YAML file and apply it.
			
Prerequisites
- You have root user access to your machine.
- 
						The OpenShift CLI (oc) is installed.
Procedure
- Create a route using the following command: - oc expose svc -n ai-demo ovms-resnet50-predictor - $ oc expose svc -n ai-demo ovms-resnet50-predictor- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - route.route.openshift.io/ovms-resnet50-predictor exposed - route.route.openshift.io/ovms-resnet50-predictor exposed- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Verify that the route you created exists by running the following command: - oc get route -n ai-demo - $ oc get route -n ai-demo- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME HOST ADMITTED SERVICE TLS ovms-resnet50-predictor ovms-resnet50-predictor-ai-demo.apps.example.com True ovms-resnet50-predictor - NAME HOST ADMITTED SERVICE TLS ovms-resnet50-predictor ovms-resnet50-predictor-ai-demo.apps.example.com True ovms-resnet50-predictor- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Additional resources
1.11. About querying your AI model
Querying your model through the API is also called model inferencing. Model inferencing is most often used to retrieve information, automate tasks, make predictions, provide data insights, or perform actions.
In general, queries must be constructed using a format compatible with the AI model being used. A model-serving runtime formats queries automatically. The model processes the query according to the underlying training and data, then provides an output. The output is expected to align with the purpose of the model itself, whether that be to give an answer, make a prediction, or perform a task.
The following examples outline general steps to make sure your model is ready for inferencing, and what you might expect in a query output from the serving runtime.
1.11.1. Verifying that your AI model is accessible
Before querying the model through the API, you can check to be certain that the model is accessible and ready to provide answers based on the connected data. The following examples continue with the OpenVINO Model Server.
Prerequisites
- You configured the AI model-serving runtime.
- You uploaded your AI model to MicroShift.
- MicroShift is running.
- 
							You installed OpenShift CLI (oc).
Procedure
- Get the IP address of the MicroShift node and assign it to the - IPvariable as the following example command shows:- IP=$(oc get nodes -o json | jq -r '.items[0].status.addresses[0].address') - $ IP=$(oc get nodes -o json | jq -r '.items[0].status.addresses[0].address')- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Identify the name of the route you created by running the following command: - oc get route -n ai-test <route_name> -o yaml - $ oc get route -n ai-test <route_name> -o yaml- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Replace<route_name>with the actual name of your route.
 
- Extract and assign the - HOSTvalue of the route to the- DOMAINvariable by running the following command:- DOMAIN=$(oc get route -n ai-test <route_name> -o=jsonpath="{ .status.ingress[0].host }")- DOMAIN=$(oc get route -n ai-test <route_name> -o=jsonpath="{ .status.ingress[0].host }")- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Replace<route_name>with the actual name of your route.
 
- Enable data transfer from the route to the MicroShift IP address by running the following command: - curl -i "${DOMAIN}/v2/models/ovms-resnet50/ready" --connect-to "${DOMAIN}::${IP}:"- $ curl -i "${DOMAIN}/v2/models/ovms-resnet50/ready" --connect-to "${DOMAIN}::${IP}:"- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Instead of using the--connect-to "${DOMAIN}::${IP}:"flag, you can also use real DNS, or add the IP address and the domain to the/etc/hostsfile.
 - Example output - HTTP/1.1 200 OK content-type: application/json date: Wed, 12 Mar 2025 16:01:32 GMT content-length: 0 set-cookie: 56bb4b6df4f80f0b59f56aa0a5a91c1a=4af1408b4a1c40925456f73033d4a7d1; path=/; HttpOnly - HTTP/1.1 200 OK content-type: application/json date: Wed, 12 Mar 2025 16:01:32 GMT content-length: 0 set-cookie: 56bb4b6df4f80f0b59f56aa0a5a91c1a=4af1408b4a1c40925456f73033d4a7d1; path=/; HttpOnly- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Query the model metadata by running the following command: - curl "${DOMAIN}/v2/models/ovms-resnet50" --connect-to "${DOMAIN}::${IP}:"- $ curl "${DOMAIN}/v2/models/ovms-resnet50" --connect-to "${DOMAIN}::${IP}:"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - {"name":"ovms-resnet50","versions":["1"],"platform":"OpenVINO","inputs":[{"name":"0","datatype":"FP32","shape":[1,224,224,3]}],"outputs":[{"name":"1463","datatype":"FP32","shape":[1,1000]}]- {"name":"ovms-resnet50","versions":["1"],"platform":"OpenVINO","inputs":[{"name":"0","datatype":"FP32","shape":[1,224,224,3]}],"outputs":[{"name":"1463","datatype":"FP32","shape":[1,1000]}]- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Next steps
- Verify that your model is ready for inferencing.
- Query the model.
- Verify the model response.
- Optional: Get the model server metrics.
1.11.2. Getting your AI model ready for inference
Before querying your AI model through the API, get the model ready to provide answers based on the training data. The following examples continue with the OVMS model.
Prerequisites
- MicroShift is running.
- 
							You have the xxdutility, which is part of thevim-commonpackage.
- You configured the model-serving runtime.
- You uploaded your AI model to MicroShift.
Procedure
- Download an image of a bee from the OpenVINO Model Server examples by running the following command: - curl -O https://raw.githubusercontent.com/openvinotoolkit/model_server/main/demos/common/static/images/bee.jpeg - $ curl -O https://raw.githubusercontent.com/openvinotoolkit/model_server/main/demos/common/static/images/bee.jpeg- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the request data by running the following script: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
1.11.3. Querying your AI model
					Make an inference request against the AI model server that is using the ovms-resnet50 model.
				
Prerequisites
- MicroShift is running.
- You configured the model-serving runtime.
- You uploaded your AI model to MicroShift.
Procedure
- Make an inference request against the model server that is using the - ovms-resnet50model by running the following command:- curl \ --data-binary "@./request.json" \ --header "Inference-Header-Content-Length: ${HEADER_LEN}" \ "${DOMAIN}/v2/models/ovms-resnet50/infer" \ --connect-to "${DOMAIN}::${IP}:" > response.json- $ curl \ --data-binary "@./request.json" \ --header "Inference-Header-Content-Length: ${HEADER_LEN}" \ "${DOMAIN}/v2/models/ovms-resnet50/infer" \ --connect-to "${DOMAIN}::${IP}:" > response.json- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example inferencing output, saved to a - response.json- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The contents of.outputs[0].datawere omitted from the example for brevity.
 
Verification
- To determine the model’s prediction, get the index of the highest element in the - .outputs[0].datato determine the model’s predicted value by using the following Python script:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - 309 - 309- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- In this example, the element labeled309is the model’s response.
 
- Validate the output against resnet’s input data, for example: - ../../../../demos/common/static/images/bee.jpeg 309 - ../../../../demos/common/static/images/bee.jpeg 309- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Next steps
- Optional. Query the AI model using other images available in the resnet input data.
1.11.4. Getting the model-server metrics
After making a query, you can get the model server’s metrics to identify bottlenecks, optimize resource allocation, and ensure efficient infrastructure utilization.
You can alternatively configure Open Telemetry for MicroShift to get model-server metrics. See "Adding Open Telemetry to an InferenceService custom resource" for more information.
Prerequisites
- MicroShift is running.
- There have been enough queries to provide the metrics data you want to see.
Procedure
- Get the Prometheus-format metrics of the model server by making a request on the - /metricsendpoint by running the following command:- curl "${DOMAIN}/metrics" --connect-to "${DOMAIN}::${IP}:"- $ curl "${DOMAIN}/metrics" --connect-to "${DOMAIN}::${IP}:"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Partial example output - HELP ovms_requests_success Number of successful requests to a model or a DAG. TYPE ovms_requests_success counter - # HELP ovms_requests_success Number of successful requests to a model or a DAG. # TYPE ovms_requests_success counter ovms_requests_success{api="KServe",interface="REST",method="ModelReady",name="ovms-resnet50"} 4 ovms_requests_success{api="KServe",interface="REST",method="ModelMetadata",name="ovms-resnet50",version="1"} 1- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
1.12. Overriding KServe configuration
If you want to override KServe settings to customize your model-serving environment, you can follow the general steps for your operating system.
- Option 1
- 
									Make a copy of the existing ConfigMapfile,inferenceservice-config, in theredhat-ods-applicationsnamespace.
- Edit the settings you want to change.
- 
									Overwrite the existing ConfigMapobject.
- 
									Restart KServe by either by deleting the pod or scaling the Deploymentpod parameter down to0and then back up to1.
 
- 
									Make a copy of the existing 
- Option 2
- 
									Copy the ConfigMapfile,/usr/lib/microshift/manifests.d/010-microshift-ai-model-serving-kserve/inferenceservice-config-microshift-patch.yaml.
- Edit the settings you want to change.
- 
									Apply the ConfigMapobject.
- 
									Restart KServe by either by deleting the pod or scaling the Deploymentpod parameter down to0and then back up to1.
 
- 
									Copy the 
- For RHEL for Edge and image mode for RHEL systems
- 
									Create a new manifest with the ConfigMapfile, based on either of the/usr/lib/microshift/manifests.d/010-microshift-ai-model-serving-kserve/inferenceservice-config-microshift-patch.yamlorinferenceservice-configfiles, in theredhat-ods-applicationsnamespace.
- 
									Ensure that the new manifest is placed in the /usr/lib/microshift/manifests.d/directory. Staring with prefix011is recommended so that your manifest is applied after the/usr/lib/microshift/manifests.d/010-microshift-ai-model-serving-kserve/directory contents.
 
- 
									Create a new manifest with the