k3s新版本發佈!支持Helm3!還有其餘重要更新Highlight!

前 言

兩個月前,業界應用最爲普遍的Kubernetes管理平臺建立者Rancher Labs(如下簡稱Rancher)在KubeCon2019北美峯會上宣佈,Rancher打造的輕量級Kubernetes發行版k3s正式GA,這款產品專爲在資源有限的環境設計,能夠知足在邊緣計算環境中、在小型設備上運行Kubernetes集羣的需求。在這以後,咱們依舊持續受到全球開發者的關注,到12月末,Github Star突破了11,000。nginx

本週,k3s發佈新版本v1.17.0+k3s.1,這一版本是GA後的首個重大變動版本,本文將針對該版本進行簡要說明。git

版本號命名規則

以前k3s一直都使用通用的版本號,如v0.一、v0.二、v1.0等。因爲k3s從K8s衍生而來,每一個k3s版本都會對應一個Kubernetes版本,好比k3s v1.0對應的是Kubernetes v1.16.3,可是這些信息須要在Release Note中查找,這給用戶帶來了極大的不便。Rancher一貫重視用戶的使用體驗,所以更改了k3s的版本號命名方式。新的版本號命名方式採用「<K8s version>+<k3s metadata>」的格式,好比v1.17.0+k3s.1版本,如此用戶就能顯而易見地清楚當前對應的Kubernetes版本。github

v1.17.0+k3s.1重要改進

Helm2切換到Helm3

一般,咱們都是經過Helm的CLI工具來管理chart。此前的k3s版本僅僅支持Helm2,在本次發佈的新版本中增長了對Helm3的支持。Helm3中移除了Tiller組件,其自己的簡潔性給k3s的使用帶來了便利。在新版本的k3s中,Helm3的使用方式以下:redis

$ helm --kubeconfig /etc/rancher/k3s/k3s.yaml repo add helm-stable https://kubernetes-charts.storage.googleapis.com/
"helm-stable" has been added to your repositories
 
$ helm --kubeconfig /etc/rancher/k3s/k3s.yaml search repo nginx
NAME                                    CHART VERSION   APP VERSION     DESCRIPTION
helm-stable/nginx-ingress               1.28.0          0.26.2          An nginx Ingress controller that uses ConfigMap...
helm-stable/nginx-ldapauth-proxy        0.1.3           1.13.5          nginx proxy with ldapauth
helm-stable/nginx-lego                  0.3.1                           Chart for nginx-ingress-controller and kube-lego
helm-stable/gcloud-endpoints            0.1.2           1               DEPRECATED Develop, deploy, protect and monitor…
 
$ helm --kubeconfig /etc/rancher/k3s/k3s.yaml install helm-stable/redis --generate-name
 
$ helm --kubeconfig /etc/rancher/k3s/k3s.yaml list --all-namespaces
NAME                    NAMESPACE       REVISION        UPDATED                                 STATUS          CHART           APP VERSION
redis-1578463519        default         1               2020-01-08 06:05:22.482166284 +0000 UTC deployed        redis-10.3.1    5.0.7
traefik                 kube-system     1               2020-01-08 05:24:20.987390979 +0000 UTC deployed        traefik-1.81.0  1.7.19

注意:traefik是k3s內置的ingress-controller,可是默認經過Helm安裝,因此這裏咱們能夠讀取到,請不要誤刪。docker

針對Helm的使用,k3s還有另一種方式,就是經過「Auto-Deploying Manifests」功能來部署chart,固然它須要咱們使用自定義CRD進行描述。這是k3s經過內置了一個本身實現的helm controller(https://github.com/rancher/helm-controller)來實現的,爲了同時兼容Helm3和Helm2,咱們增長了helmVersion進行說明,好比api

# 默認使用helm3,如使用helm2則指定helmVersion
apiVersion: helm.cattle.io/v1
kind: HelmChart
metadata:
  name: grafana
  namespace: kube-system
spec:
  chart: stable/grafana
  helmVersion: v2
  targetNamespace: monitoring
  set:
    adminPassword: "NotVerySafePassword"
  valuesContent: |-
    image:
      tag: master
    env:
      GF_EXPLORE_ENABLED: true
    adminUser: admin
    sidecar:
      datasources:
        enabled: true

此處更詳細的信息,請參考官方文檔:架構

https://rancher.com/docs/k3s/latest/en/advanced/ide

pause容器問題

咱們都知道Kubernetes的Pod都須要一個pause鏡像,此前的k3s版本使用的是gcr倉庫的pause鏡像,這增長了國內用戶初次安裝的難度,體驗並不友好。新版本對此進行了優化,已經將pause鏡像的地址配置使用DockerHub,這樣對於剛接觸k3s的用戶來講,極大下降了初次部署的難度:工具

$ crictl images | grep pause
IMAGE                                      TAG                  IMAGE ID            SIZE
docker.io/rancher/pause                    3.1                  da86e6ba6ca19       327kB

關於這一issue更詳細的說明,請參考:優化

https://github.com/rancher/k3s/issues/1128

其餘

k3s內置實現了svclb,換言之,用戶能夠無需其餘配置就可以使用type=Loadbalancer的service。在此前的版本中UDP端口的使用存在一些問題,此版本中進行了修復:

https://github.com/rancher/k3s/issues/577

k3s內置部署了metric-server,方便用戶查看各類資源的度量信息。在此前的版本中,有用戶反饋metrics信息查不到的狀況,通過排查發現是部分架構的metric-server鏡像沒有推送完整,致使可能使用非amd64的鏡像出現問題。在這一版本中也已經修復:

https://github.com/rancher/k3s/issues/1189

更多其餘issue,請查看milestone:

https://github.com/rancher/k3s/milestone/13?closed=1

關於新版本的更多信息,請查閱Release Note:

https://github.com/rancher/k3s/releases/tag/v1.17.0+k3s.1

後 記

k3s發佈至今,一直保持高速發展的態勢。去年11月中旬發佈了GA版本,Github Star數已經超過11,000。也有用戶開始在生產環境中嘗試使用k3s而且取得了不錯的效果。做爲一個發佈不到一年的開源產品,當然不完美,也所以遭受了諸多質疑甚至謾罵攻擊,咱們十分理解用戶的心情,也會堅守技術創新的初心。k3s的研發團隊也在不斷努力,針對社區用戶提出的問題以及諸如邊緣計算、嵌入式設備、CI環境等實際使用場景對k3s進行優化和完善。同時,咱們很是歡迎各路豪傑參與k3s的改進。

k3s Github:

https://github.com/rancher/k3s

相關文章
相關標籤/搜索