k8s在go語(yǔ)言中的使用及client?初始化簡(jiǎn)介
作為k8s官方維護(hù)的客戶端,k8s go-client對(duì)于go語(yǔ)言中使用k8s可以說(shuō)是唯一選項(xiàng)。但是官方的使用示例我個(gè)人覺得并不是很清晰,尤其是對(duì)于對(duì)于k8s并不熟悉的用戶。這里我總結(jié)一下使用過(guò)程中碰到的坑,也希望能給有需要的人一些參考。
首先從官方示例說(shuō)起:這里先解釋一下k8s連接問(wèn)題。集群的節(jié)點(diǎn)上會(huì)有一個(gè).kube目錄(這個(gè)目錄一般在root用戶home目錄下)目錄中會(huì)存在一個(gè)config文件,文件中記錄了連接k8s集群所需的所有信息,如apiserver地址,用戶認(rèn)證token等。一般來(lái)說(shuō)客戶端連接集群均需要此配置文件。一下就是官方示例代碼。
var kubeconfig *string
//配置了config目錄就讀取該目錄下的config信息
if home := homedir.HomeDir(); home != "" {
kubeconfig = flag.String("kubeconfig", filepath.Join(home, ".kube", "config"), "(optional) absolute path to the kubeconfig file")
} else {
//否則就需要指定配置文件路徑
kubeconfig = flag.String("kubeconfig", "", "absolute path to the kubeconfig file")
}
flag.Parse()
config, err := clientcmd.BuildConfigFromFlags("", *kubeconfig)
if err != nil {
panic(err)
}
clientset, err := kubernetes.NewForConfig(config)
if err != nil {
panic(err)
}可以看到初始化go-client必須要指定config文件。但是實(shí)際使用中往往沒有這里理想化,比如我們的代碼運(yùn)行在集群外,再比如我們的代碼連接的client需要在不同集群上來(lái)回切換,更甚者我們需要連接的集群會(huì)隨時(shí)改變,集群數(shù)量改變,集群的連接信息改變??傊芏嗲闆r下無(wú)法直接從集群獲取到config文件,也無(wú)法使用固定的config文件。
總體上來(lái)說(shuō),使用場(chǎng)景包括集群內(nèi)和集群外訪問(wèn),同時(shí)也可以分為固定訪問(wèn)和動(dòng)態(tài)訪問(wèn)。對(duì)于集群內(nèi)且集群的配置是固定的,使用起來(lái)還是相當(dāng)簡(jiǎn)單。
1、集群內(nèi)且集群配置固定,以進(jìn)程方式運(yùn)行,即代碼編譯后直接以進(jìn)程的方式運(yùn)行在集群的某個(gè)節(jié)點(diǎn)上且只會(huì)訪問(wèn)本地或外部固定集群。這種情況下,本地集群config文件路徑是固定的,外部集群可以提前把config文件放到本地,使用示例代碼的配置方式即可
2、集群內(nèi)且集群配置固定,以pod方式運(yùn)行。對(duì)于本地集群,雖然pod就跑在集群中,但是容器的因?yàn)楦綦x性,無(wú)法獲取集群的配置信息。此時(shí)可以通過(guò)默認(rèn)配置跟k8s RBAC進(jìn)行本地集群訪問(wèn),即使用pod中的默認(rèn)apiserver地址和端口環(huán)境變量(可以直接使用go-client的默認(rèn)config rest.InclusterConfig)連接集群,同時(shí)給pod配置集群的admin角色即可。也可以將.kube目錄掛載到pod上,通過(guò)讀取該目錄中的配置文件初始化客戶端。訪問(wèn)外部集群跟1中的方式無(wú)太大差別。
3、需要訪問(wèn)的集群不固定(集群數(shù)量隨時(shí)增減,集群認(rèn)證信息會(huì)過(guò)期),這種情況下無(wú)論是否運(yùn)行在容器中都不太好使用官方的示例代碼來(lái)連接集群。此種情況下需要一個(gè)能夠獲取集群認(rèn)證信息(token,user password等)的地方。有了這些信息代碼中就可以手動(dòng)新建config,通過(guò)這個(gè)config來(lái)初始化集群,同時(shí)在認(rèn)證信息失效后及時(shí)重新初始化
手動(dòng)指定apiserver地址,這里地址可以是url也可以主機(jī)加端口
kubeconfig,er := clientcmd.BuildConfigFromFlags(apiUrl,"")
配置認(rèn)證信息,token或者用戶名加密碼或者其他認(rèn)證方式
kubeconfig.BearerToken = token
初始化client
clientset, err := kubernetes.NewFo,rConfig(kubeconfig)
當(dāng)發(fā)生變動(dòng)或者認(rèn)證信息失效時(shí),客戶端或報(bào)相應(yīng)的權(quán)限錯(cuò)誤,即可重新獲取認(rèn)證信息,重新初始化。這樣可以保證不重啟程序,不手動(dòng)修改配置的情況下適應(yīng)集群變動(dòng)
以上就是k8s在go語(yǔ)言中的使用及client 初始化簡(jiǎn)介的詳細(xì)內(nèi)容,更多關(guān)于k8s go client初始化的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
詳解Golang中Context的三個(gè)常見應(yīng)用場(chǎng)景
Golang?context主要用于定義超時(shí)取消,取消后續(xù)操作,在不同操作中傳遞值。本文通過(guò)簡(jiǎn)單易懂的示例進(jìn)行說(shuō)明,感興趣的可以了解一下2022-12-12
Go實(shí)現(xiàn)跨平臺(tái)的藍(lán)牙聊天室示例詳解
這篇文章主要為大家介紹了Go實(shí)現(xiàn)跨平臺(tái)的藍(lán)牙聊天室示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12
輕松構(gòu)建Go應(yīng)用的Dockerfile
本文介紹了如何制作一個(gè)用于構(gòu)建和運(yùn)行Go應(yīng)用程序的Docker鏡像的Dockerfile的相關(guān)資料,需要的朋友可以參考下2023-10-10
golang如何使用指針靈活操作內(nèi)存及unsafe包原理解析
本文將深入探討unsafe包的功能和原理,同時(shí),我們學(xué)習(xí)某種東西,一方面是為了實(shí)踐運(yùn)用,另一方面則是出于功利性面試的目的,所以,本文還會(huì)為大家介紹unsafe?包的典型應(yīng)用以及高頻面試題,感興趣的朋友跟隨小編一起看看吧2024-07-07

