幫助你駕馭 Kubernetes 的 4 個工具

2019-07-15 12:20:00

學習如何駕馭 Kubernetes 比如何建造它更重要,這些工具可以幫助你更快上路。

在本系列的第三篇文章中,,我強調你應該學會使用 Kubernetes,而不是建造它。我還解釋說,在 Kubernetes 中,你必須學習最小的一組原語來建模應用程式。我想強調這一點:你需要學習的這組原語是最簡單的原語集,你可以通過它們學習如何實現生產級的應用程式部署(即高可用性 [HA]、多容器、多應用程式)。換句話說,學習 Kubernetes 內建的原語集比學習叢集軟體、叢集檔案系統、負載平衡器、讓人發瘋的 Apache 和 Nginx 的設定、路由器、交換機、防火牆和儲存後端更容易 —— 這些是你在傳統的 IT 環境(虛擬機器或裸機)中建模簡單的 HA 應用程式所需要的東西。

在這第四篇文章中,我將分享一些有助於你學習快速駕馭 Kubernetes 的工具。

1、Katacoda

無疑,Katacoda 是試駕 Kubernetes 叢集的最簡單方法。只需單擊一下,五秒鐘後就可以將基於 Web 的終端直接連線到正在執行的 Kubernetes 叢集中。這對於使用和學習來說非常棒。我甚至將它用於演示和測試新想法。Katacoda 提供了一個完整的臨時環境,在你使用完畢後可以回收利用。

OpenShift Playground

OpenShift Playground

Kubernetes Playground

Kubernetes Playground

Katacoda 提供了一個臨時的環境和更深入的實驗室環境。例如,我最近三四年主講的 Linux Container Internals Lab 是在 Katacoda 中構建的。

Katacoda 在其主站點上維護了若干 Kubernetes 和雲教學並與 Red Hat 合作以支援了一個 OpenShift 的專用學習門戶。了解一下,它們是極好的學習資源。

當你第一次學習駕駛翻斗車時,最好先觀察一下其他人的駕駛方式。

2、Podman generate kube

podman generate kube 命令是一個很棒的子命令,可以幫助使用者自然地從執行簡單容器的簡單容器引擎轉換到執行許多容器的叢集用例(正如我在中所描述的那樣)。Podman 通過讓你啟動一個新的容器,然後匯出這個可工作的 Kube YAML,並在 Kubernetes 中啟動它來實現這一點。看看這個(你可以在 Katacoda lab 中執行它,它已經有了 Podman 和 OpenShift)。

首先,請注意執行容器的語法與 Docker 非常相似:

podman run -dtn two-pizza quay.io/fatherlinux/two-pizza

不過這個是其它容器引擎所沒有的:

podman generate kube two-pizza

輸出:

# Generation of Kubernetes YAML is still under development!## Save the output of this file and use kubectl create -f to import# it into Kubernetes.## Created with podman-1.3.1apiVersion: v1kind: Podmetadata:  creationTimestamp: "2019-06-07T08:08:12Z"  labels:    app: two-pizza  name: two-pizzaspec:  containers:  - command:    - /bin/sh    - -c    - bash -c 'while true; do /usr/bin/nc -l -p 3306 < /srv/hello.txt; done'    env:    - name: PATH      value: /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin    - name: TERM      value: xterm    - name: HOSTNAME    - name: container      value: oci    image: quay.io/fatherlinux/two-pizza:latest    name: two-pizza    resources: {}    securityContext:      allowPrivilegeEscalation: true      capabilities: {}      privileged: false      readOnlyRootFilesystem: false    tty: true    workingDir: /status: {}---apiVersion: v1kind: Servicemetadata:  creationTimestamp: "2019-06-07T08:08:12Z"  labels:    app: two-pizza  name: two-pizzaspec:  selector:    app: two-pizza  type: NodePortstatus:  loadBalancer: {}

你現在有了一些可以的工作 Kubernetes YAML,你可以用它作為練習的起點來學習、調整等等。-s 標誌可以為你創造一項服務。Brent Baude 甚至致力於新增卷/持久捲斷言等新功能。如果想進一步深入,請在 Brent 的部落格文章《Podman 現在可以輕鬆過渡到 Kubernetes 和 CRI-O》中了解他的工作。

