Skip to content

Latest commit

 

History

History
329 lines (256 loc) · 41.3 KB

File metadata and controls

329 lines (256 loc) · 41.3 KB

deepgram-self-hosted

Version: 0.9.0 Type: application AppVersion: release-241226 Artifact Hub

A Helm chart for running Deepgram services in a self-hosted environment

Homepage: https://developers.deepgram.com/docs/self-hosted-introduction

Deepgram Self-Hosted Kubernetes Guides: https://developers.deepgram.com/docs/kubernetes

Source Code

Requirements

Kubernetes: >=1.28.0-0

Repository Name Version
https://helm.ngc.nvidia.com/nvidia gpu-operator ^24.3.0
https://kubernetes.github.io/autoscaler cluster-autoscaler ^9.37.0
https://prometheus-community.github.io/helm-charts kube-prometheus-stack ^60.2.0
https://prometheus-community.github.io/helm-charts prometheus-adapter ^4.10.0

Using the Chart

Get Repository Info

helm repo add deepgram https://deepgram.github.io/self-hosted-resources
helm repo update

Installing the Chart

The Deepgram self-hosted chart requires Helm 3.7+ in order to install successfully. Please check your helm release before installation.

You will need to provide your self-service Deepgram licensing and credentials information. See global.deepgramSecretRef and global.pullSecretRef in the Values section for more details, and the Deepgram Self-Hosted Kubernetes Guides for instructions on how to create these secrets.

You may also override any default configuration values. See the Values section for a list of available options, and the samples directory for examples of a standard installation.

helm install -f my-values.yaml [RELEASE_NAME] deepgram/deepgram-self-hosted --atomic --timeout 45m

Upgrade and Rollback Strategies

To upgrade the Deepgram components to a new version, follow these steps:

  1. Update the various image.tag values in the values.yaml file to the desired version.

  2. Run the Helm upgrade command:

    helm upgrade -f my-values.yaml [RELEASE_NAME] deepgram/deepgram-self-hosted --atomic --timeout 60m

If you encounter any issues during the upgrade process, you can perform a rollback to the previous version:

helm rollback deepgram

Before upgrading, ensure that you have reviewed the release notes and any migration guides provided by Deepgram for the specific version you are upgrading to.

Uninstalling the Chart

helm uninstall [RELEASE_NAME]

This removes all the Kubernetes components associated with the chart and deletes the release.

Changelog

See the chart CHANGELOG for a list of relevant changes for each version of the Helm chart.

For more details on changes to the underlying Deepgram resources, such as the container images or available models, see the official Deepgram changelog (RSS feed).

Chart Configuration

Persistent Storage Options

The Deepgram Helm chart supports different persistent storage options for storing Deepgram models and data. The available options include:

  • AWS Elastic File System (EFS)
  • Google Cloud Persistent Disk (GPD)
  • Custom PersistentVolumeClaim (PVC)

To configure a specific storage option, see the engine.modelManager.volumes configuration values. Make sure to provide the necessary configuration values for the selected storage option, such as the EFS file system ID or the GPD disk type and size.

For detailed instructions on setting up and configuring each storage option, refer to the Deepgram self-hosted guides and the respective cloud provider's documentation.

Autoscaling

Autoscaling your cluster's capacity to meet incoming traffic demands involves both node autoscaling and pod autoscaling. Node autoscaling for supported cloud providers is setup by default when using this Helm chart and creating your cluster with the Deepgram self-hosted guides. Pod autoscaling can be enabled via the scaling.auto.enabled configuration option in this chart.

Engine

The Engine component is the core of the Deepgram self-hosted platform, responsible for performing inference using your deployed models. Autoscaling increases the number of Engine replicas to maintain consistent performance for incoming traffic.

There are currently two primary ways to scale the Engine component: scaling with a hard request limit per Engine Pod, or scaling with a soft request limit per Engine pod.

