fix hpa target report

mine
derailed 2019-03-08 16:38:53 -07:00
parent d570c70e67
commit 0b0a723c68
2 changed files with 77 additions and 18 deletions

View File

@ -15,14 +15,14 @@ func NewHPA() Res {
// Get a service. // Get a service.
func (*HPA) Get(ns, n string) (interface{}, error) { func (*HPA) Get(ns, n string) (interface{}, error) {
opts := metav1.GetOptions{} opts := metav1.GetOptions{}
return conn.dialOrDie().Autoscaling().HorizontalPodAutoscalers(ns).Get(n, opts) return conn.dialOrDie().AutoscalingV2beta2().HorizontalPodAutoscalers(ns).Get(n, opts)
} }
// List all services in a given namespace // List all services in a given namespace
func (*HPA) List(ns string) (Collection, error) { func (*HPA) List(ns string) (Collection, error) {
opts := metav1.ListOptions{} opts := metav1.ListOptions{}
rr, err := conn.dialOrDie().Autoscaling().HorizontalPodAutoscalers(ns).List(opts) rr, err := conn.dialOrDie().AutoscalingV2beta2().HorizontalPodAutoscalers(ns).List(opts)
if err != nil { if err != nil {
return Collection{}, err return Collection{}, err
} }

View File

@ -3,16 +3,18 @@ package resource
import ( import (
"fmt" "fmt"
"strconv" "strconv"
"strings"
"github.com/derailed/k9s/internal/k8s" "github.com/derailed/k9s/internal/k8s"
log "github.com/sirupsen/logrus" log "github.com/sirupsen/logrus"
v1 "k8s.io/api/autoscaling/v1" v1 "k8s.io/api/autoscaling/v1"
autoscalingv2beta2 "k8s.io/api/autoscaling/v2beta2"
) )
// HPA tracks a kubernetes resource. // HPA tracks a kubernetes resource.
type HPA struct { type HPA struct {
*Base *Base
instance *v1.HorizontalPodAutoscaler instance *autoscalingv2beta2.HorizontalPodAutoscaler
} }
// NewHPAList returns a new resource list. // NewHPAList returns a new resource list.
@ -45,10 +47,10 @@ func NewHPAWithArgs(r k8s.Res) *HPA {
func (*HPA) NewInstance(i interface{}) Columnar { func (*HPA) NewInstance(i interface{}) Columnar {
cm := NewHPA() cm := NewHPA()
switch i.(type) { switch i.(type) {
case *v1.HorizontalPodAutoscaler: case *autoscalingv2beta2.HorizontalPodAutoscaler:
cm.instance = i.(*v1.HorizontalPodAutoscaler) cm.instance = i.(*autoscalingv2beta2.HorizontalPodAutoscaler)
case v1.HorizontalPodAutoscaler: case autoscalingv2beta2.HorizontalPodAutoscaler:
ii := i.(v1.HorizontalPodAutoscaler) ii := i.(autoscalingv2beta2.HorizontalPodAutoscaler)
cm.instance = &ii cm.instance = &ii
default: default:
log.Fatalf("Unknown %#v", i) log.Fatalf("Unknown %#v", i)
@ -96,20 +98,10 @@ func (r *HPA) Fields(ns string) Row {
ff = append(ff, i.Namespace) ff = append(ff, i.Namespace)
} }
target := "<unknown>"
if i.Status.CurrentCPUUtilizationPercentage != nil {
target = strconv.Itoa(int(*i.Status.CurrentCPUUtilizationPercentage))
}
var current int32
if i.Spec.TargetCPUUtilizationPercentage != nil {
current = *i.Spec.TargetCPUUtilizationPercentage
}
return append(ff, return append(ff,
i.ObjectMeta.Name, i.ObjectMeta.Name,
i.Spec.ScaleTargetRef.Name, i.Spec.ScaleTargetRef.Name,
fmt.Sprintf("%s٪/%d٪", target, current), toMetrics(i.Spec.Metrics, i.Status.CurrentMetrics),
strconv.Itoa(int(*i.Spec.MinReplicas)), strconv.Itoa(int(*i.Spec.MinReplicas)),
strconv.Itoa(int(i.Spec.MaxReplicas)), strconv.Itoa(int(i.Spec.MaxReplicas)),
strconv.Itoa(int(i.Status.CurrentReplicas)), strconv.Itoa(int(i.Status.CurrentReplicas)),
@ -121,3 +113,70 @@ func (r *HPA) Fields(ns string) Row {
func (*HPA) ExtFields() Properties { func (*HPA) ExtFields() Properties {
return Properties{} return Properties{}
} }
func toMetrics(specs []autoscalingv2beta2.MetricSpec, statuses []autoscalingv2beta2.MetricStatus) string {
if len(specs) == 0 {
return "<none>"
}
list, max, more, count := []string{}, 2, false, 0
for i, spec := range specs {
switch spec.Type {
case autoscalingv2beta2.ExternalMetricSourceType:
current := "<unknown>"
if spec.External.Target.AverageValue != nil {
if len(statuses) > i && statuses[i].External != nil && &statuses[i].External.Current.AverageValue != nil {
current = statuses[i].External.Current.AverageValue.String()
}
list = append(list, fmt.Sprintf("%s/%s (avg)", current, spec.External.Target.AverageValue.String()))
} else {
if len(statuses) > i && statuses[i].External != nil {
current = statuses[i].External.Current.Value.String()
}
list = append(list, fmt.Sprintf("%s/%s", current, spec.External.Target.Value.String()))
}
case autoscalingv2beta2.PodsMetricSourceType:
current := "<unknown>"
if len(statuses) > i && statuses[i].Pods != nil {
current = statuses[i].Pods.Current.AverageValue.String()
}
list = append(list, fmt.Sprintf("%s/%s", current, spec.Pods.Target.AverageValue.String()))
case autoscalingv2beta2.ObjectMetricSourceType:
current := "<unknown>"
if len(statuses) > i && statuses[i].Object != nil {
current = statuses[i].Object.Current.Value.String()
}
list = append(list, fmt.Sprintf("%s/%s", current, spec.Object.Target.Value.String()))
case autoscalingv2beta2.ResourceMetricSourceType:
current := "<unknown>"
if spec.Resource.Target.AverageValue != nil {
if len(statuses) > i && statuses[i].Resource != nil {
current = statuses[i].Resource.Current.AverageValue.String()
}
list = append(list, fmt.Sprintf("%s/%s", current, spec.Resource.Target.AverageValue.String()))
} else {
if len(statuses) > i && statuses[i].Resource != nil && statuses[i].Resource.Current.AverageUtilization != nil {
current = fmt.Sprintf("%d%%", *statuses[i].Resource.Current.AverageUtilization)
}
target := "<auto>"
if spec.Resource.Target.AverageUtilization != nil {
target = fmt.Sprintf("%d%%", *spec.Resource.Target.AverageUtilization)
}
list = append(list, fmt.Sprintf("%s/%s", current, target))
}
default:
list = append(list, "<unknown type>")
}
count++
}
if count > max {
list = list[:max]
more = true
}
ret := strings.Join(list, ", ")
if more {
return fmt.Sprintf("%s + %d more...", ret, count-max)
}
return ret
}