37 Star 411 Fork 76

GVPrancher/rancher

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
utils.go 4.78 KB
一键复制 编辑 原始数据 按行查看 历史
Dan Ramich 提交于 2019-06-12 09:11 . Run goimports on all of rancher
package servicemonitor
import (
"encoding/json"
"fmt"
"reflect"
"sort"
"strings"
monitoringv1 "github.com/coreos/prometheus-operator/pkg/client/monitoring/v1"
util "github.com/rancher/rancher/pkg/controllers/user/workload"
rmonitoringv1 "github.com/rancher/types/apis/monitoring.coreos.com/v1"
v3 "github.com/rancher/types/apis/project.cattle.io/v3"
corev1 "k8s.io/api/core/v1"
metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
"k8s.io/apimachinery/pkg/labels"
"k8s.io/apimachinery/pkg/util/intstr"
)
func filterRancherLabels(l map[string]string) labels.Set {
rtn := map[string]string{}
for k, v := range l {
if !strings.Contains(k, "cattle.io/") {
rtn[k] = v
}
}
return labels.Set(rtn)
}
func getWorkloadOwnerReference(w *util.Workload) metav1.OwnerReference {
controller := true
return metav1.OwnerReference{
APIVersion: w.APIVersion,
Kind: w.Kind,
Name: w.Name,
UID: w.UUID,
Controller: &controller,
}
}
func getMetricsFromWorkload(w *util.Workload) ([]v3.WorkloadMetric, error) {
data, ok := w.TemplateSpec.Annotations[metricsAnnotation]
if !ok {
return nil, nil
}
var metrics []v3.WorkloadMetric
if err := json.Unmarshal([]byte(data), &metrics); err != nil {
return nil, err
}
return metrics, nil
}
func getServiceMonitorFromWorkload(w *util.Workload) (*monitoringv1.ServiceMonitor, error) {
metrics, err := getMetricsFromWorkload(w)
if err != nil {
return nil, err
}
if len(metrics) == 0 {
return nil, nil
}
workloadTargetAnnotation, err := util.IDAnnotationToString(w.Key)
if err != nil {
return nil, err
}
rtn := &monitoringv1.ServiceMonitor{
ObjectMeta: metav1.ObjectMeta{
OwnerReferences: []metav1.OwnerReference{getWorkloadOwnerReference(w)},
Namespace: w.Namespace,
Annotations: map[string]string{
util.WorkloadAnnotation: workloadTargetAnnotation,
},
Name: w.Name,
},
Spec: monitoringv1.ServiceMonitorSpec{},
}
for _, metric := range metrics {
portName := fmt.Sprintf("%s%d", "metrics", metric.Port)
intstrPort := intstr.FromInt(int(metric.Port))
endpoint := monitoringv1.Endpoint{
Port: portName,
TargetPort: &intstrPort,
Path: metric.Path,
Scheme: metric.Schema,
TLSConfig: &monitoringv1.TLSConfig{
InsecureSkipVerify: true,
},
}
if endpoint.Path == "" {
endpoint.Path = "/metrics"
}
rtn.Spec.Endpoints = append(rtn.Spec.Endpoints, endpoint)
}
return rtn, nil
}
func getWorkloadFromOwners(namespace string, owners []metav1.OwnerReference, lister rmonitoringv1.ServiceMonitorLister) (*monitoringv1.ServiceMonitor, error) {
for _, owner := range owners {
if !*owner.Controller || owner.Kind != "ServiceMonitor" {
continue
}
return lister.Get(namespace, owner.Name)
}
return nil, nil
}
func areServiceMonitorEqual(a, b *monitoringv1.ServiceMonitor) bool {
sort.Sort(EndpointSorter(a.Spec.Endpoints))
sort.Sort(EndpointSorter(b.Spec.Endpoints))
if len(a.Spec.Endpoints) != len(b.Spec.Endpoints) {
return false
}
for i := 0; i < len(a.Spec.Endpoints); i++ {
aEndpoint := a.Spec.Endpoints[i]
bEndpoint := b.Spec.Endpoints[i]
if aEndpoint.Port != bEndpoint.Port ||
aEndpoint.Path != bEndpoint.Path ||
aEndpoint.Scheme != bEndpoint.Scheme {
return false
}
}
for _, annotation := range []string{util.WorkloadAnnotation, servicesAnnotation} {
adata := a.Annotations[annotation]
bdata := b.Annotations[annotation]
if adata == bdata && adata == "" {
continue
}
var aarray, barray []string
if err := json.Unmarshal([]byte(adata), &aarray); err != nil {
return false
}
if err := json.Unmarshal([]byte(bdata), &barray); err != nil {
return false
}
sort.Strings(aarray)
sort.Strings(barray)
if !reflect.DeepEqual(aarray, barray) {
return false
}
}
return true
}
type EndpointSorter []monitoringv1.Endpoint
func (e EndpointSorter) Len() int {
return len(e)
}
func (e EndpointSorter) Swap(i, j int) {
e[i], e[j] = e[j], e[i]
}
func (e EndpointSorter) Less(i, j int) bool {
return getEndpointString(e[i]) < getEndpointString(e[j])
}
func getEndpointString(e monitoringv1.Endpoint) string {
return fmt.Sprintf("%s%s%s", e.Scheme, e.Port, e.Path)
}
func getStringSliceFromAnnotation(obj metav1.ObjectMeta, key string) []string {
annotaiton, ok := obj.Annotations[key]
if !ok {
return []string{}
}
var rtn []string
json.Unmarshal([]byte(annotaiton), &rtn)
return rtn
}
func GetServicePortsFromEndpoint(endpoints []monitoringv1.Endpoint) []corev1.ServicePort {
PortMap := map[string]bool{}
var rtn []corev1.ServicePort
for _, endpoint := range endpoints {
if _, ok := PortMap[endpoint.Port]; ok {
continue
}
rtn = append(rtn, corev1.ServicePort{
Name: endpoint.Port,
Port: endpoint.TargetPort.IntVal,
TargetPort: *endpoint.TargetPort,
})
PortMap[endpoint.Port] = true
}
return rtn
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/rancher/rancher.git
git@gitee.com:rancher/rancher.git
rancher
rancher
rancher
v2.3.0-alpha5

搜索帮助