Skip to main content

Global View upgrade (2026.6.1)

Global View is one of the core components of the Virtana Platform. It provides a centralized, unified dashboard to monitor and manage performance across your entire infrastructure, consolidating insights from multiple sources into a single pane of glass.

This topic describes how to upgrade an existing Global View installation from version 2026.4.1 to version 2026.6.1.

Prerequisites

Before you upgrade Global View to 2026.6.1, confirm that your environment meets the following requirements:

  • An existing Virtana Platform installation running version 2026.4.1.

  • A Kubernetes cluster with Helm 3.x installed.

  • Access to the Virtana Helm repository.

  • Valid Docker registry credentials.

  • DNS records configured for the Global View, Keycloak, and GrowthBook hostnames.

What's new in 2026.6.1

Version 2026.6.1 changes several parts of the Global View values files. Review these changes before you prepare your configuration:

  • VirtanAI (Copilot) configuration: The single OPENAI_API_KEY variable is replaced with a provider-based model that supports OpenAI, Gemini, and LiteLLM.

  • SeaweedFS replaces MinIO: Global View now uses SeaweedFS as its object storage backend. Remove all MinIO configuration from your values files.

  • Redis image repository renamed: For private-registry deployments, the Redis image repository changes from redis to dhi-redis.

  • Keycloak image updated: The Keycloak container image changes from quay.io/keycloak/keycloak:26.3 to dhi.io/keycloak:26.

Prepare the Helm values file

Create a file named global-view-values.yaml, and replace all placeholder values with your environment-specific settings. The following sections describe each block in the file.

Global configuration

The global configuration block sets ingress behavior, the PostgreSQL backing store, registry credentials, identity provider settings, and tenant details. Add the following block to global-view-values.yaml:

global:
  controlplane:
    ingress:
      annotations:
        nginx.ingress.kubernetes.io/ssl-redirect: "false"
        nginx.ingress.kubernetes.io/force-ssl-redirect: "false"
  postgresql:
    migration:
      enabled: false
    storage:
      size: 50Gi
  environment: app
  secret_source: valuesfile
  storageClass: &defaultStorageClass ""
  dockerRegistryCredentials:
    DOCKER_SERVER: "https://index.docker.io/v2/"
    DOCKER_USERNAME: "username"
    DOCKER_PASSWORD: "password"
  keycloak:
    hostname: <KEYCLOAK_HOSTNAME>
    adminUser: "vpadmin"
    adminPassword: "P@ssW0rd@123"
  public_dns_host_name: <global_view_hostname>
  public_dns_host_am_suffix: -oc-<global_view_hostname>
  organization_details:
    organization_name: "<TENANT_NAME>"
    first_name: "John"
    last_name: "Doe"
    contact_email: "xxxx.xxxx@domain.com"
  create_tls_selfsigned_certs: true
  affinity: &affinity {}
  nodeSelector: &nodeSelector {}
  tolerations: &tolerations []

The following table describes the fields in the global configuration block:

Field

Description

Default value

global.controlplane.ingress.annotations

Controls the behavior of the NGINX Ingress for the control plane.

nginx.ingress.kubernetes.io/ssl-redirect

Controls automatic HTTP-to-HTTPS redirection.

false

nginx.ingress.kubernetes.io/force-ssl-redirect

When enabled, forces all incoming traffic to be served over HTTPS.

false

global.postgresql

Configures the PostgreSQL database that backs the platform.

postgresql.migration.enabled

Controls whether database migration jobs run automatically. Keep this value set to false when you upgrade to 2026.6.1.

false

postgresql.storage.size

Size of the persistent volume for PostgreSQL.

50Gi

global.environment

Deployment environment name or type.

app

global.secret_source

Specifies where secrets come from. Supported values: valuesfile, none.

valuesfile

global.storageClass

Default Kubernetes StorageClass for persistent volume claims (PVCs). If blank, the cluster default StorageClass is used.

""

global.dockerRegistryCredentials

Credentials used to pull container images from a Docker registry.

DOCKER_SERVER (private registry)

URL of your private registry. Use this when you deploy in an air-gapped environment.

https://index.docker.io/v2/

DOCKER_USERNAME

Registry username.

"username"

DOCKER_PASSWORD

Registry password.

"password"

DOCKER_SERVERS (Docker Hub)

List of servers used when you pull images directly from Docker Hub. Don't change the list.

"https://index.docker.io/v2/", "https://dhi.io/"

global.keycloak

Integrates the platform with a Keycloak identity provider.

keycloak.hostname

Public hostname where Keycloak is accessible.

<KEYCLOAK_HOSTNAME>

keycloak.adminUser, keycloak.adminPassword

Credentials for the Keycloak admin account that configures realms, clients, and users.

vpadmin / P@ssW0rd@123

global.public_dns_host_name

