windows_exporter/collector/mscluster_cluster.go
Jan-Otto Kröpke 8509bc69a6
switch to go-kit logger
Signed-off-by: Jan-Otto Kröpke <mail@jkroepke.de>
2023-07-09 22:37:27 +02:00

1200 lines
38 KiB
Go

package collector
import (
"github.com/go-kit/log"
"github.com/prometheus/client_golang/prometheus"
"github.com/yusufpapurcu/wmi"
)
// A MSCluster_ClusterCollector is a Prometheus collector for WMI MSCluster_Cluster metrics
type MSCluster_ClusterCollector struct {
logger log.Logger
AddEvictDelay *prometheus.Desc
AdminAccessPoint *prometheus.Desc
AutoAssignNodeSite *prometheus.Desc
AutoBalancerLevel *prometheus.Desc
AutoBalancerMode *prometheus.Desc
BackupInProgress *prometheus.Desc
BlockCacheSize *prometheus.Desc
ClusSvcHangTimeout *prometheus.Desc
ClusSvcRegroupOpeningTimeout *prometheus.Desc
ClusSvcRegroupPruningTimeout *prometheus.Desc
ClusSvcRegroupStageTimeout *prometheus.Desc
ClusSvcRegroupTickInMilliseconds *prometheus.Desc
ClusterEnforcedAntiAffinity *prometheus.Desc
ClusterFunctionalLevel *prometheus.Desc
ClusterGroupWaitDelay *prometheus.Desc
ClusterLogLevel *prometheus.Desc
ClusterLogSize *prometheus.Desc
ClusterUpgradeVersion *prometheus.Desc
CrossSiteDelay *prometheus.Desc
CrossSiteThreshold *prometheus.Desc
CrossSubnetDelay *prometheus.Desc
CrossSubnetThreshold *prometheus.Desc
CsvBalancer *prometheus.Desc
DatabaseReadWriteMode *prometheus.Desc
DefaultNetworkRole *prometheus.Desc
DetectedCloudPlatform *prometheus.Desc
DetectManagedEvents *prometheus.Desc
DetectManagedEventsThreshold *prometheus.Desc
DisableGroupPreferredOwnerRandomization *prometheus.Desc
DrainOnShutdown *prometheus.Desc
DynamicQuorumEnabled *prometheus.Desc
EnableSharedVolumes *prometheus.Desc
FixQuorum *prometheus.Desc
GracePeriodEnabled *prometheus.Desc
GracePeriodTimeout *prometheus.Desc
GroupDependencyTimeout *prometheus.Desc
HangRecoveryAction *prometheus.Desc
IgnorePersistentStateOnStartup *prometheus.Desc
LogResourceControls *prometheus.Desc
LowerQuorumPriorityNodeId *prometheus.Desc
MaxNumberOfNodes *prometheus.Desc
MessageBufferLength *prometheus.Desc
MinimumNeverPreemptPriority *prometheus.Desc
MinimumPreemptorPriority *prometheus.Desc
NetftIPSecEnabled *prometheus.Desc
PlacementOptions *prometheus.Desc
PlumbAllCrossSubnetRoutes *prometheus.Desc
PreventQuorum *prometheus.Desc
QuarantineDuration *prometheus.Desc
QuarantineThreshold *prometheus.Desc
QuorumArbitrationTimeMax *prometheus.Desc
QuorumArbitrationTimeMin *prometheus.Desc
QuorumLogFileSize *prometheus.Desc
QuorumTypeValue *prometheus.Desc
RequestReplyTimeout *prometheus.Desc
ResiliencyDefaultPeriod *prometheus.Desc
ResiliencyLevel *prometheus.Desc
ResourceDllDeadlockPeriod *prometheus.Desc
RootMemoryReserved *prometheus.Desc
RouteHistoryLength *prometheus.Desc
S2DBusTypes *prometheus.Desc
S2DCacheDesiredState *prometheus.Desc
S2DCacheFlashReservePercent *prometheus.Desc
S2DCachePageSizeKBytes *prometheus.Desc
S2DEnabled *prometheus.Desc
S2DIOLatencyThreshold *prometheus.Desc
S2DOptimizations *prometheus.Desc
SameSubnetDelay *prometheus.Desc
SameSubnetThreshold *prometheus.Desc
SecurityLevel *prometheus.Desc
SecurityLevelForStorage *prometheus.Desc
SharedVolumeVssWriterOperationTimeout *prometheus.Desc
ShutdownTimeoutInMinutes *prometheus.Desc
UseClientAccessNetworksForSharedVolumes *prometheus.Desc
WitnessDatabaseWriteTimeout *prometheus.Desc
WitnessDynamicWeight *prometheus.Desc
WitnessRestartInterval *prometheus.Desc
}
func newMSCluster_ClusterCollector(logger log.Logger) (Collector, error) {
const subsystem = "mscluster_cluster"
return &MSCluster_ClusterCollector{
logger: log.With(logger, "collector", subsystem),
AddEvictDelay: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "add_evict_delay"),
"Provides access to the cluster's AddEvictDelay property, which is the number a seconds that a new node is delayed after an eviction of another node.",
[]string{"name"},
nil,
),
AdminAccessPoint: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "admin_access_point"),
"The type of the cluster administrative access point.",
[]string{"name"},
nil,
),
AutoAssignNodeSite: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "auto_assign_node_site"),
"Determines whether or not the cluster will attempt to automatically assign nodes to sites based on networks and Active Directory Site information.",
[]string{"name"},
nil,
),
AutoBalancerLevel: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "auto_balancer_level"),
"Determines the level of aggressiveness of AutoBalancer.",
[]string{"name"},
nil,
),
AutoBalancerMode: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "auto_balancer_mode"),
"Determines whether or not the auto balancer is enabled.",
[]string{"name"},
nil,
),
BackupInProgress: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "backup_in_progress"),
"Indicates whether a backup is in progress.",
[]string{"name"},
nil,
),
BlockCacheSize: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "block_cache_size"),
"CSV BlockCache Size in MB.",
[]string{"name"},
nil,
),
ClusSvcHangTimeout: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "clus_svc_hang_timeout"),
"Controls how long the cluster network driver waits between Failover Cluster Service heartbeats before it determines that the Failover Cluster Service has stopped responding.",
[]string{"name"},
nil,
),
ClusSvcRegroupOpeningTimeout: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "clus_svc_regroup_opening_timeout"),
"Controls how long a node will wait on other nodes in the opening stage before deciding that they failed.",
[]string{"name"},
nil,
),
ClusSvcRegroupPruningTimeout: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "clus_svc_regroup_pruning_timeout"),
"Controls how long the membership leader will wait to reach full connectivity between cluster nodes.",
[]string{"name"},
nil,
),
ClusSvcRegroupStageTimeout: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "clus_svc_regroup_stage_timeout"),
"Controls how long a node will wait on other nodes in a membership stage before deciding that they failed.",
[]string{"name"},
nil,
),
ClusSvcRegroupTickInMilliseconds: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "clus_svc_regroup_tick_in_milliseconds"),
"Controls how frequently the membership algorithm is sending periodic membership messages.",
[]string{"name"},
nil,
),
ClusterEnforcedAntiAffinity: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "cluster_enforced_anti_affinity"),
"Enables or disables hard enforcement of group anti-affinity classes.",
[]string{"name"},
nil,
),
ClusterFunctionalLevel: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "cluster_functional_level"),
"The functional level the cluster is currently running in.",
[]string{"name"},
nil,
),
ClusterGroupWaitDelay: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "cluster_group_wait_delay"),
"Maximum time in seconds that a group waits for its preferred node to come online during cluster startup before coming online on a different node.",
[]string{"name"},
nil,
),
ClusterLogLevel: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "cluster_log_level"),
"Controls the level of cluster logging.",
[]string{"name"},
nil,
),
ClusterLogSize: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "cluster_log_size"),
"Controls the maximum size of the cluster log files on each of the nodes.",
[]string{"name"},
nil,
),
ClusterUpgradeVersion: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "cluster_upgrade_version"),
"Specifies the upgrade version the cluster is currently running in.",
[]string{"name"},
nil,
),
CrossSiteDelay: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "cross_site_delay"),
"Controls how long the cluster network driver waits in milliseconds between sending Cluster Service heartbeats across sites.",
[]string{"name"},
nil,
),
CrossSiteThreshold: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "cross_site_threshold"),
"Controls how many Cluster Service heartbeats can be missed across sites before it determines that Cluster Service has stopped responding.",
[]string{"name"},
nil,
),
CrossSubnetDelay: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "cross_subnet_delay"),
"Controls how long the cluster network driver waits in milliseconds between sending Cluster Service heartbeats across subnets.",
[]string{"name"},
nil,
),
CrossSubnetThreshold: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "cross_subnet_threshold"),
"Controls how many Cluster Service heartbeats can be missed across subnets before it determines that Cluster Service has stopped responding.",
[]string{"name"},
nil,
),
CsvBalancer: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "csv_balancer"),
"Whether automatic balancing for CSV is enabled.",
[]string{"name"},
nil,
),
DatabaseReadWriteMode: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "database_read_write_mode"),
"Sets the database read and write mode.",
[]string{"name"},
nil,
),
DefaultNetworkRole: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "default_network_role"),
"Provides access to the cluster's DefaultNetworkRole property.",
[]string{"name"},
nil,
),
DetectedCloudPlatform: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "detected_cloud_platform"),
"(DetectedCloudPlatform)",
[]string{"name"},
nil,
),
DetectManagedEvents: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "detect_managed_events"),
"(DetectManagedEvents)",
[]string{"name"},
nil,
),
DetectManagedEventsThreshold: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "detect_managed_events_threshold"),
"(DetectManagedEventsThreshold)",
[]string{"name"},
nil,
),
DisableGroupPreferredOwnerRandomization: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "disable_group_preferred_owner_randomization"),
"(DisableGroupPreferredOwnerRandomization)",
[]string{"name"},
nil,
),
DrainOnShutdown: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "drain_on_shutdown"),
"Whether to drain the node when cluster service is being stopped.",
[]string{"name"},
nil,
),
DynamicQuorumEnabled: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "dynamic_quorum_enabled"),
"Allows cluster service to adjust node weights as needed to increase availability.",
[]string{"name"},
nil,
),
EnableSharedVolumes: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "enable_shared_volumes"),
"Enables or disables cluster shared volumes on this cluster.",
[]string{"name"},
nil,
),
FixQuorum: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "fix_quorum"),
"Provides access to the cluster's FixQuorum property, which specifies if the cluster is in a fix quorum state.",
[]string{"name"},
nil,
),
GracePeriodEnabled: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "grace_period_enabled"),
"Whether the node grace period feature of this cluster is enabled.",
[]string{"name"},
nil,
),
GracePeriodTimeout: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "grace_period_timeout"),
"The grace period timeout in milliseconds.",
[]string{"name"},
nil,
),
GroupDependencyTimeout: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "group_dependency_timeout"),
"The timeout after which a group will be brought online despite unsatisfied dependencies",
[]string{"name"},
nil,
),
HangRecoveryAction: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "hang_recovery_action"),
"Controls the action to take if the user-mode processes have stopped responding.",
[]string{"name"},
nil,
),
IgnorePersistentStateOnStartup: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "ignore_persistent_state_on_startup"),
"Provides access to the cluster's IgnorePersistentStateOnStartup property, which specifies whether the cluster will bring online groups that were online when the cluster was shut down.",
[]string{"name"},
nil,
),
LogResourceControls: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "log_resource_controls"),
"Controls the logging of resource controls.",
[]string{"name"},
nil,
),
LowerQuorumPriorityNodeId: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "lower_quorum_priority_node_id"),
"Specifies the Node ID that has a lower priority when voting for quorum is performed. If the quorum vote is split 50/50%, the specified node's vote would be ignored to break the tie. If this is not set then the cluster will pick a node at random to break the tie.",
[]string{"name"},
nil,
),
MaxNumberOfNodes: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "max_number_of_nodes"),
"Indicates the maximum number of nodes that may participate in the Cluster.",
[]string{"name"},
nil,
),
MessageBufferLength: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "message_buffer_length"),
"The maximum unacknowledged message count for GEM.",
[]string{"name"},
nil,
),
MinimumNeverPreemptPriority: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "minimum_never_preempt_priority"),
"Groups with this priority or higher cannot be preempted.",
[]string{"name"},
nil,
),
MinimumPreemptorPriority: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "minimum_preemptor_priority"),
"Minimum priority a cluster group must have to be able to preempt another group.",
[]string{"name"},
nil,
),
NetftIPSecEnabled: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "netft_ip_sec_enabled"),
"Whether IPSec is enabled for cluster internal traffic.",
[]string{"name"},
nil,
),
PlacementOptions: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "placement_options"),
"Various option flags to modify default placement behavior.",
[]string{"name"},
nil,
),
PlumbAllCrossSubnetRoutes: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "plumb_all_cross_subnet_routes"),
"Plumbs all possible cross subnet routes to all nodes.",
[]string{"name"},
nil,
),
PreventQuorum: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "prevent_quorum"),
"Whether the cluster will ignore group persistent state on startup.",
[]string{"name"},
nil,
),
QuarantineDuration: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "quarantine_duration"),
"The quarantine period timeout in milliseconds.",
[]string{"name"},
nil,
),
QuarantineThreshold: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "quarantine_threshold"),
"Number of node failures before it will be quarantined.",
[]string{"name"},
nil,
),
QuorumArbitrationTimeMax: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "quorum_arbitration_time_max"),
"Controls the maximum time necessary to decide the Quorum owner node.",
[]string{"name"},
nil,
),
QuorumArbitrationTimeMin: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "quorum_arbitration_time_min"),
"Controls the minimum time necessary to decide the Quorum owner node.",
[]string{"name"},
nil,
),
QuorumLogFileSize: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "quorum_log_file_size"),
"This property is obsolete.",
[]string{"name"},
nil,
),
QuorumTypeValue: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "quorum_type_value"),
"Get the current quorum type value. -1: Unknown; 1: Node; 2: FileShareWitness; 3: Storage; 4: None",
[]string{"name"},
nil,
),
RequestReplyTimeout: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "request_reply_timeout"),
"Controls the request reply time-out period.",
[]string{"name"},
nil,
),
ResiliencyDefaultPeriod: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "resiliency_default_period"),
"The default resiliency period, in seconds, for the cluster.",
[]string{"name"},
nil,
),
ResiliencyLevel: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "resiliency_level"),
"The resiliency level for the cluster.",
[]string{"name"},
nil,
),
ResourceDllDeadlockPeriod: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "resource_dll_deadlock_period"),
"This property is obsolete.",
[]string{"name"},
nil,
),
RootMemoryReserved: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "root_memory_reserved"),
"Controls the amount of memory reserved for the parent partition on all cluster nodes.",
[]string{"name"},
nil,
),
RouteHistoryLength: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "route_history_length"),
"The history length for routes to help finding network issues.",
[]string{"name"},
nil,
),
S2DBusTypes: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "s2d_bus_types"),
"Bus types for storage spaces direct.",
[]string{"name"},
nil,
),
S2DCacheDesiredState: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "s2d_cache_desired_state"),
"Desired state of the storage spaces direct cache.",
[]string{"name"},
nil,
),
S2DCacheFlashReservePercent: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "s2d_cache_flash_reserve_percent"),
"Percentage of allocated flash space to utilize when caching.",
[]string{"name"},
nil,
),
S2DCachePageSizeKBytes: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "s2d_cache_page_size_k_bytes"),
"Page size in KB used by S2D cache.",
[]string{"name"},
nil,
),
S2DEnabled: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "s2d_enabled"),
"Whether direct attached storage (DAS) is enabled.",
[]string{"name"},
nil,
),
S2DIOLatencyThreshold: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "s2dio_latency_threshold"),
"The I/O latency threshold for storage spaces direct.",
[]string{"name"},
nil,
),
S2DOptimizations: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "s2d_optimizations"),
"Optimization flags for storage spaces direct.",
[]string{"name"},
nil,
),
SameSubnetDelay: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "same_subnet_delay"),
"Controls how long the cluster network driver waits in milliseconds between sending Cluster Service heartbeats on the same subnet.",
[]string{"name"},
nil,
),
SameSubnetThreshold: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "same_subnet_threshold"),
"Controls how many Cluster Service heartbeats can be missed on the same subnet before it determines that Cluster Service has stopped responding.",
[]string{"name"},
nil,
),
SecurityLevel: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "security_level"),
"Controls the level of security that should apply to intracluster messages. 0: Clear Text; 1: Sign; 2: Encrypt ",
[]string{"name"},
nil,
),
SecurityLevelForStorage: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "security_level_for_storage"),
"(SecurityLevelForStorage)",
[]string{"name"},
nil,
),
SharedVolumeVssWriterOperationTimeout: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "shared_volume_vss_writer_operation_timeout"),
"CSV VSS Writer operation timeout in seconds.",
[]string{"name"},
nil,
),
ShutdownTimeoutInMinutes: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "shutdown_timeout_in_minutes"),
"The maximum time in minutes allowed for cluster resources to come offline during cluster service shutdown.",
[]string{"name"},
nil,
),
UseClientAccessNetworksForSharedVolumes: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "use_client_access_networks_for_shared_volumes"),
"Whether the use of client access networks for cluster shared volumes feature of this cluster is enabled. 0: Disabled; 1: Enabled; 2: Auto",
[]string{"name"},
nil,
),
WitnessDatabaseWriteTimeout: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "witness_database_write_timeout"),
"Controls the maximum time in seconds that a cluster database write to a witness can take before the write is abandoned.",
[]string{"name"},
nil,
),
WitnessDynamicWeight: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "witness_dynamic_weight"),
"The weight of the configured witness.",
[]string{"name"},
nil,
),
WitnessRestartInterval: prometheus.NewDesc(
prometheus.BuildFQName(Namespace, subsystem, "witness_restart_interval"),
"Controls the witness restart interval.",
[]string{"name"},
nil,
),
}, nil
}
// MSCluster_Cluster docs:
// - https://docs.microsoft.com/en-us/previous-versions/windows/desktop/cluswmi/mscluster-cluster
type MSCluster_Cluster struct {
Name string
AddEvictDelay uint
AdminAccessPoint uint
AutoAssignNodeSite uint
AutoBalancerLevel uint
AutoBalancerMode uint
BackupInProgress uint
BlockCacheSize uint
ClusSvcHangTimeout uint
ClusSvcRegroupOpeningTimeout uint
ClusSvcRegroupPruningTimeout uint
ClusSvcRegroupStageTimeout uint
ClusSvcRegroupTickInMilliseconds uint
ClusterEnforcedAntiAffinity uint
ClusterFunctionalLevel uint
ClusterGroupWaitDelay uint
ClusterLogLevel uint
ClusterLogSize uint
ClusterUpgradeVersion uint
CrossSiteDelay uint
CrossSiteThreshold uint
CrossSubnetDelay uint
CrossSubnetThreshold uint
CsvBalancer uint
DatabaseReadWriteMode uint
DefaultNetworkRole uint
DetectedCloudPlatform uint
DetectManagedEvents uint
DetectManagedEventsThreshold uint
DisableGroupPreferredOwnerRandomization uint
DrainOnShutdown uint
DynamicQuorumEnabled uint
EnableSharedVolumes uint
FixQuorum uint
GracePeriodEnabled uint
GracePeriodTimeout uint
GroupDependencyTimeout uint
HangRecoveryAction uint
IgnorePersistentStateOnStartup uint
LogResourceControls uint
LowerQuorumPriorityNodeId uint
MaxNumberOfNodes uint
MessageBufferLength uint
MinimumNeverPreemptPriority uint
MinimumPreemptorPriority uint
NetftIPSecEnabled uint
PlacementOptions uint
PlumbAllCrossSubnetRoutes uint
PreventQuorum uint
QuarantineDuration uint
QuarantineThreshold uint
QuorumArbitrationTimeMax uint
QuorumArbitrationTimeMin uint
QuorumLogFileSize uint
QuorumTypeValue uint
RequestReplyTimeout uint
ResiliencyDefaultPeriod uint
ResiliencyLevel uint
ResourceDllDeadlockPeriod uint
RootMemoryReserved uint
RouteHistoryLength uint
S2DBusTypes uint
S2DCacheDesiredState uint
S2DCacheFlashReservePercent uint
S2DCachePageSizeKBytes uint
S2DEnabled uint
S2DIOLatencyThreshold uint
S2DOptimizations uint
SameSubnetDelay uint
SameSubnetThreshold uint
SecurityLevel uint
SecurityLevelForStorage uint
SharedVolumeVssWriterOperationTimeout uint
ShutdownTimeoutInMinutes uint
UseClientAccessNetworksForSharedVolumes uint
WitnessDatabaseWriteTimeout uint
WitnessDynamicWeight uint
WitnessRestartInterval uint
}
// Collect sends the metric values for each metric
// to the provided prometheus Metric channel.
func (c *MSCluster_ClusterCollector) Collect(ctx *ScrapeContext, ch chan<- prometheus.Metric) error {
var dst []MSCluster_Cluster
q := queryAll(&dst, c.logger)
if err := wmi.QueryNamespace(q, &dst, "root/MSCluster"); err != nil {
return err
}
for _, v := range dst {
ch <- prometheus.MustNewConstMetric(
c.AddEvictDelay,
prometheus.GaugeValue,
float64(v.AddEvictDelay),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.AdminAccessPoint,
prometheus.GaugeValue,
float64(v.AdminAccessPoint),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.AutoAssignNodeSite,
prometheus.GaugeValue,
float64(v.AutoAssignNodeSite),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.AutoBalancerLevel,
prometheus.GaugeValue,
float64(v.AutoBalancerLevel),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.AutoBalancerMode,
prometheus.GaugeValue,
float64(v.AutoBalancerMode),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.BackupInProgress,
prometheus.GaugeValue,
float64(v.BackupInProgress),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.BlockCacheSize,
prometheus.GaugeValue,
float64(v.BlockCacheSize),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ClusSvcHangTimeout,
prometheus.GaugeValue,
float64(v.ClusSvcHangTimeout),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ClusSvcRegroupOpeningTimeout,
prometheus.GaugeValue,
float64(v.ClusSvcRegroupOpeningTimeout),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ClusSvcRegroupPruningTimeout,
prometheus.GaugeValue,
float64(v.ClusSvcRegroupPruningTimeout),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ClusSvcRegroupStageTimeout,
prometheus.GaugeValue,
float64(v.ClusSvcRegroupStageTimeout),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ClusSvcRegroupTickInMilliseconds,
prometheus.GaugeValue,
float64(v.ClusSvcRegroupTickInMilliseconds),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ClusterEnforcedAntiAffinity,
prometheus.GaugeValue,
float64(v.ClusterEnforcedAntiAffinity),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ClusterFunctionalLevel,
prometheus.GaugeValue,
float64(v.ClusterFunctionalLevel),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ClusterGroupWaitDelay,
prometheus.GaugeValue,
float64(v.ClusterGroupWaitDelay),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ClusterLogLevel,
prometheus.GaugeValue,
float64(v.ClusterLogLevel),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ClusterLogSize,
prometheus.GaugeValue,
float64(v.ClusterLogSize),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ClusterUpgradeVersion,
prometheus.GaugeValue,
float64(v.ClusterUpgradeVersion),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.CrossSiteDelay,
prometheus.GaugeValue,
float64(v.CrossSiteDelay),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.CrossSiteThreshold,
prometheus.GaugeValue,
float64(v.CrossSiteThreshold),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.CrossSubnetDelay,
prometheus.GaugeValue,
float64(v.CrossSubnetDelay),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.CrossSubnetThreshold,
prometheus.GaugeValue,
float64(v.CrossSubnetThreshold),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.CsvBalancer,
prometheus.GaugeValue,
float64(v.CsvBalancer),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.DatabaseReadWriteMode,
prometheus.GaugeValue,
float64(v.DatabaseReadWriteMode),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.DefaultNetworkRole,
prometheus.GaugeValue,
float64(v.DefaultNetworkRole),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.DetectedCloudPlatform,
prometheus.GaugeValue,
float64(v.DetectedCloudPlatform),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.DetectManagedEvents,
prometheus.GaugeValue,
float64(v.DetectManagedEvents),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.DetectManagedEventsThreshold,
prometheus.GaugeValue,
float64(v.DetectManagedEventsThreshold),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.DisableGroupPreferredOwnerRandomization,
prometheus.GaugeValue,
float64(v.DisableGroupPreferredOwnerRandomization),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.DrainOnShutdown,
prometheus.GaugeValue,
float64(v.DrainOnShutdown),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.DynamicQuorumEnabled,
prometheus.GaugeValue,
float64(v.DynamicQuorumEnabled),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.EnableSharedVolumes,
prometheus.GaugeValue,
float64(v.EnableSharedVolumes),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.FixQuorum,
prometheus.GaugeValue,
float64(v.FixQuorum),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.GracePeriodEnabled,
prometheus.GaugeValue,
float64(v.GracePeriodEnabled),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.GracePeriodTimeout,
prometheus.GaugeValue,
float64(v.GracePeriodTimeout),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.GroupDependencyTimeout,
prometheus.GaugeValue,
float64(v.GroupDependencyTimeout),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.HangRecoveryAction,
prometheus.GaugeValue,
float64(v.HangRecoveryAction),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.IgnorePersistentStateOnStartup,
prometheus.GaugeValue,
float64(v.IgnorePersistentStateOnStartup),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.LogResourceControls,
prometheus.GaugeValue,
float64(v.LogResourceControls),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.LowerQuorumPriorityNodeId,
prometheus.GaugeValue,
float64(v.LowerQuorumPriorityNodeId),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.MaxNumberOfNodes,
prometheus.GaugeValue,
float64(v.MaxNumberOfNodes),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.MessageBufferLength,
prometheus.GaugeValue,
float64(v.MessageBufferLength),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.MinimumNeverPreemptPriority,
prometheus.GaugeValue,
float64(v.MinimumNeverPreemptPriority),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.MinimumPreemptorPriority,
prometheus.GaugeValue,
float64(v.MinimumPreemptorPriority),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.NetftIPSecEnabled,
prometheus.GaugeValue,
float64(v.NetftIPSecEnabled),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.PlacementOptions,
prometheus.GaugeValue,
float64(v.PlacementOptions),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.PlumbAllCrossSubnetRoutes,
prometheus.GaugeValue,
float64(v.PlumbAllCrossSubnetRoutes),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.PreventQuorum,
prometheus.GaugeValue,
float64(v.PreventQuorum),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.QuarantineDuration,
prometheus.GaugeValue,
float64(v.QuarantineDuration),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.QuarantineThreshold,
prometheus.GaugeValue,
float64(v.QuarantineThreshold),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.QuorumArbitrationTimeMax,
prometheus.GaugeValue,
float64(v.QuorumArbitrationTimeMax),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.QuorumArbitrationTimeMin,
prometheus.GaugeValue,
float64(v.QuorumArbitrationTimeMin),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.QuorumLogFileSize,
prometheus.GaugeValue,
float64(v.QuorumLogFileSize),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.QuorumTypeValue,
prometheus.GaugeValue,
float64(v.QuorumTypeValue),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.RequestReplyTimeout,
prometheus.GaugeValue,
float64(v.RequestReplyTimeout),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ResiliencyDefaultPeriod,
prometheus.GaugeValue,
float64(v.ResiliencyDefaultPeriod),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ResiliencyLevel,
prometheus.GaugeValue,
float64(v.ResiliencyLevel),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ResourceDllDeadlockPeriod,
prometheus.GaugeValue,
float64(v.ResourceDllDeadlockPeriod),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.RootMemoryReserved,
prometheus.GaugeValue,
float64(v.RootMemoryReserved),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.RouteHistoryLength,
prometheus.GaugeValue,
float64(v.RouteHistoryLength),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.S2DBusTypes,
prometheus.GaugeValue,
float64(v.S2DBusTypes),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.S2DCacheDesiredState,
prometheus.GaugeValue,
float64(v.S2DCacheDesiredState),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.S2DCacheFlashReservePercent,
prometheus.GaugeValue,
float64(v.S2DCacheFlashReservePercent),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.S2DCachePageSizeKBytes,
prometheus.GaugeValue,
float64(v.S2DCachePageSizeKBytes),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.S2DEnabled,
prometheus.GaugeValue,
float64(v.S2DEnabled),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.S2DIOLatencyThreshold,
prometheus.GaugeValue,
float64(v.S2DIOLatencyThreshold),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.S2DOptimizations,
prometheus.GaugeValue,
float64(v.S2DOptimizations),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.SameSubnetDelay,
prometheus.GaugeValue,
float64(v.SameSubnetDelay),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.SameSubnetThreshold,
prometheus.GaugeValue,
float64(v.SameSubnetThreshold),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.SecurityLevel,
prometheus.GaugeValue,
float64(v.SecurityLevel),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.SecurityLevelForStorage,
prometheus.GaugeValue,
float64(v.SecurityLevelForStorage),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.SharedVolumeVssWriterOperationTimeout,
prometheus.GaugeValue,
float64(v.SharedVolumeVssWriterOperationTimeout),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.ShutdownTimeoutInMinutes,
prometheus.GaugeValue,
float64(v.ShutdownTimeoutInMinutes),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.UseClientAccessNetworksForSharedVolumes,
prometheus.GaugeValue,
float64(v.UseClientAccessNetworksForSharedVolumes),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.WitnessDatabaseWriteTimeout,
prometheus.GaugeValue,
float64(v.WitnessDatabaseWriteTimeout),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.WitnessDynamicWeight,
prometheus.GaugeValue,
float64(v.WitnessDynamicWeight),
v.Name,
)
ch <- prometheus.MustNewConstMetric(
c.WitnessRestartInterval,
prometheus.GaugeValue,
float64(v.WitnessRestartInterval),
v.Name,
)
}
return nil
}