Installing kagent#
This guide covers ways to install and configure kagent in your Kubernetes environment. For a quick setup, check out our Quick Start Guide. For enterpise offerings, check out Solo Enterprise for kagent.
Installation Methods#
Install kagent by using the kagent CLI or Helm.
Note: As of version 0.7, the kmcp subproject is included by default with kagent. To use an existing kmcp installation that you already set up separately, set
kmcp.enabled=falsein yourvalues.yamlfile or--setcommands for both thekagentandkagent-crdscharts.
Using kagent CLI (Recommended)#
-
Set the OpenAI API key as an environment variable.
export OPENAI_API_KEY="your-api-key-here" -
Download the kagent CLI.
brew install kagentor
curl https://raw.githubusercontent.com/kagent-dev/kagent/refs/heads/main/scripts/get-kagent | bash -
Install kagent to the cluster by using the CLI. The following command installs a demo profile with agents and MCP tools preloaded for you. If you don't want these default agents, include the
--profile minimalflag.kagent install --profile demokagent installed successfully -
Optionally: Open the kagent dashboard.
kagent dashboardExample output:
kagent dashboard is available at http://localhost:8082Press Enter to stop the port-forward...
Using Helm#
Another way to install kagent is using Helm.
-
Install the kagent Helm chart with CRDs.
helm install kagent-crds oci://ghcr.io/kagent-dev/kagent/helm/kagent-crds \--namespace kagent \--create-namespace -
Optionally prepare a Helm values file or
--setflags to use for your installation. For example, you might set up your default LLM provider, or configure resource requests and limits or disable the default agents. For options, refer to the Helm reference docs.
-
Set the
OPENAI_API_KEYenvironment variable:export OPENAI_API_KEY="your-api-key-here" -
Install the kagent Helm chart:
helm install kagent oci://ghcr.io/kagent-dev/kagent/helm/kagent \--namespace kagent \--set providers.default=openAI \--set providers.openAI.apiKey=$OPENAI_API_KEY -
Optionally: Port-forward the kagent UI on port 8080.
kubectl port-forward -n kagent svc/kagent-ui 8080:8080 -
Open the kagent UI.
-
Set the
ANTHROPIC_API_KEYenvironment variable:export ANTHROPIC_API_KEY="your-api-key-here" -
Install the kagent Helm chart:
helm install kagent oci://ghcr.io/kagent-dev/kagent/helm/kagent \--namespace kagent \--set providers.default=anthropic \--set providers.anthropic.apiKey=$ANTHROPIC_API_KEY -
Optionally: Port-forward the kagent UI on port 8080.
kubectl port-forward -n kagent svc/kagent-ui 8080:8080 -
Open the kagent UI.
-
Set the
OPENAI_API_KEYenvironment variable:export OPENAI_API_KEY="your-api-key-here" -
Install the kagent Helm chart:
helm install kagent oci://ghcr.io/kagent-dev/kagent/helm/kagent \--namespace kagent \--set providers.default=azureOpenAI \--set providers.azureOpenAI.apiKey=$OPENAI_API_KEY -
Optionally: Port-forward the kagent UI on port 8080.
kubectl port-forward -n kagent svc/kagent-ui 8080:8080 -
Open the kagent UI.
-
Set the
GEMINI_API_KEYenvironment variable:export GEMINI_API_KEY="your-api-key-here" -
Install the kagent Helm chart:
helm install kagent oci://ghcr.io/kagent-dev/kagent/helm/kagent \--namespace kagent \--set providers.default=gemini \--set providers.gemini.apiKey=$GEMINI_API_KEY -
Optionally: Port-forward the kagent UI on port 8080.
kubectl port-forward -n kagent svc/kagent-ui 8080:8080 -
Open the kagent UI.
-
Install the kagent Helm chart:
helm install kagent oci://ghcr.io/kagent-dev/kagent/helm/kagent \--namespace kagent \--set providers.default=ollama -
Optionally: Port-forward the kagent UI on port 8080.
kubectl port-forward -n kagent svc/kagent-ui 8080:8080 -
Open the kagent UI.
Advanced Configuration#
Review the following advanced configuration options that you might want to set up for your kagent installation.
Enable AgentHarness support#
AgentHarness resources require an OpenShell gateway that the kagent controller can reach. To enable the AgentHarness backends, install OpenShell and set OPENSHELL_GATEWAY_URL on the kagent controller deployment.
-
Install OpenShell in your cluster.
kubectl create namespace openshellkubectl -n openshell create secret generic openshell-ssh-handshake \--from-literal=secret="$(openssl rand -hex 32)"kubectl apply -f https://raw.githubusercontent.com/NVIDIA/OpenShell/refs/heads/main/deploy/kube/manifests/agent-sandbox.yamlhelm upgrade --install openshell oci://ghcr.io/nvidia/openshell/helm-chart \--version 0.0.49 \--namespace openshell \--create-namespace \--values - <<'EOF'server:disableTls: trueauth:allowUnauthenticatedUsers: trueservice:metricsPort: 0EOFThis example disables TLS and authentication. For production environments, configure TLS and authentication according to your OpenShell requirements. -
Configure the kagent controller with the OpenShell gateway URL.
Helm values file:
controller:openshell:enabled: "true"env:- name: OPENSHELL_GATEWAY_URLvalue: dns:///openshell.openshell.svc:8080- name: OPENSHELL_INSECUREvalue: "true"Helm
--setflags:helm upgrade --install kagent oci://ghcr.io/kagent-dev/kagent/helm/kagent \--namespace kagent \--set controller.openshell.enabled=true \--set 'controller.env[0].name=OPENSHELL_GATEWAY_URL' \--set-string 'controller.env[0].value=dns:///openshell.openshell.svc:8080' \--set 'controller.env[1].name=OPENSHELL_INSECURE' \--set-string 'controller.env[1].value=true'If you already configure
controller.env, merge theOPENSHELL_GATEWAY_URLentry into your existing values. WhenOPENSHELL_GATEWAY_URLis empty, the controller does not register AgentHarness backends.
For more information about creating harness resources, see Agent Harness.
Database configuration#
For production environments, set up kagent with an external PostgreSQL instance. For more information, see the Database configuration guide.
Configure controller environment variables#
You can configure the controller by using environment variables for settings such as service names, connection details, and more.
Configure the controller service name#
By default, kagent uses kagent-controller as the controller service name when constructing URLs for agent deployments. If you need to customize this name, set the KAGENT_CONTROLLER_NAME environment variable on the controller pod.
Helm --set flag:
helm install kagent oci://ghcr.io/kagent-dev/kagent/helm/kagent \--namespace kagent \--set controller.env[0].name=KAGENT_CONTROLLER_NAME \--set controller.env[0].value=my-kagent
Helm values file:
controller:env:- name: KAGENT_CONTROLLER_NAMEvalue: my-kagent
More environment variables#
You can add custom environment variables to the controller by using the controller.env field.
Helm --set flag:
helm install kagent oci://ghcr.io/kagent-dev/kagent/helm/kagent \--namespace kagent \--set controller.env[0].name=KAGENT_CONTROLLER_NAME \--set controller.env[0].value=my-kagent \--set controller.env[1].name=LOG_LEVEL \--set controller.env[1].value=debug
Helm values file:
controller:env:- name: KAGENT_CONTROLLER_NAMEvalue: my-kagent- name: LOG_LEVELvalue: debug- name: CUSTOM_VARvalue: custom-value
Using secrets for environment variables#
You can also reference Kubernetes secrets for environment variables by using the envFrom field in Helm.
controller:envFrom:- secretRef:name: controller-secrets
This example loads all key-value pairs from the controller-secrets secret as environment variables in the controller pod.
Uninstallation#
Refer to the Uninstall guide.