Wavefront Prometheus Adapter packaged by Bitnami¶
Wavefront Storage Adapter is a Prometheus integration to transfer metrics from Prometheus to Wavefront. It lets you save Prometheus data in Wavefront without changing your existing Prometheus setup.
Overview of Wavefront Prometheus Adapter
TL;DR¶
使用加速地址添加仓库:
Introduction¶
Bitnami charts for Helm are carefully engineered, actively maintained and are the quickest and easiest way to deploy containers on a Kubernetes cluster that are ready to handle production workloads.
Wavefront Prometheus Adapter works as a "fork", such that data written to Prometheus is also written to Wavefront. It supports metrics path conversion and direct ingestion of metrics.
This chart bootstraps a Wavefront Storage Adapter for Prometheus Deployment in a Kubernetes cluster using the Helm package manager.
Bitnami charts can be used with Kubeapps for deployment and management of Helm Charts in clusters.
Prerequisites¶
- Kubernetes 1.19+
- Helm 3.2.0+
Installing the Chart¶
To install the chart with the release name my-release
:
These commands deploy wavefront-prometheus-storage-adapter on the Kubernetes cluster in the default configuration. The Parameters section lists the parameters that can be configured during installation.
Tip: List all releases using
helm list
Uninstalling the Chart¶
To uninstall/delete the my-release
helm release:
The command removes all the Kubernetes components associated with the chart and deletes the release.
Parameters¶
Global parameters¶
Name | Description | Value |
---|---|---|
global.imageRegistry | Global Docker image registry | "" |
global.imagePullSecrets | Global Docker registry secret names as an array | [] |
global.storageClass | Global StorageClass for Persistent Volume(s) | "" |
Common parameters¶
Name | Description | Value |
---|---|---|
kubeVersion | Override Kubernetes version | "" |
nameOverride | String to partially override common.names.fullname | "" |
fullnameOverride | String to fully override common.names.fullname | "" |
commonLabels | Labels to add to all deployed objects | {} |
commonAnnotations | Annotations to add to all deployed objects | {} |
clusterDomain | Kubernetes cluster domain name | cluster.local |
extraDeploy | Array of extra objects to deploy with the release | [] |
diagnosticMode.enabled | Enable diagnostic mode (all probes will be disabled and the command will be overridden) | false |
diagnosticMode.command | Command to override all containers in the deployment | ["sleep"] |
diagnosticMode.args | Args to override all containers in the deployment | ["infinity"] |
Wavefront Prometheus Storage Adapter deployment parameters¶
Name | Description | Value |
---|---|---|
image.registry | Adapter image registry | docker.io |
image.repository | Adapter image repository | bitnami/wavefront-prometheus-storage-adapter |
image.tag | Adapter image tag (immutable tags are recommended) | 1.0.7-debian-11-r23 |
image.digest | Adapter image digest in the way sha256:aa.... Please note this parameter, if set, will override the tag | "" |
image.pullPolicy | Adapter image pull policy | IfNotPresent |
image.pullSecrets | Specify docker-registry secret names as an array | [] |
image.debug | Enable image debug mode | false |
replicaCount | Number of Adapter replicas to deploy | 1 |
startupProbe.enabled | Enable startupProbe | true |
startupProbe.initialDelaySeconds | Initial delay seconds for startupProbe | 10 |
startupProbe.periodSeconds | Period seconds for startupProbe | 10 |
startupProbe.timeoutSeconds | Timeout seconds for startupProbe | 1 |
startupProbe.failureThreshold | Failure threshold for startupProbe | 3 |
startupProbe.successThreshold | Success threshold for startupProbe | 1 |
livenessProbe.enabled | Enable livenessProbe | true |
livenessProbe.initialDelaySeconds | Initial delay seconds for livenessProbe | 15 |
livenessProbe.periodSeconds | Period seconds for livenessProbe | 10 |
livenessProbe.timeoutSeconds | Timeout seconds for livenessProbe | 5 |
livenessProbe.failureThreshold | Failure threshold for livenessProbe | 5 |
livenessProbe.successThreshold | Success threshold for livenessProbe | 1 |
readinessProbe.enabled | Enable readinessProbe | true |
readinessProbe.initialDelaySeconds | Initial delay seconds for readinessProbe | 15 |
readinessProbe.periodSeconds | Period seconds for readinessProbe | 10 |
readinessProbe.timeoutSeconds | Timeout seconds for readinessProbe | 5 |
readinessProbe.failureThreshold | Failure threshold for readinessProbe | 5 |
readinessProbe.successThreshold | Success threshold for readinessProbe | 1 |
command | Override default container command (useful when using custom images) | [] |
args | Override default container args (useful when using custom images) | [] |
hostAliases | Add deployment host aliases | [] |
resources.limits | The resources limits for the Adapter container | {} |
resources.requests | The requested resourcesc for the Adapter container | {} |
containerSecurityContext.enabled | Enabled Adapter containers' Security Context | true |
containerSecurityContext.runAsUser | Set Adapter container's Security Context runAsUser | 1001 |
containerSecurityContext.runAsNonRoot | Set Adapter container's Security Context runAsNonRoot | true |
podSecurityContext.enabled | Enabled Adapter pods' Security Context | true |
podSecurityContext.fsGroup | Set Adapter pod's Security Context fsGroup | 1001 |
podAffinityPreset | Pod affinity preset. Ignored if affinity is set. Allowed values: soft or hard | "" |
podAntiAffinityPreset | Pod anti-affinity preset. Ignored if affinity is set. Allowed values: soft or hard | soft |
nodeAffinityPreset.type | Node affinity preset type. Ignored if affinity is set. Allowed values: soft or hard | "" |
nodeAffinityPreset.key | Node label key to match. Ignored if affinity is set | "" |
nodeAffinityPreset.values | Node label values to match. Ignored if affinity is set | [] |
affinity | Affinity for pod assignment | {} |
nodeSelector | Node labels for pod assignment | {} |
tolerations | Tolerations for pod assignment | [] |
podLabels | Extra labels for Adapter pods | {} |
podAnnotations | Annotations for Adapter pods | {} |
priorityClassName | Adapter pod priority | "" |
schedulerName | Use an alternate scheduler, e.g. "stork". | "" |
topologySpreadConstraints | Topology Spread Constraints for pod assignment spread across your cluster among failure-domains. Evaluated as a template | [] |
terminationGracePeriodSeconds | Termination grace period in seconds | "" |
lifecycleHooks | Add lifecycle hooks to the Adapter deployment | {} |
customStartupProbe | Override default startup probe | {} |
customLivenessProbe | Override default liveness probe | {} |
customReadinessProbe | Override default readiness probe | {} |
updateStrategy.type | Adapter deployment update strategy | RollingUpdate |
containerPorts.http | Adapter HTTP container port | 1234 |
extraEnvVars | Add extra environment variables to the Adapter container | [] |
extraEnvVarsCM | Name of existing ConfigMap containing extra env vars | "" |
extraEnvVarsSecret | Name of existing Secret containing extra env vars | "" |
extraVolumes | Optionally specify extra list of additional volumes for Adapter pods | [] |
extraVolumeMounts | Optionally specify extra list of additional volumeMounts for Adapter container(s) | [] |
initContainers | Add additional init containers to the Adapter pods | [] |
sidecars | Add additional sidecar containers to the Adapter pod | [] |
externalProxy.host | Host of a wavefront-proxy instance (required if wavefront.enabled = false) | "" |
externalProxy.port | Host of a wavefront-proxy instance (required if wavefront.enabled = false) | 2878 |
adapterPrefix | Adapter prefix parameter | "" |
adapterTags | Adapter tags parameter | "" |
Traffic Exposure Parameters¶
Name | Description | Value |
---|---|---|
service.type | Adapter service type | ClusterIP |
service.ports.http | Adapter service HTTP port | 1234 |
service.clusterIP | Adapter service Cluster IP | "" |
service.loadBalancerIP | Adapter service LoadBalancer IP | "" |
service.loadBalancerSourceRanges | loadBalancerIP source ranges for the Service | [] |
service.extraPorts | Extra ports to expose (normally used with the sidecar value) | [] |
service.annotations | Additional custom annotations for Adapter service | {} |
service.sessionAffinity | Control where client requests go, to the same pod or round-robin | None |
service.sessionAffinityConfig | Additional settings for the sessionAffinity | {} |
service.nodePorts.http | NodePort for the HTTP endpoint | "" |
service.externalTrafficPolicy | External traffic policy for the service | Cluster |
Wavefront sub-chart parameters¶
Name | Description | Value |
---|---|---|
wavefront.enabled | Deploy Wavefront chart (necessary if externalProxyHost is not set) | true |
wavefront.wavefront.url | Wavefront SAAS service URL | https://YOUR_CLUSTER.wavefront.com |
wavefront.wavefront.token | Wavefront SAAS token | YOUR_API_TOKEN |
wavefront.collector.enabled | Deploy Wavefront collector (not used by the Adapter pod) | false |
wavefront.rbac.create | Create RBAC rules (not necessary as the Adapter only uses wavefront-proxy) | false |
wavefront.proxy.enabled | Deploy Wavefront Proxy (required if externalProxyHost is not set) | true |
wavefront.proxy.port | Deployed Wavefront Proxy port (required if externalProxyHost is not set) | 2878 |
wavefront.serviceAccount.create | Create Wavefront serivce account (not necessary as the Adapter only uses wavefront-proxy) | false |
Specify each parameter using the --set key=value[,key=value]
argument to helm install
. For example,
helm install my-release \
--set livenessProbe.successThreshold=5 \
bitnami/wavefront-prometheus-storage-adapter
The above command sets the livenessProbe.successThreshold
to 5
.
Alternatively, a YAML file that specifies the values for the parameters can be provided while installing the chart. For example,
Configuration and installation details¶
Rolling VS Immutable tags¶
It is strongly recommended to use immutable tags in a production environment. This ensures your deployment does not change automatically if the same tag is updated with a different image.
Bitnami will release a new chart updating its containers if a new version of the main container, significant changes, or critical vulnerabilities exist.
Connect to a Wavefront Proxy instance¶
The Wavefront Prometheus Storage Adapter chart needs to be connected to a Wavefront Proxy instance. This can be done in two different ways:
-
Deploying the Wavefront subchart, using only the Wavefront Proxy component (default behavior): This is done by setting
wavefront.enabled=true
andwavefront.proxy.enabled=true
, but leaving theexternalProxy.host
value unset. We recommend disabling the rest of the Wavefront sub-chart resources as they would not be used by the Prometheus Storage Adapter. You also need to configure the Wavefront SaaS URL and token using thewavefont.wavefront.url
andwavefront.wavefront.token
parameters. -
Using an external Wavefront Proxy instance: This is done by setting the
externalProxy.host
andexternalProxy.port
values. In this case, you should set thewavefront.enabled
value tofalse
. You also need to configure the Wavefront SaaS URL and token using thewavefront.wavefront.url
andwavefront.wavefront.token
parameters.
Configure Prometheus¶
Once the Wavefront Prometheus Storage Adapter is deployed, you will need to configure the prometheus.yml
file in your Prometheus installation adding the following lines (substitute the RELEASE_NAME placeholder):
Troubleshooting¶
Find more information about how to deal with common errors related to Bitnami's Helm charts in this troubleshooting guide.
Upgrading¶
To 2.0.0¶
This major updates the Wavefront subchart to its newest major release, 4.0.0, which contains a new major version for kube-state-metrics. For more information on this subchart's major version, please refer to the Wavefront upgrade notes.
To 1.0.0¶
This major updates the Wavefront subchart to its newest major release, 3.0.0, which contains a new major version for kube-state-metrics. For more information on this subchart's major version, please refer to the Wavefront upgrade notes.
License¶
Copyright © 2023 VMware, Inc.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.