Create an HTTPRoute with Gateway API

If you install Longhorn on a Kubernetes cluster with kubectl or Helm, you can use Gateway API HTTPRoute as a modern alternative to Ingress for exposing the Longhorn UI to external traffic.

Gateway API is the successor to Ingress, offering more expressive routing capabilities and a standardized approach across different implementations.

Prerequisites

  1. Gateway API CRDs installed in your cluster:

    kubectl apply -f https://github.com/kubernetes-sigs/gateway-api/releases/download/v1.2.0/standard-install.yaml
    
  2. A Gateway controller running in your cluster (e.g., Istio, Envoy Gateway, Cilium, NGINX Gateway Fabric, Traefik, etc.)

  3. At least one Gateway resource deployed and configured

Helm Values Configuration

The following Helm values control HTTPRoute generation:

KeyTypeDefaultDescription
httproute.enabledboolfalseEnable HTTPRoute generation for Longhorn UI
httproute.parentRefslist[]Gateway references specifying which Gateway(s) should handle this route
httproute.hostnameslist[]List of hostnames for the HTTPRoute
httproute.pathstring"/"Path for accessing Longhorn UI
httproute.pathTypestring"PathPrefix"Path match type: Exact, PathPrefix, or RegularExpression
httproute.annotationsobject{}Annotations for the HTTPRoute resource

Basic Installation

Install Longhorn with HTTPRoute enabled:

helm install longhorn longhorn/longhorn \
  --namespace longhorn-system \
  --create-namespace \
  --set "httproute.enabled=true" \
  --set "httproute.parentRefs[0].name=my-gateway" \
  --set "httproute.parentRefs[0].namespace=default" \
  --set "httproute.hostnames[0]=longhorn.example.com"

Advanced Configuration

For more complex setups, create a values file:

httproute:
  enabled: true
  parentRefs:
    - name: primary-gateway
      namespace: gateway-system
    - name: secondary-gateway
      namespace: gateway-system
      sectionName: https  # Target specific listener
  hostnames:
    - longhorn.example.com
    - longhorn.example.org
  path: /longhorn
  pathType: PathPrefix
  annotations:
    custom-annotation: "value"

Install with the values file:

helm install longhorn longhorn/longhorn \
  --namespace longhorn-system \
  --create-namespace \
  --values values.yaml

Verification

  1. Verify the HTTPRoute was created:

    kubectl get httproute -n longhorn-system
    
  2. Check HTTPRoute details:

    kubectl describe httproute longhorn-httproute -n longhorn-system
    
  3. Verify the route is accepted by the Gateway:

    kubectl get httproute longhorn-httproute -n longhorn-system -o jsonpath='{.status.parents[*].conditions}'
    

    The output should show Accepted: True and ResolvedRefs: True.

  4. Access the Longhorn UI through your Gateway’s external IP or hostname.

References


© 2019-2026 Longhorn Authors | Documentation Distributed under CC-BY-4.0


© 2026 The Linux Foundation. All rights reserved. The Linux Foundation has registered trademarks and uses trademarks. For a list of trademarks of The Linux Foundation, please see our Trademark Usage page.