To set a hard limit on which to scale, configure engine.concurrencyLimit.activeRequests and scaling.auto.engine.metrics.requestCapacityRatio. The activeRequests parameter will set a hard limit of how many requests any given Engine pod will accept, and the requestCapacityRatio will govern scaling the Engine deployment when a certain percentage of "available request slots" is filled. For example, a requestCapacityRatio of 0.8 will scale the Engine deployment when the current number of active requests is >=80% of the active request concurrency limit. If the cluster is not able to scale in time and current active requests hits 100% of the preset limit, additional client requests to the API will return a 429 Too Many Requests HTTP response to clients. This hard limit means that if a request is accepted for inference, it will have consistent performance, as the cluster will refuse surplus requests that could overload the cluster and degrade performance, at the expense of possibly rejecting some incoming requests if capacity does not scale in time.

To set a soft limit on which to scale, configure scaling.auto.engine.metrics.{speechToText,textToSpeech}.{batch,streaming}.requestsPerPod, depending on the primary traffic source for your environment. The cluster will attempt to scale to meet this target for number of requests per Engine pod, but will not reject extra requests with a 429 Too Many Request HTTP response like the hard limit will. If the number of extra requests increases faster than the cluster can scale additional capacity, all incoming requests will still be accepted, but the performance of individual requests may degrade.

Note

Deepgram recommends provisioning separate environments for batch speech-to-text, streaming speech-to-text, and text-to-speech workloads because typical latency and throughput tradeoffs are different for each of those use cases.

There is also a scaling.auto.engine.metrics.custom configuration value available to define your own custom scaling metric, if needed.

API

The API component is responsible for accepting incoming requests and forming responses, delegating inference work to the Deepgram Engine as needed. A single API pod can typically handle delegating requests to multiple Engine pods, so it is more compute efficient to deploy fewer API pods relative to the number of Engine pods. The scaling.auto.api.metrics.engineToApiRatio configuration value defines the ratio between Engine to API pods. The default value is appropriate for most deployments.

There is also a scaling.auto.api.metrics.custom configuration value available to define your own custom scaling metric, if needed.

License Proxy

The License Proxy is intended to be deployed as a fixed-scale deployment the proxies all licensing requests from your environment. It should not be upscaled with the traffic demands of your environment.

This chart deploys one License Proxy Pod per environment by default. If you wish to deploy a second License Proxy Pod for redundancy, set licenseProxy.deploySecondReplica to true.

RBAC Configuration

Role-Based Access Control (RBAC) is used to control access to Kubernetes resources based on the roles and permissions assigned to users or service accounts. The Deepgram Helm chart includes default RBAC roles and bindings for the API, Engine, and License Proxy components.

To use custom RBAC roles and bindings based on your specific security requirements, you can individually specify pre-existing ServiceAccounts to bind to each deployment by specifying the following options in values.yaml:

{api|engine|licenseProxy}.serviceAccount.create=false
{api|engine|licenseProxy}.serviceAccount.name=<your-pre-existing-sa>

Make sure to review and adjust the RBAC configuration according to the principle of least privilege, granting only the necessary permissions for each component.

Secret Management

The Deepgram Helm chart takes references to two existing secrets - one containing your distribution credentials to pull container images from Deepgram's image repository, and one containing your Deepgram self-hosted API key.

Consult the official Kubernetes documentation for best practices on configuring Secrets for use in your cluster.

Getting Help

See the Getting Help section in the root of this repository for a list of resources to help you troubleshoot and resolve issues.

Troubleshooting

