client-go常用函数
1、获取key的方法
cache.MetaNamespaceKeyFunc(obj)
func MetaNamespaceKeyFunc(obj interface{}) (string, error) {
if key, ok := obj.(ExplicitKey); ok {
return string(key), nil
}
meta, err := meta.Accessor(obj)
if err != nil {
return "", fmt.Errorf("object has no meta: %v", err)
}
if len(meta.GetNamespace()) > 0 {
return meta.GetNamespace() + "/" + meta.GetName(), nil
}
return meta.GetName(), nil
}
2、从缓存中删除指定对象
cache.DeletionHandlingMetaNamespaceKeyFunc()
func DeletionHandlingMetaNamespaceKeyFunc(obj interface{}) (string, error) {
if d, ok := obj.(DeletedFinalStateUnknown); ok {
return d.Key, nil
}
return MetaNamespaceKeyFunc(obj)
}
3、获取OwnerReference
metav1.GetControllerOf
调用metav1.GetControllerOf获取该pod对象的OwnerReference,并判断该pod是否有上层controller
func GetControllerOf(controllee Object) *OwnerReference {
ref := GetControllerOfNoCopy(controllee)
if ref == nil {
return nil
}
cp := *ref
return &cp
}
4、Kubernetes 源码依赖库中的 wait 库功能介绍
"k8s.io/apimachinery/pkg/util/wait"
周期性执行一个函数
在某些情况下,我们需要周期性地执行一些动作,比如发送心跳请求给master,那么可以使用 wait 库中的 Forever 功能。 这里给一个简单的例子,每隔一秒钟输出当前的时间。
package main
import (
"fmt"
"time"
"k8s.io/apimachinery/pkg/util/wait"
)
func main() {
wait.Forever(func() {
fmt.Println(time.Now().String())
}, time.Second)
}
带StopSignal的周期性执行函数
上面的 Wait 函数其实是 Util 的变体,Util 本身还带有一个 stopSignal 选项。比如我们要删除一个CDN资源,然后删除之后周期性地检查文件是否还可以访问。可以用下面的逻辑。我们这里用counter来代替检查资源状态的判断逻辑。
package main
import (
"fmt"
"time"
"k8s.io/apimachinery/pkg/util/wait"
)
var stopSignal = make(chan struct{})
func main() {
var counter = 1
wait.Until(func() {
if counter > 10 {
close(stopSignal)
}
fmt.Println(time.Now().String())
counter++
}, time.Second, stopSignal)
}
5、获取namespace的方法
namespaceKey, name, err := cache.SplitMetaNamespaceKey(key)
if err != nil {
return err
}
6、分解key的方法,通过key获取namespace,name
//与 MetaNamespaceKeyFunc() 功能相反的是 SplitMetaNamespaceKey() 函数,它将传入的 Key 分解,返回对象所在的命名空间和对象名称。
namespace, name, err := cache.SplitMetaNamespaceKey(key)
if err != nil {
return true
}
//使用namespace进行查找
service,err :=c.serviceLister.Services(namwspacekey).Get(name)
if err !=nil{
return err
}

浙公网安备 33010602011771号