Skip to content

Commit 890816c

Browse files
authored
新增一种缓存的实现方式 (#110)
1 parent ea2ce91 commit 890816c

File tree

1 file changed

+75
-0
lines changed

1 file changed

+75
-0
lines changed
Lines changed: 75 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,75 @@
1+
package main
2+
3+
import (
4+
"context"
5+
"log"
6+
"net/http"
7+
"path/filepath"
8+
9+
"github.com/gin-gonic/gin"
10+
"k8s.io/apimachinery/pkg/labels"
11+
"k8s.io/client-go/informers"
12+
"k8s.io/client-go/kubernetes"
13+
"k8s.io/client-go/tools/cache"
14+
"k8s.io/client-go/tools/clientcmd"
15+
"k8s.io/client-go/util/homedir"
16+
)
17+
18+
func main() {
19+
config, err := clientcmd.BuildConfigFromFlags("", filepath.Join(homedir.HomeDir(), ".kube", "config"))
20+
if err != nil {
21+
panic(err)
22+
}
23+
clientSet, err := kubernetes.NewForConfig(config)
24+
if err != nil {
25+
panic(err)
26+
}
27+
28+
ctx, cancel := context.WithCancel(context.Background())
29+
defer cancel()
30+
31+
sharedInformers := informers.NewSharedInformerFactory(clientSet, 0)
32+
// refer to https://github.com/kubernetes/kubernetes/blob/ea0764452222146c47ec826977f49d7001b0ea8c/staging/src/k8s.io/client-go/dynamic/dynamicinformer/informer_test.go#L107
33+
34+
// TODO: 可以追加更多的 gvr
35+
//gvrs := []schema.GroupVersionResource{
36+
// {Group: "apps", Version: "v1", Resource: "deployments"},
37+
// {Group: "", Version: "v1", Resource: "pods"},
38+
//}
39+
//for _, gvr := range gvrs {
40+
// if _, err = sharedInformers.ForResource(gvr); err != nil {
41+
// panic(err)
42+
// }
43+
//}
44+
45+
lsListerSynced := sharedInformers.Core().V1().Pods().Informer().HasSynced
46+
47+
// Start all informers.
48+
sharedInformers.Start(ctx.Done())
49+
// Wait for all caches to sync.
50+
sharedInformers.WaitForCacheSync(ctx.Done())
51+
52+
if !cache.WaitForNamedCacheSync("pods", ctx.Done(), lsListerSynced) {
53+
return
54+
}
55+
56+
log.Printf("all informers has been started")
57+
58+
// 构造 pod podLister,用于 gin 的查询
59+
podLister := sharedInformers.Core().V1().Pods().Lister()
60+
// 启动 gin router
61+
// 仅做演示,无封装,无异常处理
62+
// 启动之后, curl 127.0.0.1:8088/pods 测试效果
63+
r := gin.Default()
64+
r.GET("/pods", func(c *gin.Context) {
65+
pods, err := podLister.Pods("default").List(labels.Everything())
66+
if err != nil {
67+
panic(err)
68+
c.JSON(http.StatusBadRequest, gin.H{"message": err, "code": 400})
69+
return
70+
}
71+
c.JSON(http.StatusOK, gin.H{"message": "pong", "code": 200, "result": pods})
72+
})
73+
74+
_ = r.Run(":8088")
75+
}

0 commit comments

Comments
 (0)