如何優雅地使用containerd?這里有一份必讀的技巧攻略

前 言

Docker是我們常用的容器runtime,友好的CLI,豐富的社區資料,外加研發運維人員多年的經驗積累,使用Docker幾乎是沒有任何門檻的事。而k3s為了降低資源消耗,將默認的runtime修改為containerd,雖然containerd很早就已經是Docker的一部分,但是純粹使用containerd還是給大家帶來了諸多困擾。本文收集了一些社區常見的containerd問題,尋求到解決方案后整理成文,供大家需要時查閱。

入門簡介

我們都知道Kubernetes定義了自己運行時接口規范CRI,containerd雖然具備容器管理能力,但是不能被直接被Kubernetes使用。k3s作為Kubernetes的精簡版本,也是如此,k3s自身的kubelet通過cri-containerd plugin(https://github.com/containerd/cri)來驅動containerd創建Pod。

在這里插入圖片描述

單純的Containerd沒有Docker CLI,對于經常使用Docker的用戶來說,一下就會感到不習慣。根據CRI規范,Kubernetes社區也定義了專門CLI工具crictl(https://github.com/kubernetes-sigs/cri-tools)。k3s中也內置了crictl,它被直接編譯到k3s binary中,你在安裝k3s時,會自動創建crictl的軟連接。crictl具備了和Docker CLI類似的功能:

在這里插入圖片描述

除了crictl,k3s還內置了ctr(https://github.com/containerd/containerd/tree/master/cmd/ctr),ctr是containerd本身的CLI,更對容器和鏡像API的基本封裝:

在這里插入圖片描述

目前k3s的containerd使用的runc-v2版本,這個版本有個巨大的優化就是針對每個Pod創建containerd-shim進程。以Traefik Pod為例,pause容器和traefik容器都是containerd-shim的子進程,這種進程劃分方式更加合理,對Kubernetes更加友好。

在這里插入圖片描述

常用技巧

containerd相關的CLI確實沒有Docker CLI方便,比如筆者在使用containerd時碰到一個場景,期望實現對鏡像重新tag的操作,這在Docker下非常容易做到,但是在containerd下非常麻煩。crictl中并不支持這種操作,社區中也有相關issue解釋:

https://github.com/kubernetes-sigs/cri-tools/issues/438

所以我們只能使用其他方式,通常我會這樣做:

# 在一臺機去上使用docker tag轉換image
# 導出鏡像,并拷貝到k3s機器上
docker tag busybox busyboxaaa
docker save -o busybox.tar busyboxaaa
scp busybox.tar ubuntu@172.31.24.12:~/
 
# 用ctr導入
ctr image import busybox.tar

k3s集成的containerd的配置文件被存放在 /var/lib/rancher/k3s/agent/etc/containerd/config.toml 中,但是如果要修改其配置不能單純修改它,你需要通過模版修改它:

cd /var/lib/rancher/k3s/agent/etc/containerd
cp config.toml config.toml.tmpl
 
# update config.toml.tmpl
# reboot k3s to take affect
systemctl restart k3s

通常來說,我們都會在本地環境使用k3s,使用私有Registry也是不可避免的,Docker中配置私有registry是非常方便的,而在containerd中該如何配置?關于containerd的registry配置請參考:

https://github.com/containerd/cri/blob/master/docs/registry.md

值得一提的是一個特殊場景,通常你會在內網在用registry鏡像啟用一個鏡像倉庫服務,為了簡單方便,你可以不啟用tls證書而單純使用http模式。這種情況下,k3s有一個方便的配置方式,即編輯/etc/rancher/k3s/registries.yaml,比如:

$ cat /etc/rancher/k3s/registries.yaml
mirrors:
  "172.31.7.129:5000":
    endpoint:
      - "http://172.31.7.129:5000”
 
$ systemctl restart k3s

重啟后,containerd的配置會出現變化,直接使用crictl命令即可拉取鏡像:

在這里插入圖片描述

后 記

從業界的技術發展趨勢上看,Docker越來越被Kubernetes社區所拋棄,以實現CRI接口的各種容器runtime會與Kubernetes兼容性越發友好。Docker本身的迭代速度已經無法滿足容器的發展,k3s直接使用containerd可以很快跟蹤各種容器技術本身的新特性,對技術人員來說,盡早適應Docker以外的runtime,才能跟上社區主流的前進方向。

?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,283評論 6 530
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 97,947評論 3 413
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,094評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,485評論 1 308
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,268評論 6 405
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,817評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,906評論 3 440
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,039評論 0 285
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,551評論 1 331
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,502評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,662評論 1 366
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,188評論 5 356
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 43,907評論 3 345
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,304評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,563評論 1 281
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,255評論 3 389
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,637評論 2 370

推薦閱讀更多精彩內容