Main DNS name for the Global View UI.

<global_view_hostname>

global.public_dns_host_am_suffix

Suffix used to construct additional hostnames for auxiliary services.

-oc-<global_view_hostname>

global.organization_details

Metadata about the tenant or organization.

organization_name

Tenant or company name.

<TENANT_NAME>

first_name, last_name

Primary contact person.

John / Doe

contact_email

Contact email for notifications and support.

xxxx.xxxx@domain.com

global.create_tls_selfsigned_certs

Controls TLS certificate handling.

true

affinity

Kubernetes pod affinity and anti-affinity rules. An empty value ({}) lets pods schedule anywhere.

{}

nodeSelector

Maps pods to nodes by label. An empty value ({}) applies no node constraints.

{}

tolerations

Allows pods to schedule onto tainted nodes. An empty value ([]) applies no tolerations.

[]

VirtanAI (Copilot) configuration

In 2026.6.1, VirtanAI (the Copilot chatbot) uses a provider-based configuration model that supports OpenAI, Gemini, and LiteLLM. This model replaces the single OPENAI_API_KEY variable used in earlier releases.

Add the following blocks to global-view-values.yaml:

virtana-ai:
  enabled: true
  env:
    VIRTANA_AI_MODEL_PROVIDER: ""   

cp-configs:
  virtana_ai:
    virtana_ai_api_key: ""            
    virtana_ai_inference_endpoint: "" 

The following table describes the VirtanAI configuration fields:

Field

Description

Default value

virtana-ai.enabled

Enables the VirtanAI (Copilot) component.

true

virtana-ai.env.VIRTANA_AI_MODEL_PROVIDER

Selects the model provider. Supported values: OPENAI, GEMINI, LITELLM.

""

cp-configs.virtana_ai.virtana_ai_api_key

API key for the selected provider. Replaces the former OPENAI_API_KEY variable.

""

cp-configs.virtana_ai.virtana_ai_inference_endpoint

Inference endpoint URL. Leave blank for OpenAI or Gemini. For a self-hosted LiteLLM deployment, set the LiteLLM endpoint URL, for example https://litellm.example.com.

""

Set the following variables in the input.env file:

VIRTANA_AI_MODEL_PROVIDER=''
VIRTANA_AI_API_KEY=''
VIRTANA_AI_INFERENCE_ENDPOINT=''

The following table maps VirtanAI setting to its OVA configuration.

Table 9.

OVA Variables

Description

VIRTANA_AI_MODEL_PROVIDER

Selects the model provider. Supported values: OPENAI, GEMINI, LITELLM.

VIRTANA_AI_API_KEY

API key for the selected provider. Replaces the former OPENAI_API_KEY variable.

VIRTANA_AI_INFERENCE_ENDPOINT

Inference endpoint URL. Leave blank for OpenAI or Gemini. For a self-hosted LiteLLM deployment, set the LiteLLM endpoint URL, for example https://litellm.example.com.



SMTP configuration

The SMTP configuration block sets the mail server that Global View uses to send notification emails. Add the following block under cp-configs in global-view-values.yaml:

cp-configs:
  smtp:
    smtpHost: smtp.gmail.com
    smtpPort: "587"
    smtpUsername: ""
    smtpPassword: ""
    smtpFromEmail: "noreplies@virtana.com"
    smtpTlsInsecureSkipVerify: "false"

The following table describes the SMTP configuration fields:

Field

Description

Default value

smtpHost

SMTP server address.

smtp.gmail.com

smtpPort

SMTP port.

"587"

smtpUsername, smtpPassword

Authentication credentials for the SMTP server.

""

smtpFromEmail

Sender address for outgoing notification emails.

"noreplies@virtana.com"

smtpTlsInsecureSkipVerify

When set to false, verifies TLS certificates.

"false"

GrowthBook configuration

The GrowthBook configuration block sets the ingress, hostnames, and scheduling rules for the GrowthBook feature-flag service. Add the following block to global-view-values.yaml:

growthbook:
  ingress:
    enabled: true
    annotations:
      nginx.ingress.kubernetes.io/cors-allow-origin: "https://<GROWTH_BOOK_HOSTNAME>"
    appOriginName: <GROWTH_BOOK_HOSTNAME>
    apiHostName: <GROWTH_BOOK_API_HOSTNAME>
  affinity: *affinity
  nodeSelector: *nodeSelector
  tolerations: *tolerations

The following table describes the GrowthBook configuration fields:

Field

Description

Default value

cors-allow-origin

Restricts browser CORS requests to the GrowthBook UI hostname.

https://<GROWTH_BOOK_HOSTNAME>

appOriginName

Hostname for the GrowthBook web UI.

<GROWTH_BOOK_HOSTNAME>

apiHostName

Hostname for the GrowthBook API endpoint.

