2021-02-17 分類: 網(wǎng)站建設(shè)
在本系列的第三篇文章中, Kubernetes 基礎(chǔ):首先學(xué)習(xí)如何使用 ,我強(qiáng)調(diào)你應(yīng)該學(xué)會使用 Kubernetes,而不是建造它。我還解釋說,在 Kubernetes 中,你必須學(xué)習(xí)最小的一組原語來建模應(yīng)用程序。我想強(qiáng)調(diào)這一點(diǎn):你需要學(xué)習(xí)的這組原語是最簡單的原語集,你可以通過它們學(xué)習(xí)如何實現(xiàn)生產(chǎn)級的應(yīng)用程序部署(即高可用性 [HA]、多容器、多應(yīng)用程序)。換句話說,學(xué)習(xí) Kubernetes 內(nèi)置的原語集比學(xué)習(xí)集群軟件、集群文件系統(tǒng)、負(fù)載平衡器、讓人發(fā)瘋的 Apache 和 Nginx 的配置、路由器、交換機(jī)、防火墻和存儲后端更容易 —— 這些是你在傳統(tǒng)的 IT 環(huán)境(虛擬機(jī)或裸機(jī))中建模簡單的 HA 應(yīng)用程序所需要的東西。
1、Katacoda
無疑, Katacoda 是試駕 Kubernetes 集群的最簡單方法。只需單擊一下,五秒鐘后就可以將基于 Web 的終端直接連接到正在運(yùn)行的 Kubernetes 集群中。這對于使用和學(xué)習(xí)來說非常棒。我甚至將它用于演示和測試新想法。Katacoda 提供了一個完整的臨時環(huán)境,在你使用完畢后可以回收利用。
Katacoda 提供了一個臨時的環(huán)境和更深入的實驗室環(huán)境。例如,我最近三四年主講的 Linux Container Internals Lab 是在 Katacoda 中構(gòu)建的。
Katacoda 在其主站點(diǎn)上維護(hù)了若干 Kubernetes 和云教程 并與 Red Hat 合作以支持了一個 OpenShift 的專用學(xué)習(xí)門戶 。了解一下,它們是極好的學(xué)習(xí)資源。
當(dāng)你第一次學(xué)習(xí)駕駛翻斗車時,最好先觀察一下其他人的駕駛方式。
2、Podman generate kube
podman generate kube 命令是一個很棒的子命令,可以幫助用戶自然地從運(yùn)行簡單容器的簡單容器引擎轉(zhuǎn)換到運(yùn)行許多容器的集群用例(正如我在 上篇文章 中所描述的那樣)。 Podman 通過讓你啟動一個新的容器,然后導(dǎo)出這個可工作的 Kube YAML,并在 Kubernetes 中啟動它來實現(xiàn)這一點(diǎn)??纯催@個(你可以在 Katacoda lab 中運(yùn)行它,它已經(jīng)有了 Podman 和 OpenShift)。
首先,請注意運(yùn)行容器的語法與 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.1
- apiVersion: v1
- kind: Pod
- metadata:
- creationTimestamp: "2019-06-07T08:08:12Z"
- labels:
- app: two-pizza
- name: two-pizza
- spec:
- 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: v1
- kind: Service
- metadata:
- creationTimestamp: "2019-06-07T08:08:12Z"
- labels:
- app: two-pizza
- name: two-pizza
- spec:
- selector:
- app: two-pizza
- type: NodePort
- status:
- loadBalancer: {}
你現(xiàn)在有了一些可以的工作 Kubernetes YAML,你可以用它作為練習(xí)的起點(diǎn)來學(xué)習(xí)、調(diào)整等等。-s 標(biāo)志可以為你創(chuàng)造一項服務(wù)。 Brent Baude 甚至致力于 添加卷/持久卷斷言 等新功能。如果想進(jìn)一步深入,請在 Brent 的博客文章《 Podman 現(xiàn)在可以輕松過渡到 Kubernetes 和 CRI-O 》中了解他的工作。
3、oc new-app
oc new-app 命令非常強(qiáng)大。它是特定于 OpenShift 的,所以它在默認(rèn)的 Kubernetes 中不可用,但是當(dāng)你開始學(xué)習(xí) Kubernetes 時它非常有用。讓我們從快速命令開始創(chuàng)建一個相當(dāng)復(fù)雜的應(yīng)用程序:
- oc new-project -n example
- oc new-app -f https://raw.githubusercontent.com/openshift/origin/master/examples/quickstarts/cakephp-mysql.json
使用 oc new-app,你可以從 OpenShift 開發(fā)人員那里偷取模板,并在開發(fā)原語來描述你自己的應(yīng)用程序時擁有一個已知良好的起點(diǎn)。運(yùn)行上述命令后,你的 Kubernetes 命名空間(在 OpenShift 中)將由若干新的已定義資源填充。
- oc get all
輸出:
- NAME READY STATUS RESTARTS AGE
- pod/cakephp-mysql-example-1-build 0/1 Completed 0 4m
- pod/cakephp-mysql-example-1-gz65l 1/1 Running 0 1m
- pod/mysql-1-nkhqn 1/1 Running 0 4m
- NAME DESIRED CURRENT READY AGE
- replicationcontroller/cakephp-mysql-example-1 1 1 1 1m
- replicationcontroller/mysql-1 1 1 1 4m
- NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
- service/cakephp-mysql-example ClusterIP 172.30.234.135 <none> 8080/TCP 4m
- service/mysql ClusterIP 172.30.13.195 <none> 3306/TCP 4m
- NAME REVISION DESIRED CURRENT TRIGGERED BY
- deploymentconfig.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 LATEST
- buildconfig.build.openshift.io/cakephp-mysql-example Source Git 1
- NAME TYPE FROM STATUS STARTED DURATION
- build.build.openshift.io/cakephp-mysql-example-1 Source Git@47a951e Complete 4 minutes ago 2m27s
- NAME DOCKER REPO TAGS UPDATED
- imagestream.image.openshift.io/cakephp-mysql-example docker-registry.default.svc:5000/example/cakephp-mysql-example latest About aminute ago
- NAME HOST/PORT PATH SERVICES PORT TERMINATION WILDCARD
- route.route.openshift.io/cakephp-mysql-example cakephp-mysql-example-example.2886795271-80-rhsummit1.environments.katacoda.com cakephp-mysql-example <all> None
這樣做的好處是你可以刪除 Pod,觀察復(fù)制控制器如何重新創(chuàng)建它們,縮放 Pod 等等。你可以使用模板并將其更改為其他應(yīng)用程序(這是我第一次啟動時所做的)。
4、Visual Studio Code
我把我最喜歡的放在最后。我的大部分工作都使用 vi ,但我從來沒有為 Kubernetes 找到一個好的語法高亮器和代碼補(bǔ)完插件(如果有的話,請告訴我)。相反,我發(fā)現(xiàn)微軟的 VS Code 有一套殺手級的插件,可以完成 Kubernetes 資源的創(chuàng)建并提供樣板。
首先,安裝上圖中顯示的 Kubernetes 和 YAML 插件。
然后,你可以從頭開始創(chuàng)建新的 YAML 文件,并自動補(bǔ)完 Kubernetes 資源。上面的示例顯示了一個服務(wù)。
當(dāng)你使用自動補(bǔ)完并選擇服務(wù)資源時,它會填充該對象的一些模板。當(dāng)你第一次學(xué)習(xí)使用 Kubernetes 時,這非常棒。你可以構(gòu)建 Pod、服務(wù)、復(fù)制控制器、部署等。當(dāng)你從頭開始構(gòu)建這些文件甚至修改你使用 podman generate kube 創(chuàng)建的文件時,這是一個非常好的功能。
總結(jié)
這四個工具(如果算上兩個插件,則為六個)將幫助你學(xué)習(xí)駕馭 Kubernetes,而不是構(gòu)造或裝備它。在本系列的最后一篇文章中,我將討論為什么 Kubernetes 如此適合運(yùn)行這么多不同的工作負(fù)載。
當(dāng)前題目:幫助你駕馭 Kubernetes 的 4 個工具
文章地址:http://aaarwkj.com/news14/101364.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供軟件開發(fā)、網(wǎng)站維護(hù)、營銷型網(wǎng)站建設(shè)、定制網(wǎng)站、App開發(fā)、云服務(wù)器
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容