7642cf7a5f
``` Updated: argo/argo-cd: - 5.26.1 bitnami/kafka: - 21.4.0 bitnami/postgresql: - 12.2.3 bitnami/redis: - 17.8.5 bitnami/tomcat: - 10.5.19 bitnami/wordpress: - 15.2.54 datadog/datadog: - 3.19.2 gopaddle/gopaddle: - 4.2.6 haproxy/haproxy: - 1.29.2 intel/tcs-issuer: - 0.5.0 jaeger/jaeger-operator: - 2.41.0 jenkins/jenkins: - 4.3.8 jfrog/artifactory-ha: - 107.55.7 jfrog/artifactory-jcr: - 107.55.7 kubecost/cost-analyzer: - 1.101.2 percona/psmdb-db: - 1.14.0 percona/psmdb-operator: - 1.14.0 redpanda/redpanda: - 3.0.3 sysdig/sysdig: - 1.15.79 ``` |
||
---|---|---|
.. | ||
charts | ||
grafana-templates | ||
scripts | ||
templates | ||
Chart.yaml | ||
README.md | ||
app-readme.md | ||
attached-disks.json | ||
cluster-metrics.json | ||
cluster-utilization.json | ||
custom-pricing.csv | ||
deployment-utilization.json | ||
kubernetes-resource-efficiency.json | ||
label-cost-utilization.json | ||
namespace-utilization.json | ||
networkCosts-metrics.json | ||
node-utilization.json | ||
pod-utilization-multi-cluster.json | ||
pod-utilization.json | ||
prom-benchmark.json | ||
questions.yaml | ||
values-agent.yaml | ||
values-amp.yaml | ||
values-cloud-agent.yaml | ||
values-custom-pricing.yaml | ||
values-eks-cost-monitoring.yaml | ||
values-thanos.yaml | ||
values-windows-node-affinity.yaml | ||
values.yaml |
README.md
Kubecost helm chart
Helm chart for the Kubecost project, which is created to monitor and manage Kubernetes resource spend. Please contact team@kubecost.com or visit kubecost.com for more info.
While Helm is the recommended install path, these resources can also be deployed with the following command:
kubectl apply -f https://raw.githubusercontent.com/kubecost/cost-analyzer-helm-chart/master/kubecost.yaml --namespace kubecost
The following table lists the commonly used configurable parameters of the Kubecost Helm chart and their default values.
Parameter | Description | Default |
---|---|---|
global.prometheus.enabled |
If false, use an existing Prometheus install. More info. | true |
prometheus.kube-state-metrics.disabled |
If false, deploy kube-state-metrics for Kubernetes metrics | false |
prometheus.kube-state-metrics.resources |
Set kube-state-metrics resource requests and limits. | {} |
prometheus.server.persistentVolume.enabled |
If true, Prometheus server will create a Persistent Volume Claim. | true |
prometheus.server.persistentVolume.size |
Prometheus server data Persistent Volume size. Default set to retain ~6000 samples per second for 15 days. | 32Gi |
prometheus.server.retention |
Determines when to remove old data. | 15d |
prometheus.server.resources |
Prometheus server resource requests and limits. | {} |
prometheus.nodeExporter.resources |
Node exporter resource requests and limits. | {} |
prometheus.nodeExporter.enabled prometheus.serviceAccounts.nodeExporter.create |
If false, do not crate NodeExporter daemonset. | true |
prometheus.alertmanager.persistentVolume.enabled |
If true, Alertmanager will create a Persistent Volume Claim. | true |
prometheus.pushgateway.persistentVolume.enabled |
If true, Prometheus Pushgateway will create a Persistent Volume Claim. | true |
persistentVolume.enabled |
If true, Kubecost will create a Persistent Volume Claim for product config data. | true |
persistentVolume.size |
Define PVC size for cost-analyzer | 32.0Gi |
persistentVolume.dbSize |
Define PVC size for cost-analyzer's flat file database | 32.0Gi |
ingress.enabled |
If true, Ingress will be created | false |
ingress.annotations |
Ingress annotations | {} |
ingress.paths |
Ingress paths | ["/"] |
ingress.hosts |
Ingress hostnames | [cost-analyzer.local] |
ingress.tls |
Ingress TLS configuration (YAML) | [] |
networkPolicy.enabled |
If true, create a NetworkPolicy to deny egress | false |
networkPolicy.costAnalyzer.enabled |
If true, create a newtork policy for cost-analzyer | false |
networkPolicy.costAnalyzer.annotations |
Annotations to be added to the network policy | {} |
networkPolicy.costAnalyzer.additionalLabels |
Additional labels to be added to the network policy | {} |
networkPolicy.costAnalyzer.ingressRules |
A list of network policy ingress rules | null |
networkPolicy.costAnalyzer.egressRules |
A list of network policy egress rules | null |
networkCosts.enabled |
If true, collect network allocation metrics More info | false |
networkCosts.podMonitor.enabled |
If true, a PodMonitor for the network-cost daemonset is created | false |
serviceMonitor.enabled |
Set this to true to create ServiceMonitor for Prometheus operator |
false |
serviceMonitor.additionalLabels |
Additional labels that can be used so ServiceMonitor will be discovered by Prometheus | {} |
prometheusRule.enabled |
Set this to true to create PrometheusRule for Prometheus operator |
false |
prometheusRule.additionalLabels |
Additional labels that can be used so PrometheusRule will be discovered by Prometheus | {} |
grafana.resources |
Grafana resource requests and limits. | {} |
grafana.sidecar.datasources.defaultDatasourceEnabled |
Set this to false to disable creation of Prometheus datasource in Grafana |
true |
serviceAccount.create |
Set this to false if you want to create the service account kubecost-cost-analyzer on your own |
true |
tolerations |
node taints to tolerate | [] |
affinity |
pod affinity | {} |
kubecostProductConfigs.productKey.mountPath |
Use instead of kubecostProductConfigs.productKey.secretname to declare the path at which the product key file is mounted (eg. by a secrets provisioner) |
N/A |
kubecostFrontend.api.fqdn |
Customize the upstream api FQDN | computed in terms of the service name and namespace |
kubecostFrontend.model.fqdn |
Customize the upstream model FQDN | computed in terms of the service name and namespace |
clusterController.fqdn |
Customize the upstream cluster controller FQDN | computed in terms of the service name and namespace |
global.grafana.fqdn |
Customize the upstream grafana FQDN | computed in terms of the release name and namespace |
Testing
To perform local testing do next:
- install locally kind according to documentation.
- install locally ct according to documentation.
- create local cluster using
kind
use image version from kind docker registry
kind create cluster --image kindest/node:<set-image-tag>
- perform ct execution
ct install --chart-dirs="." --charts="." --helm-repo-extra-args="--set=global.prometheus.enabled=false --set=global.grafana.enabled=false"