<GROWTH_BOOK_API_HOSTNAME>

Storage and infrastructure components

The storage and infrastructure block configures MongoDB, object storage, Redis, Kafka, PostgreSQL, metrics, and alerts. In 2026.6.1, SeaweedFS replaces MinIO as the object storage backend, so the minio block is removed. Add the following block to global-view-values.yaml:

cp-mongodb:
  affinity: *affinity
  nodeSelector: *nodeSelector
  tolerations: *tolerations
  migration:
    enabled: false
  persistence:
    size: 50Gi

seaweedfs:
  image:
    registry: <REGISTRY_NAME>
  allInOne:
    data:
      type: persistentVolumeClaim
      size: 20Gi
      storageClass: *defaultStorageClass
    nodeSelector: *nodeSelector
    affinity: *affinity
    tolerations: *tolerations

redis:
  persistentVolumeClaim:
    existingPersistentVolumeClaim: "redis-data-controlplane-infra-redis-master-0"

strimzi-kafka-operator:
  controller:
    persistence:
      size: 50Gi

cloud-native-postgresql-cluster:
  affinity: *affinity

cp-metrics-service:
  victoria-metrics-single:
    rbac:
      create: true
      namespaced: true
    server:
      size: 100Gi

alerts-service:
  solrdb:
    enabled: true
    persistent_ebs:
      spec:
        resources:
          requests:
            storage: 100Gi
  solr:
    enabled: false
    persistence:
      size: 50Gi
    zookeeper:
      persistence:
        size: 20Gi

The following table describes the storage and infrastructure fields:

Field

Description

Default value

cp-mongodb.migration.enabled

Controls whether MongoDB data migrations run.

false

cp-mongodb.persistence.size

MongoDB storage for control plane documents.

50Gi

seaweedfs.allInOne.data.size

Object storage for files and artifacts. SeaweedFS replaces MinIO in 2026.6.1.

20Gi

seaweedfs.image.registry

Image registry for SeaweedFS. Set this for private-registry deployments.

<REGISTRY_NAME>

redis.persistentVolumeClaim.existingPersistentVolumeClaim

Reuses the existing Redis PVC from the prior installation to preserve data during the upgrade.

strimzi-kafka-operator.controller.persistence.size

Storage for the Strimzi Kafka operator controller state.

50Gi

cp-metrics-service.victoria-metrics-single.server.size

Time-series metrics database size. RBAC is namespaced.

100Gi

alerts-service.solrdb.enabled

Enables the SolrDB component.

true

alerts-service.solrdb.persistent_ebs...storage

EBS-backed Solr database for alert indexing.

100Gi

alerts-service.solr.enabled

Enables the in-chart Solr deployment.

false

alerts-service.solr.persistence.size

Disk size for Solr.

50Gi

alerts-service.solr.zookeeper.persistence.size

ZooKeeper persistence volume size for the Solr coordination service.

20Gi

Note

For an upgrade, Redis references an existingPersistentVolumeClaim instead of creating new storage. This preserves data continuity from the previous Redis deployment.

Note

SeaweedFS replaces MinIO in 2026.6.1. Remove all MinIO configuration from global-view-values.yaml. Existing MinIO data is migrated automatically during the upgrade. If you don't provide a SeaweedFS block, Global View deploys SeaweedFS with default settings.

Private container registry override (optional)

Create a file named global-view-image-registry.yaml to pull images from your own container image registry instead of Virtana's official Docker registry. For the full list of override values, see Overriding the private container registry.

Note

When you build global-view-image-registry.yaml for 2026.6.1, apply these changes: remove the minio block, set the SeaweedFS image registry through seaweedfs.image.registry in global-view-values.yaml, and change the Redis image repository from redis to dhi-redis.

Deploy Global View

In this step, you apply the prepared Helm values and image registry overrides to roll out the upgraded Global View stack to your Kubernetes or OpenShift cluster. The deployment runs in three phases — CRDs, infrastructure modules, and service modules, so that custom resources, storage, messaging, and application services are created and upgraded in a controlled, dependency-aware order. All three phases use the virtana-repo/virtana-global-view Helm chart.

For the detailed deployment commands, see Deploying Global View.

Note

The Keycloak container image changes from quay.io/keycloak/keycloak:26.3 to dhi.io/keycloak:26 in 2026.6.1. Keycloak deploys from a separate chart in the keycloak namespace. Apply the Keycloak image update during the same maintenance window as the Global View upgrade.

Verify the upgrade

To confirm that Global View is accessible after the upgrade, complete the following steps:

  1. Open your web browser and go to https://<global_view_hostname>/ui. Replace <global_view_hostname> with the hostname you defined during configuration.

  2. Sign in with the organization email address and the password you created during registration.

When the UI loads and sign-in succeeds, the upgrade is complete.