Documentation

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=false in your values.yaml file or --set commands for both the kagent and kagent-crds charts.

  1. Set the OpenAI API key as an environment variable.

    export OPENAI_API_KEY="your-api-key-here"
  2. Download the kagent CLI.

    brew install kagent

    or

    curl https://raw.githubusercontent.com/kagent-dev/kagent/refs/heads/main/scripts/get-kagent | bash
  3. 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 minimal flag.

    kagent install --profile demo
    kagent installed successfully
  4. Optionally: Open the kagent dashboard.

    kagent dashboard

    Example output:

    kagent dashboard is available at http://localhost:8082
    Press Enter to stop the port-forward...

Using Helm#

Another way to install kagent is using Helm.

  1. Install the kagent Helm chart with CRDs.

    helm install kagent-crds oci://ghcr.io/kagent-dev/kagent/helm/kagent-crds \
    --namespace kagent \
    --create-namespace
  2. Optionally prepare a Helm values file or --set flags 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.

  1. Set the OPENAI_API_KEY environment variable:

    export OPENAI_API_KEY="your-api-key-here"
  2. 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
  3. Optionally: Port-forward the kagent UI on port 8080.

    kubectl port-forward -n kagent svc/kagent-ui 8080:8080
  4. Open the kagent UI.

  1. Set the ANTHROPIC_API_KEY environment variable:

    export ANTHROPIC_API_KEY="your-api-key-here"
  2. 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
  3. Optionally: Port-forward the kagent UI on port 8080.

    kubectl port-forward -n kagent svc/kagent-ui 8080:8080
  4. Open the kagent UI.

  1. Set the OPENAI_API_KEY environment variable:

    export OPENAI_API_KEY="your-api-key-here"
  2. 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
  3. Optionally: Port-forward the kagent UI on port 8080.

    kubectl port-forward -n kagent svc/kagent-ui 8080:8080
  4. Open the kagent UI.

  1. Set the GEMINI_API_KEY environment variable:

    export GEMINI_API_KEY="your-api-key-here"
  2. 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
  3. Optionally: Port-forward the kagent UI on port 8080.

    kubectl port-forward -n kagent svc/kagent-ui 8080:8080
  4. Open the kagent UI.

  1. Install the kagent Helm chart:

    helm install kagent oci://ghcr.io/kagent-dev/kagent/helm/kagent \
    --namespace kagent \
    --set providers.default=ollama
  2. Optionally: Port-forward the kagent UI on port 8080.

    kubectl port-forward -n kagent svc/kagent-ui 8080:8080
  3. Open the kagent UI.

Advanced Configuration#

Review the following advanced configuration options that you might want to set up for your kagent installation.

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_NAME
value: 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_NAME
value: my-kagent
- name: LOG_LEVEL
value: debug
- name: CUSTOM_VAR
value: 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.

Next Steps#

Kagent Lab: Discover kagent and kmcp
Free, on‑demand lab: build custom AI agents with kagent and integrate tools via kmcp on Kubernetes.