Consul is a distributed, highly available, and data center aware solution to connect and configure applications across dynamic, distributed infrastructure.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

61 lines
1.3 KiB

// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: MPL-2.0
package structs
import (
"github.com/hashicorp/consul/acl"
"github.com/hashicorp/consul/api"
"github.com/hashicorp/consul/types"
)
// These are used to manage the built-in "serfHealth" check that's attached
// to every node in the catalog.
const (
SerfCheckID types.CheckID = "serfHealth"
SerfCheckName = "Serf Health Status"
SerfCheckAliveOutput = "Agent alive and reachable"
SerfCheckFailedOutput = "Agent not live or unreachable"
)
const (
// These are used to manage the "consul" service that's attached to every
// Consul server node in the catalog.
ConsulServiceID = "consul"
ConsulServiceName = "consul"
)
type CatalogContents struct {
Nodes []*Node
Services []*ServiceNode
Checks []*HealthCheck
}
type CatalogSummary struct {
Nodes []HealthSummary
Services []HealthSummary
Checks []HealthSummary
}
type HealthSummary struct {
Name string `json:",omitempty"`
Total int
Passing int
Warning int
Critical int
acl.EnterpriseMeta
}
func (h *HealthSummary) Add(status string) {
h.Total++
switch status {
case api.HealthPassing:
h.Passing++
case api.HealthWarning:
h.Warning++
case api.HealthCritical:
h.Critical++
}
}