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 }