If you encounter issues while deploying or using Deepgram, consider the following troubleshooting steps:

  1. Check the pod status and logs:

    • Use kubectl get pods to check the status of the Deepgram pods.
    • Use kubectl logs <pod-name> to view the logs of a specific pod.
  2. Verify resource availability:

    • Ensure that the cluster has sufficient CPU, memory, and storage resources to accommodate the Deepgram components.
    • Check for any resource constraints or limits imposed by the namespace or the cluster.
  3. Review the Kubernetes events:

    • Use kubectl get events to view any events or errors related to the Deepgram deployment.
  4. Check the network connectivity:

    • Verify that the Deepgram components can communicate with each other and with the Deepgram license server (license.deepgram.com).
    • Check the network policies and firewall rules to ensure that the necessary ports and protocols are allowed.
  5. Collect diagnostic information:

    • Gather relevant logs and metrics.
    • Export your existing Helm chart values:
      helm get values [RELEASE_NAME] > my-deployed-values.yaml
    • Provide the collected diagnostic information to Deepgram for assistance.

Values

Key Type Default Description
api.additionalAnnotations object nil Additional annotations to add to the API deployment
api.additionalLabels object {} Additional labels to add to API resources
api.affinity object {} Affinity and anti-affinity to apply for API pods.
api.driverPool object `` driverPool configures the backend pool of speech engines (generically referred to as "drivers" here). The API will load-balance among drivers in the standard pool; if one standard driver fails, the next one will be tried.
api.driverPool.standard object `` standard is the main driver pool to use.
api.driverPool.standard.maxResponseSize string "1073741824" Maximum response to deserialize from Driver (in bytes). Default is 1GB, expressed in bytes.
api.driverPool.standard.retryBackoff float 1.6 retryBackoff is the factor to increase the retrySleep by for each additional retry (for exponential backoff).
api.driverPool.standard.retrySleep string "2s" retrySleep defines the initial sleep period (in humantime duration) before attempting a retry.
api.driverPool.standard.timeoutBackoff float 1.2 timeoutBackoff is the factor to increase the timeout by for each additional retry (for exponential backoff).
api.features object `` Enable ancillary features
api.features.diskBufferPath string nil If API is receiving requests faster than Engine can process them, a request queue will form. By default, this queue is stored in memory. Under high load, the queue may grow too large and cause Out-Of-Memory errors. To avoid this, set a diskBufferPath to buffer the overflow on the request queue to disk. WARN: This is only to temporarily buffer requests during high load. If there is not enough Engine capacity to process the queued requests over time, the queue (and response time) will grow indefinitely.
api.features.entityDetection bool false Enables entity detection on pre-recorded audio if a valid entity detection model is available. WARNING: Beta functionality.
api.features.entityRedaction bool false Enables entity-based redaction on pre-recorded audio if a valid entity detection model is available. WARNING: Beta functionality.
api.image.path string "quay.io/deepgram/self-hosted-api" path configures the image path to use for creating API containers. You may change this from the public Quay image path if you have imported Deepgram images into a private container registry.
api.image.pullPolicy string "IfNotPresent" pullPolicy configures how the Kubelet attempts to pull the Deepgram API image
api.image.tag string "release-241226" tag defines which Deepgram release to use for API containers
api.livenessProbe object `` Liveness probe customization for API pods.
api.namePrefix string "deepgram-api" namePrefix is the prefix to apply to the name of all K8s objects associated with the Deepgram API containers.
api.readinessProbe object `` Readiness probe customization for API pods.
api.resolver object `` Specify custom DNS resolution options.
api.resolver.maxTTL int nil maxTTL sets the DNS TTL value if specifying a custom DNS nameserver.
api.resolver.nameservers list [] nameservers allows for specifying custom domain name server(s). A valid list item's format is "{IP} {PORT} {PROTOCOL (tcp or udp)}", e.g. "127.0.0.1 53 udp".
api.resources object `` Configure resource limits per API container. See Deepgram's documentation for more details.
api.securityContext object {} Security context for API pods.
api.server object `` Configure how the API will listen for your requests
api.server.callbackConnTimeout string "1s" callbackConnTimeout configures how long to wait for a connection to a callback URL. See Deepgram's callback documentation for more details. The value should be a humantime duration.
api.server.callbackTimeout string "10s" callbackTimeout configures how long to wait for a response from a callback URL. See Deepgram's callback documentation for more details. The value should be a humantime duration.
api.server.fetchConnTimeout string "1s" fetchConnTimeout configures how long to wait for a connection to a fetch URL. The value should be a humantime duration. A fetch URL is a URL passed in an inference request from which a payload should be downloaded.
api.server.fetchTimeout string "60s" fetchTimeout configures how long to wait for a response from a fetch URL. The value should be a humantime duration. A fetch URL is a URL passed in an inference request from which a payload should be downloaded.
api.server.host string "0.0.0.0" host is the IP address to listen on. You will want to listen on all interfaces to interact with other pods in the cluster.
api.server.port int 8080 port to listen on.
api.serviceAccount.create bool true Specifies whether to create a default service account for the Deepgram API Deployment.
api.serviceAccount.name string nil Allows providing a custom service account name for the API component. If left empty, the default service account name will be used. If specified, and api.serviceAccount.create = true, this defines the name of the default service account. If specified, and api.serviceAccount.create = false, this provides the name of a preconfigured service account you wish to attach to the API deployment.
api.tolerations list [] Tolerations to apply to API pods.
api.updateStrategy.rollingUpdate.maxSurge int 1 The maximum number of extra API pods that can be created during a rollingUpdate, relative to the number of replicas. See the Kubernetes documentation for more details.
api.updateStrategy.rollingUpdate.maxUnavailable int 0 The maximum number of API pods, relative to the number of replicas, that can go offline during a rolling update. See the Kubernetes documentation for more details.
cluster-autoscaler.autoDiscovery.clusterName string nil Name of your AWS EKS cluster. Using the Cluster Autoscaler on AWS requires knowledge of certain cluster metadata.
cluster-autoscaler.awsRegion string nil Region of your AWS EKS cluster. Using the Cluster Autoscaler on AWS requires knowledge of certain cluster metadata.
cluster-autoscaler.enabled bool false Set to true to enable node autoscaling with AWS EKS. Note needed for GKE, as autoscaling is enabled by a cli option on cluster creation.
cluster-autoscaler.rbac.serviceAccount.annotations."eks.amazonaws.com/role-arn" string nil Replace with the AWS Role ARN configured for the Cluster Autoscaler. See the Deepgram AWS EKS guide or Cluster Autoscaler AWS documentation for details.
cluster-autoscaler.rbac.serviceAccount.name string "cluster-autoscaler-sa" Name of the IAM Service Account with the necessary permissions
engine.additionalAnnotations object nil Additional annotations to add to the Engine deployment
engine.additionalLabels object {} Additional labels to add to Engine resources
engine.affinity object {} Affinity and anti-affinity to apply for Engine pods.
engine.chunking object `` chunking defines the size of audio chunks to process in seconds. Adjusting these values will affect both inference performance and accuracy of results. Please contact your Deepgram Account Representative if you want to adjust any of these values.
engine.chunking.speechToText.batch.maxDuration float nil minDuration is the maximum audio duration for a STT chunk size for a batch request
engine.chunking.speechToText.batch.minDuration float nil minDuration is the minimum audio duration for a STT chunk size for a batch request
engine.chunking.speechToText.streaming.maxDuration float nil minDuration is the maximum audio duration for a STT chunk size for a streaming request
engine.chunking.speechToText.streaming.minDuration float nil minDuration is the minimum audio duration for a STT chunk size for a streaming request
engine.chunking.speechToText.streaming.step float 1 step defines how often to return interim results, in seconds. This value may be lowered to increase the frequency of interim results. However, this also causes a significant decrease in the number of concurrent streams supported by a single GPU. Please contact your Deepgram Account representative for more details.
engine.concurrencyLimit.activeRequests int nil activeRequests limits the number of active requests handled by a single Engine container. If additional requests beyond the limit are sent, the API container forming the request will try a different Engine pod. If no Engine pods are able to accept the request, the API will return a 429 HTTP response to the client. The nil default means no limit will be set.
engine.halfPrecision.state string "auto" Engine will automatically enable half precision operations if your GPU supports them. You can explicitly enable or disable this behavior with the state parameter which supports "enable", "disabled", and "auto".
engine.image.path string "quay.io/deepgram/self-hosted-engine" path configures the image path to use for creating Engine containers. You may change this from the public Quay image path if you have imported Deepgram images into a private container registry.
engine.image.pullPolicy string "IfNotPresent" pullPolicy configures how the Kubelet attempts to pull the Deepgram Engine image
engine.image.tag string "release-241226" tag defines which Deepgram release to use for Engine containers
engine.livenessProbe object `` Liveness probe customization for Engine pods.
engine.metricsServer object `` metricsServer exposes an endpoint on each Engine container for reporting inference-specific system metrics. See https://developers.deepgram.com/docs/metrics-guide#deepgram-engine for more details.
engine.metricsServer.host string "0.0.0.0" host is the IP address to listen on for metrics requests. You will want to listen on all interfaces to interact with other pods in the cluster.
engine.metricsServer.port int 9991 port to listen on for metrics requests
engine.modelManager.models.add list [] Links to your Deepgram models to automatically download into storage backing a persistent volume. Automatic model management is currently supported for AWS EFS volumes only. Insert each model link provided to you by your Deepgram Account Representative.
engine.modelManager.models.links list [] Deprecated field to automatically download models. Functionality still supported, but migration to use engine.modelManager.models.add is strongly recommended.
engine.modelManager.models.remove list [] If desiring to remove a model from storage (to reduce number of models loaded by Engine on startup), move a link from the engine.modelManager.models.add section to this section. You can also use a model name instead of the full link to designate for removal. Automatic model management is currently supported for AWS EFS volumes only.
engine.modelManager.volumes.aws.efs.enabled bool false Whether to use an AWS Elastic File Sytem to store Deepgram models for use by Engine containers. This option requires your cluster to be running in AWS EKS.
engine.modelManager.volumes.aws.efs.fileSystemId string nil FileSystemId of existing AWS Elastic File System where Deepgram model files will be persisted. You can find it using the AWS CLI: $ aws efs describe-file-systems --query "FileSystems[*].FileSystemId"
engine.modelManager.volumes.aws.efs.forceDownload bool false Whether to force a fresh download of all model links provided, even if models are already present in EFS.
engine.modelManager.volumes.aws.efs.namePrefix string "dg-models" Name prefix for the resources associated with the model storage in AWS EFS.
engine.modelManager.volumes.customVolumeClaim.enabled bool false You may manually create your own PersistentVolume and PersistentVolumeClaim to store and expose model files to the Deepgram Engine. Configure your storage beforehand, and enable here. Note: Make sure the PV and PVC accessMode are set to readWriteMany or readOnlyMany
engine.modelManager.volumes.customVolumeClaim.modelsDirectory string "/" Name of the directory within your pre-configured PersistentVolume where the models are stored
engine.modelManager.volumes.customVolumeClaim.name string nil Name of your pre-configured PersistentVolumeClaim
engine.modelManager.volumes.gcp.gpd.enabled bool false Whether to use an GKE Persistent Disks to store Deepgram models for use by Engine containers. This option requires your cluster to be running in GCP GKE. See the GKE documentation on using pre-existing persistent disks.
engine.modelManager.volumes.gcp.gpd.fsType string "ext4"
engine.modelManager.volumes.gcp.gpd.namePrefix string "dg-models" Name prefix for the resources associated with the model storage in GCP GPD.
engine.modelManager.volumes.gcp.gpd.storageCapacity string "40G" The size of your pre-existing persistent disk.
engine.modelManager.volumes.gcp.gpd.storageClassName string "standard-rwo" The storageClassName of the existing persistent disk.
engine.modelManager.volumes.gcp.gpd.volumeHandle string "" The identifier of your pre-existing persistent disk. The format is projects/{project_id}/zones/{zone_name}/disks/{disk_name} for Zonal persistent disks, or projects/{project_id}/regions/{region_name}/disks/{disk_name} for Regional persistent disks.
engine.namePrefix string "deepgram-engine" namePrefix is the prefix to apply to the name of all K8s objects associated with the Deepgram Engine containers.
engine.readinessProbe object `` Readiness probe customization for Engine pods.
engine.resources object `` Configure resource limits per Engine container. See Deepgram's documentation for more details.
engine.resources.limits.gpu int 1 gpu maps to the nvidia.com/gpu resource parameter
engine.resources.requests.gpu int 1 gpu maps to the nvidia.com/gpu resource parameter
engine.securityContext object {} Security context for API pods.
engine.server object `` Configure Engine containers to listen for requests from API containers.
engine.server.host string "0.0.0.0" host is the IP address to listen on for inference requests. You will want to listen on all interfaces to interact with other pods in the cluster.
engine.server.port int 8080 port to listen on for inference requests
engine.serviceAccount.create bool true Specifies whether to create a default service account for the Deepgram Engine Deployment.
engine.serviceAccount.name string nil Allows providing a custom service account name for the Engine component. If left empty, the default service account name will be used. If specified, and engine.serviceAccount.create = true, this defines the name of the default service account. If specified, and engine.serviceAccount.create = false, this provides the name of a preconfigured service account you wish to attach to the Engine deployment.
engine.startupProbe object `` The startupProbe combination of periodSeconds and failureThreshold allows time for the container to load all models and start listening for incoming requests. Model load time can be affected by hardware I/O speeds, as well as network speeds if you are using a network volume mount for the models. If you are hitting the failure threshold before models are finished loading, you may want to extend the startup probe. However, this will also extend the time it takes to detect a pod that can't establish a network connection to validate its license.
engine.startupProbe.failureThreshold int 60 failureThreshold defines how many unsuccessful startup probe attempts are allowed before the container will be marked as Failed
engine.startupProbe.periodSeconds int 10 periodSeconds defines how often to execute the probe.
engine.tolerations list [] Tolerations to apply to Engine pods.
engine.updateStrategy.rollingUpdate.maxSurge int 1 The maximum number of extra Engine pods that can be created during a rollingUpdate, relative to the number of replicas. See the Kubernetes documentation for more details.
engine.updateStrategy.rollingUpdate.maxUnavailable int 0 The maximum number of Engine pods, relative to the number of replicas, that can go offline during a rolling update. See the Kubernetes documentation for more details.
global.additionalLabels object {} Additional labels to add to all Deepgram resources
global.deepgramSecretRef string nil Name of the pre-configured K8s Secret containing your Deepgram self-hosted API key. See chart docs for more details.
global.outstandingRequestGracePeriod int 1800 When an API or Engine container is signaled to shutdown via Kubernetes sending a SIGTERM signal, the container will stop listening on its port, and no new requests will be routed to that container. However, the container will continue to run until all existing batch or streaming requests have completed, after which it will gracefully shut down. Batch requests should be finished within 10-15 minutes, but streaming requests can proceed indefinitely. outstandingRequestGracePeriod defines the period (in sec) after which Kubernetes will forcefully shutdown the container, terminating any outstanding connections. 1800 / 60 sec/min = 30 mins
global.pullSecretRef string nil If using images from the Deepgram Quay image repositories, or another private registry to which your cluster doesn't have default access, you will need to provide a pre-configured K8s Secret with image repository credentials. See chart docs for more details.
gpu-operator object `` Passthrough values for NVIDIA GPU Operator Helm chart You may use the NVIDIA GPU Operator to manage installation of NVIDIA drivers and the container toolkit on nodes with attached GPUs.
gpu-operator.driver.enabled bool true Whether to install NVIDIA drivers on nodes where a NVIDIA GPU is detected. If your Kubernetes nodes run a base image that comes with NVIDIA drivers pre-configured, disable this option, but keep the parent gpu-operator and sibling toolkit options enabled.
gpu-operator.driver.version string "550.54.15" NVIDIA driver version to install.
gpu-operator.enabled bool true Whether to install the NVIDIA GPU Operator to manage driver and/or container toolkit installation. See the list of supported Operating Systems to verify compatibility with your cluster/nodes. Disable this option if your cluster/nodes are not compatible. If disabled, you will need to self-manage NVIDIA software installation on all nodes where you want to schedule Deepgram Engine pods.
gpu-operator.toolkit.enabled bool true Whether to install NVIDIA drivers on nodes where a NVIDIA GPU is detected.
gpu-operator.toolkit.version string "v1.15.0-ubi8" NVIDIA container toolkit to install. The default ubuntu image tag for the toolkit requires a dynamic runtime link to a version of GLIBC that may not be present on nodes running older Linux distribution releases, such as Ubuntu 22.04. Therefore, we specify the ubi8 image, which statically links the GLIBC library and avoids this issue.
kube-prometheus-stack object `` Passthrough values for Prometheus k8s stack Helm chart. Prometheus (and its adapter) should be configured when scaling.auto is enabled. You may choose to use the installation/configuration bundled in this Helm chart, or you may configure an existing Prometheus installation in your cluster to expose the needed values. See source Helm chart for explanation of available values. Default values provided in this chart are used to provide pod autoscaling for Deepgram pods.
kube-prometheus-stack.includeDependency bool nil Normally, this chart will be installed if scaling.auto.enabled is true. However, if you wish to manage the Prometheus adapter in your cluster on your own and not as part of the Deepgram Helm chart, you can force it to not be installed by setting this to false.
licenseProxy object `` Configuration options for the optional Deepgram License Proxy.
licenseProxy.additionalAnnotations object nil Additional annotations to add to the LicenseProxy deployment
licenseProxy.additionalLabels object {} Additional labels to add to License Proxy resources
licenseProxy.affinity object {} Affinity and anti-affinity to apply for License Proxy pods.
licenseProxy.deploySecondReplica bool false If the License Proxy is deployed, one replica should be sufficient to support many API/Engine pods. Highly available environments may wish to deploy a second replica to ensure uptime, which can be toggled with this option.
licenseProxy.enabled bool false The License Proxy is optional, but highly recommended to be deployed in production to enable highly available environments.
licenseProxy.image.path string "quay.io/deepgram/self-hosted-license-proxy" path configures the image path to use for creating License Proxy containers. You may change this from the public Quay image path if you have imported Deepgram images into a private container registry.
licenseProxy.image.pullPolicy string "IfNotPresent" pullPolicy configures how the Kubelet attempts to pull the Deepgram License Proxy image
licenseProxy.image.tag string "release-241226" tag defines which Deepgram release to use for License Proxy containers
licenseProxy.keepUpstreamServerAsBackup bool true Even with a License Proxy deployed, API and Engine pods can be configured to keep the upstream license.deepgram.com license server as a fallback licensing option if the License Proxy is unavailable. Disable this option if you are restricting API/Engine Pod network access for security reasons, and only the License Proxy should send egress traffic to the upstream license server.
licenseProxy.livenessProbe object `` Liveness probe customization for Proxy pods.
licenseProxy.namePrefix string "deepgram-license-proxy" namePrefix is the prefix to apply to the name of all K8s objects associated with the Deepgram License Proxy containers.
licenseProxy.readinessProbe object `` Readiness probe customization for License Proxy pods.
licenseProxy.resources object `` Configure resource limits per License Proxy container. See Deepgram's documentation for more details.
licenseProxy.securityContext object {} Security context for API pods.
licenseProxy.server object `` Configure how the license proxy will listen for licensing requests.
licenseProxy.server.baseUrl string "/" baseUrl is the prefix for incoming license verification requests.
licenseProxy.server.host string "0.0.0.0" host is the IP address to listen on. You will want to listen on all interfaces to interact with other pods in the cluster.
licenseProxy.server.port int 8443 port to listen on.
licenseProxy.server.statusPort int 8080 statusPort is the port to listen on for the status/health endpoint.
licenseProxy.serviceAccount.create bool true Specifies whether to create a default service account for the Deepgram License Proxy Deployment.
licenseProxy.serviceAccount.name string nil Allows providing a custom service account name for the LicenseProxy component. If left empty, the default service account name will be used. If specified, and licenseProxy.serviceAccount.create = true, this defines the name of the default service account. If specified, and licenseProxy.serviceAccount.create = false, this provides the name of a preconfigured service account you wish to attach to the License Proxy deployment.
licenseProxy.tolerations list [] Tolerations to apply to License Proxy pods.
licenseProxy.updateStrategy.rollingUpdate object `` For the LicenseProxy, we only expose maxSurge and not maxUnavailable. This is to avoid accidentally having all LicenseProxy nodes go offline during upgrades, which could impact the entire cluster's connection to the Deepgram License Server.
licenseProxy.updateStrategy.rollingUpdate.maxSurge int 1 The maximum number of extra License Proxy pods that can be created during a rollingUpdate, relative to the number of replicas. See the Kubernetes documentation for more details.
prometheus-adapter object `` Passthrough values for Prometheus Adapter Helm chart. Prometheus, and its adapter here, should be configured when scaling.auto is enabled. You may choose to use the installation/configuration bundled in this Helm chart, or you may configure an existing Prometheus installation in your cluster to expose the needed values. See source Helm chart for explanation of available values. Default values provided in this chart are used to provide pod autoscaling for Deepgram pods.
prometheus-adapter.includeDependency string nil Normally, this chart will be installed if scaling.auto.enabled is true. However, if you wish to manage the Prometheus adapter in your cluster on your own and not as part of the Deepgram Helm chart, you can force it to not be installed by setting this to false.
scaling object `` Configuration options for horizontal scaling of Deepgram services. Only one of static and auto options can be enabled.
scaling.auto object `` Enable pod autoscaling based on system load/traffic.
scaling.auto.api.metrics.custom list nil If you have custom metrics you would like to scale with, you may add them here. See the k8s docs for how to structure a list of metrics
scaling.auto.api.metrics.engineToApiRatio int 4 Scale the API deployment to this Engine-to-Api pod ratio
scaling.auto.engine.behavior object "See values.yaml file for default" Configurable scaling behavior
scaling.auto.engine.maxReplicas int 10 Maximum number of Engine replicas.
scaling.auto.engine.metrics.custom list [] If you have custom metrics you would like to scale with, you may add them here. See the k8s docs for how to structure a list of metrics
scaling.auto.engine.metrics.requestCapacityRatio string nil If engine.concurrencyLimit.activeRequests is set, this variable will define the ratio of current active requests to maximum active requests at which the Engine pods will scale. Setting this value too close to 1.0 may lead to a situation where the cluster is at max capacity and rejects incoming requests. Setting the ratio too close to 0.0 will over-optimistically scale your cluster and increase compute costs unnecessarily.
scaling.auto.engine.metrics.speechToText.batch.requestsPerPod int nil Scale the Engine pods based on a static desired number of speech-to-text batch requests per pod
scaling.auto.engine.metrics.speechToText.streaming.requestsPerPod int nil Scale the Engine pods based on a static desired number of speech-to-text streaming requests per pod
scaling.auto.engine.metrics.textToSpeech.batch.requestsPerPod int nil Scale the Engine pods based on a static desired number of text-to-speech batch requests per pod
scaling.auto.engine.minReplicas int 1 Minimum number of Engine replicas.
scaling.replicas object `` Number of replicas to set during initial installation.

Maintainers

Name Email Url
Deepgram Self-Hosted [email protected]