3、oc new-app

oc new-app 命令非常強大。它是特定於 OpenShift 的,所以它在預設的 Kubernetes 中不可用,但是當你開始學習 Kubernetes 時它非常有用。讓我們從快速命令開始建立一個相當複雜的應用程式:

oc new-project -n exampleoc new-app -f https://raw.githubusercontent.com/openshift/origin/master/examples/quickstarts/cakephp-mysql.json

使用 oc new-app,你可以從 OpenShift 開發人員那裡偷取模板,並在開發原語來描述你自己的應用程式時擁有一個已知良好的起點。執行上述命令後,你的 Kubernetes 名稱空間(在 OpenShift 中)將由若干新的已定義資源填充。

oc get all

輸出:

NAME                                READY     STATUS      RESTARTS   AGEpod/cakephp-mysql-example-1-build   0/1       Completed   0          4mpod/cakephp-mysql-example-1-gz65l   1/1       Running     0          1mpod/mysql-1-nkhqn                   1/1       Running     0          4mNAME                                            DESIRED   CURRENT   READY     AGEreplicationcontroller/cakephp-mysql-example-1   1         1         1         1mreplicationcontroller/mysql-1                   1         1         1         4mNAME                            TYPE        CLUSTER-IP       EXTERNAL-IP   PORT(S)    AGEservice/cakephp-mysql-example   ClusterIP   172.30.234.135   <none>        8080/TCP   4mservice/mysql                   ClusterIP   172.30.13.195    <none>        3306/TCP   4mNAME                                                       REVISION   DESIRED   CURRENT   TRIGGERED BYdeploymentconfig.apps.openshift.io/cakephp-mysql-example   1          1         1         config,image(cakephp-mysql-example:latest)deploymentconfig.apps.openshift.io/mysql                   1          1         1         config,image(mysql:5.7)NAME                                                   TYPE      FROM      LATESTbuildconfig.build.openshift.io/cakephp-mysql-example   Source    Git       1NAME                                               TYPE      FROM          STATUS     STARTED         DURATIONbuild.build.openshift.io/cakephp-mysql-example-1   Source    Git@47a951e   Complete   4 minutes ago   2m27sNAME                                                   DOCKER REPO                                                      TAGS      UPDATEDimagestream.image.openshift.io/cakephp-mysql-example   docker-registry.default.svc:5000/example/cakephp-mysql-example   latest    About aminute agoNAME                                             HOST/PORT                                                                         PATH   SERVICES                PORT      TERMINATION   WILDCARDroute.route.openshift.io/cakephp-mysql-example   cakephp-mysql-example-example.2886795271-80-rhsummit1.environments.katacoda.com   cakephp-mysql-example   <all>                   None

這樣做的好處是你可以刪除 Pod,觀察複製控制器如何重新建立它們,縮放 Pod 等等。你可以使用模板並將其更改為其他應用程式(這是我第一次啟動時所做的)。

4、Visual Studio Code

我把我最喜歡的放在最後。我的大部分工作都使用 vi,但我從來沒有為 Kubernetes 找到一個好的語法高亮器和程式碼補完外掛(如果有的話,請告訴我)。相反,我發現微軟的 VS Code 有一套殺手級的外掛,可以完成 Kubernetes 資源的建立並提供樣板。

VS Code plugins UI

首先,安裝上圖中顯示的 Kubernetes 和 YAML 外掛。

Autocomplete in VS Code

然後,你可以從頭開始建立新的 YAML 檔案,並自動補完 Kubernetes 資源。上面的範例顯示了一個服務。

VS Code autocomplete filling in boilerplate for an object

當你使用自動補完並選擇服務資源時,它會填充該物件的一些模板。當你第一次學習使用 Kubernetes 時,這非常棒。你可以構建 Pod、服務、複製控制器、部署等。當你從頭開始構建這些檔案甚至修改你使用 podman generate kube 建立的檔案時,這是一個非常好的功能。

總結

這四個工具(如果算上兩個外掛,則為六個)將幫助你學習駕馭 Kubernetes,而不是構造或裝備它。在本系列的最後一篇文章中,我將討論為什麼 Kubernetes 如此適合執行這麼多不同的工作負載。