Monitor Type: kubernetes-cluster
(Source)
Accepts Endpoints: No
Multiple Instances Allowed: Yes
If you are using OpenShift there is an openshift-cluster monitor to be used instead of this monitor that contains additional OpenShift metrics.
Collects cluster-level metrics from the Kubernetes API server. It uses the watch functionality of the K8s API to listen for updates about the cluster and maintains a cache of metrics that get sent on a regular interval.
Since the agent is generally running in multiple places in a K8s cluster and
since it is generally more convenient to share the same configuration across
all agent instances, this monitor by default makes use of a leader election
process to ensure that it is the only agent sending metrics in a cluster.
All of the agents running in the same namespace that have this monitor
configured will decide amongst themselves which should send metrics for this
monitor, and the rest will stand by ready to activate if the leader agent
dies. You can override leader election by setting the config option
alwaysClusterReporter
to true, which will make the monitor always report
metrics.
This monitor is similar to kube-state-metrics, and sends many of the same metrics, but in a way that is less verbose and better fitted for the SignalFx backend.
To activate this monitor in the Smart Agent, add the following to your agent config:
monitors: # All monitor config goes under this key
- type: kubernetes-cluster
... # Additional config
For a list of monitor options that are common to all monitors, see Common Configuration.
Config option | Required | Type | Description |
---|---|---|---|
alwaysClusterReporter |
no | bool |
If true , leader election is skipped and metrics are always reported. (default: false ) |
namespace |
no | string |
If specified, only resources within the given namespace will be monitored. If omitted (blank) all supported resources across all namespaces will be monitored. |
useNodeName |
no | bool |
If set to true, the Kubernetes node name will be used as the dimension to which to sync properties about each respective node. This is necessary if your cluster's machines do not have unique machine-id values, as can happen when machine images are improperly cloned. (default: false ) |
kubernetesAPI |
no | object (see below) |
Config for the K8s API client |
nodeConditionTypesToReport |
no | list of strings |
A list of node status condition types to report as metrics. The metrics will be reported as datapoints of the form kubernetes.node_<type_snake_cased> with a value of 0 corresponding to "False", 1 to "True", and -1 to "Unknown". (default: [Ready] ) |
The nested kubernetesAPI
config object has the following fields:
Config option | Required | Type | Description |
---|---|---|---|
authType |
no | string |
How to authenticate to the K8s API server. This can be one of none (for no auth), tls (to use manually specified TLS client certs, not recommended), serviceAccount (to use the standard service account token provided to the agent pod), or kubeConfig to use credentials from ~/.kube/config . (default: serviceAccount ) |
skipVerify |
no | bool |
Whether to skip verifying the TLS cert from the API server. Almost never needed. (default: false ) |
clientCertPath |
no | string |
The path to the TLS client cert on the pod's filesystem, if using tls auth. |
clientKeyPath |
no | string |
The path to the TLS client key on the pod's filesystem, if using tls auth. |
caCertPath |
no | string |
Path to a CA certificate to use when verifying the API server's TLS cert. Generally this is provided by K8s alongside the service account token, which will be picked up automatically, so this should rarely be necessary to specify. |
These are the metrics available for this monitor. Metrics that are categorized as container/host (default) are in bold and italics in the list below.
kubernetes.container_ready
(gauge)
Whether a container has passed its readiness probe (0 for no, 1 for yes)kubernetes.container_restart_count
(gauge)
How many times the container has restarted in the recent past. This value is pulled directly from the K8s API and the value can go indefinitely high and be reset to 0 at any time depending on how your kubelet is configured to prune dead containers. It is best to not depend too much on the exact value but rather look at it as either== 0
, in which case you can conclude there were no restarts in the recent past, or> 0
, in which case you can conclude there were restarts in the recent past, and not try and analyze the value beyond that.kubernetes.daemon_set.current_scheduled
(gauge)
The number of nodes that are running at least 1 daemon pod and are supposed to run the daemon podkubernetes.daemon_set.desired_scheduled
(gauge)
The total number of nodes that should be running the daemon pod (including nodes currently running the daemon pod)kubernetes.daemon_set.misscheduled
(gauge)
The number of nodes that are running the daemon pod, but are not supposed to run the daemon podkubernetes.daemon_set.ready
(gauge)
The number of nodes that should be running the daemon pod and have one or more of the daemon pod running and readykubernetes.deployment.available
(gauge)
Total number of available pods (ready for at least minReadySeconds) targeted by this deployment.kubernetes.deployment.desired
(gauge)
Number of desired pods in this deploymentkubernetes.namespace_phase
(gauge)
The current phase of namespaces (1
for active and0
for terminating)kubernetes.node_ready
(gauge)
Whether this node is ready (1), not ready (0) or in an unknown state (-1)kubernetes.pod_phase
(gauge)
Current phase of the pod (1 - Pending, 2 - Running, 3 - Succeeded, 4 - Failed, 5 - Unknown)kubernetes.replica_set.available
(gauge)
Total number of available pods (ready for at least minReadySeconds) targeted by this replica setkubernetes.replica_set.desired
(gauge)
Number of desired pods in this replica setkubernetes.replication_controller.available
(gauge)
Total number of available pods (ready for at least minReadySeconds) targeted by this replication controller.kubernetes.replication_controller.desired
(gauge)
Number of desired podskubernetes.resource_quota_hard
(gauge)
The upper limit for a particular resource in a specific namespace. Will only be sent if a quota is specified. CPU requests/limits will be sent as millicores.kubernetes.resource_quota_used
(gauge)
The usage for a particular resource in a specific namespace. Will only be sent if a quota is specified. CPU requests/limits will be sent as millicores.
The following information applies to the agent version 4.7.0+ that has
enableBuiltInFiltering: true
set on the top level of the agent config.
To emit metrics that are not default, you can add those metrics in the
generic monitor-level extraMetrics
config option. Metrics that are derived
from specific configuration options that do not appear in the above list of
metrics do not need to be added to extraMetrics
.
To see a list of metrics that will be emitted you can run agent-status monitors
after configuring this monitor in a running agent instance.
The following information only applies to agent version older than 4.7.0. If
you have a newer agent and have set enableBuiltInFiltering: true
at the top
level of your agent config, see the section above. See upgrade instructions in
Old-style whitelist filtering.
If you have a reference to the whitelist.json
in your agent's top-level
metricsToExclude
config option, and you want to emit metrics that are not in
that whitelist, then you need to add an item to the top-level
metricsToInclude
config option to override that whitelist (see Inclusion
filtering. Or you can just
copy the whitelist.json, modify it, and reference that in metricsToExclude
.
The following dimensions may occur on metrics emitted by this monitor. Some dimensions may be specific to certain metrics.
Name | Description |
---|---|
kubernetes_name |
The name of the resource that the metric describes |
kubernetes_namespace |
The namespace of the resource that the metric describes |
kubernetes_node |
The name of the node, as defined by the name field of the node resource. |
kubernetes_pod_uid |
The UID of the pod that the metric describes |
machine_id |
The machine ID from /etc/machine-id. This should be unique across all nodes in your cluster, but some cluster deployment tools don't guarantee this. This will not be sent if the useNodeName config option is set to true. |
metric_source |
This is always set to kubernetes |
quota_name |
The name of the k8s ResourceQuota object that the quota is part of |
resource |
The k8s resource that the quota applies to |
The following properties are set on the dimension values of the dimension specified.
Name | Dimension | Description |
---|---|---|
<node label> |
machine_id/kubernetes_node |
All non-blank labels on a given node will be synced as properties to the machine_id or kubernetes_node dimension value for that node. Which dimension gets the properties is determined by the useNodeName config option. Any blank values will be synced as tags on that same dimension. |
<pod label> |
kubernetes_pod_uid |
Any labels with non-blank values on the pod will be synced as properties to the kubernetes_pod_uid dimension. Any blank labels will be synced as tags on that same dimension. |