一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

在Windows 10上創(chuàng)建單節(jié)點(diǎn)的Kubernetes實施示例

汽車玩家 ? 來源:新鈦云服 ? 作者:新鈦云服 ? 2020-05-05 21:01 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

本Kubernetes實施示例演示了如何在Windows 10上創(chuàng)建單節(jié)點(diǎn)群集,以啟動并運(yùn)行容器化的應(yīng)用程序。

Kubernetes使開發(fā)人員和系統(tǒng)管理員可以快速部署應(yīng)用程序并將其擴(kuò)展到其需求,而無需停機(jī)。Kubernetes系統(tǒng)是高度可配置的,幾乎所有內(nèi)容都圍繞四個重要概念:節(jié)點(diǎn),pod,部署和服務(wù)。

準(zhǔn)備好進(jìn)入Kubernetes的世界了嗎?這是開始的關(guān)鍵步驟和Kubernetes命令。

學(xué)習(xí)Kubernetes架構(gòu)的基礎(chǔ)知識

首先,了解Kubernetes系統(tǒng)的基礎(chǔ)非常有用。運(yùn)行容器的服務(wù)器及其內(nèi)部的應(yīng)用程序稱為節(jié)點(diǎn)。主服務(wù)器控制,管理和配置這些節(jié)點(diǎn)服務(wù)器。主節(jié)點(diǎn)還管理Pod或一組駐留在節(jié)點(diǎn)上的一個或多個容器。

主服務(wù)器充當(dāng)Kubernetes集群的控制平面??刂破矫嬷懈鞣N組件的主要目的是維護(hù)所有Kubernetes對象的記錄,并通過自動響應(yīng)變化來連續(xù)管理集群的期望狀態(tài)。

控制平面有四個主要組成部分:

Etcd:Kubernetes集群etcd的最基本組件是輕量級可用的配置存儲。它可以跨多個Kubernetes節(jié)點(diǎn)設(shè)置。它的主要目的是存儲Kubernetes集群中每個節(jié)點(diǎn)都可以訪問的配置數(shù)據(jù)。

Kube-apiserver:這是用于kubectl等命令行工具的RESTful接口,為它們提供了與Kubernetes集群進(jìn)行交互的方式。簡單來說,它充當(dāng)各種工具的管理點(diǎn),以通過REST API控制和配置Kubernetes集群。

Kube控制器管理:該服務(wù)的主要作用是維護(hù)群集的狀態(tài),例如副本數(shù)。如果觀察到所需狀態(tài)有任何變化,則kube-controller-manager將運(yùn)行所需的過程以確保滿足所需狀態(tài)。

Kube調(diào)度器:該組件的主要職責(zé)是根據(jù)配置,資源需求和特定于工作負(fù)載的需求計劃群集工作負(fù)載。

節(jié)點(diǎn)服務(wù)器有多個組件,這些組件使主服務(wù)器可以使用它們。這些包括:

容器運(yùn)行時:要運(yùn)行封裝在節(jié)點(diǎn)上存在的pod中的應(yīng)用程序,我們需要一個輕量級的,隔離的操作環(huán)境:容器。容器運(yùn)行時是一種工具,例如Docker,用于創(chuàng)建,部署和運(yùn)行應(yīng)用程序。

Kubelet:Kubelet是安裝在節(jié)點(diǎn)上以與主節(jié)點(diǎn)進(jìn)行通信并從其接收命令的代理或服務(wù)。它指導(dǎo)需要在節(jié)點(diǎn)上執(zhí)行的操作,例如創(chuàng)建,縮放和刪除容器。

Kube代理:此代理服務(wù)將請求中繼到正確的容器并執(zhí)行負(fù)載平衡。Kube-proxy還執(zhí)行主機(jī)級子網(wǎng)劃分,以確保其他組件可以訪問服務(wù)。

Kubernetes實施步驟

在本教程中,我們將創(chuàng)建一個在Windows 10操作系統(tǒng)上運(yùn)行的單節(jié)點(diǎn)群集。

要在Windows上安裝和設(shè)置Kubernetes,請加載kubectl并安裝minikube。Chocolatey軟件包管理器在此過程中會提供幫助。命令行工具kubectl對Kubernetes集群運(yùn)行命令,而minikube是使我們能夠在機(jī)器上的VM中運(yùn)行單節(jié)點(diǎn)集群的工具。輸入命令:

choco install Kubernetes-cli minikube

這將返回如下所示的輸出:

在Windows 10上創(chuàng)建單節(jié)點(diǎn)的Kubernetes實施示例

現(xiàn)在,運(yùn)行以下命令并驗證您的計算機(jī)上是否安裝了kubectl:

kubectl.exe version --client

必須在以下屏幕截圖中看到類似的輸出:

在Windows 10上創(chuàng)建單節(jié)點(diǎn)的Kubernetes實施示例

接下來,在Kubernetes中啟動一個工作機(jī)-或節(jié)點(diǎn)。它可以是物理機(jī)或虛擬機(jī)。為此,請使用以下命令啟動minikube:

minikube start

這將返回如下所示的輸出:

在Windows 10上創(chuàng)建單節(jié)點(diǎn)的Kubernetes實施示例

由于我們在Windows上安裝Kubernetes,因此請使用Hyper-V啟動VM并在VM上設(shè)置Kubernetes集群。

這樣就完成了設(shè)置。

如何在Kubernetes中運(yùn)行容器

要啟動容器,請使用下面的Kubernetes命令創(chuàng)建部署。提供部署名稱和要部署的容器映像。Kubernetes將自動選擇Docker作為默認(rèn)的容器運(yùn)行時。在這里,我們使用將運(yùn)行Nginx Web服務(wù)器的鏡像:

kubectl.exe create deployment my-nginx --image nginx

創(chuàng)建部署后,Kubernetes將構(gòu)建Pod來承載應(yīng)用程序?qū)嵗?/p>

運(yùn)行上一條命令后立即輸入get pods,以在部署pod時捕獲ContainerCreating狀態(tài):

kubectl.exe get pods

這將在幾秒鐘內(nèi)完成,并且容器狀態(tài)應(yīng)更改為“正在運(yùn)行”:

在Windows 10上創(chuàng)建單節(jié)點(diǎn)的Kubernetes實施示例

如下所示,將describe關(guān)鍵字與部署名稱一起使用,以查看有關(guān)部署的更多詳細(xì)信息:

kubectl.exe get deployment

kubectl.exe describe deployment helloworld-nginx

這將返回結(jié)果,例如副本數(shù),所需狀態(tài)和時間戳記:

在Windows 10上創(chuàng)建單節(jié)點(diǎn)的Kubernetes實施示例

在此Kubernetes實施教程中,我們僅運(yùn)行一個容器或Nginx服務(wù)器,但有時必須適應(yīng)增加的工作量和流量。在這種情況下,請擴(kuò)大應(yīng)用程序?qū)嵗臄?shù)量。這可以通過使用帶有--replicas參數(shù)的kubectl規(guī)模部署來實現(xiàn):

kubectl.exe scale deployment helloworld-nginx --replicas 4

檢查部署。將觀察到已部署了該應(yīng)用程序?qū)嵗乃膫€副本:

在Windows 10上創(chuàng)建單節(jié)點(diǎn)的Kubernetes實施示例

現(xiàn)在,檢查Kubernetes pod;該節(jié)點(diǎn)上應(yīng)運(yùn)行四個容器:

在Windows 10上創(chuàng)建單節(jié)點(diǎn)的Kubernetes實施示例

啟動應(yīng)用程序并運(yùn)行

現(xiàn)在,有一個應(yīng)用程序在具有各自IP地址的多個容器中運(yùn)行。接下來,將它們公開到群集之外,以便可以訪問該應(yīng)用程序:

Kubectl.exe expose deployment helloworld-nginx --port=80 --type=NodePort

通過kubectl get services命令進(jìn)行驗證。這將返回NodePort的服務(wù)類型,以在Kubernetes集群的每個節(jié)點(diǎn)上公開端口80。該服務(wù)是一個抽象層,基本上可以實現(xiàn)負(fù)載平衡,并在共享IP地址的群集中對一個以上的pod進(jìn)行分組。

在Windows 10上創(chuàng)建單節(jié)點(diǎn)的Kubernetes實施示例

要在Web瀏覽器中打開此應(yīng)用程序,請創(chuàng)建一個代理以將本地端口連接到群集端口,我們在上一步中使用NodePort服務(wù)公開了該端口:

kubectl.exe port-forward svc/helloworld-nginx 80:80

如下所示:

在Windows 10上創(chuàng)建單節(jié)點(diǎn)的Kubernetes實施示例

轉(zhuǎn)到Web瀏覽器并打開http://127.0.0.1/或http://localhost/以查看在Kubernetes容器中部署的Nginx Web服務(wù)器的主頁。

測試Kubernetes控制平面

最后,測試Kubernetes控制平面或主服務(wù)器是否能夠維持節(jié)點(diǎn)服務(wù)器上運(yùn)行的Pod的所需狀態(tài)。要檢查這一點(diǎn),請使用以下命令來強(qiáng)制刪除運(yùn)行該應(yīng)用程序?qū)嵗囊粋€容器:

kubectl.exe delete pod helloworld-nginx-67bb76cf46-mks6j

識別出這種不希望的狀態(tài),Kubernetes將立即在容器中運(yùn)行該應(yīng)用程序的新實例:

在Windows 10上創(chuàng)建單節(jié)點(diǎn)的Kubernetes實施示例

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • WINDOWS
    +關(guān)注

    關(guān)注

    4

    文章

    3612

    瀏覽量

    91373
  • kubernetes
    +關(guān)注

    關(guān)注

    0

    文章

    245

    瀏覽量

    9063
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    樹莓派部署 Kubernetes:通過 UDM Pro 實現(xiàn) BGP 負(fù)載均衡!

    最近,我將家庭實驗室的架構(gòu)核心切換為一組樹莓派。盡管樹莓派上運(yùn)行的Kubernetes發(fā)行版眾多,但在資源受限的設(shè)備運(yùn)行Kubernetes時,控制平面的開銷是一個常見挑戰(zhàn)
    的頭像 發(fā)表于 06-25 18:00 ?251次閱讀
    樹莓派部署 <b class='flag-5'>Kubernetes</b>:通過 UDM Pro 實現(xiàn) BGP 負(fù)載均衡!

    節(jié)點(diǎn)Elasticsearch+Filebeat+Kibana安裝指南

    節(jié)點(diǎn)Elasticsearch+Filebeat+Kibana安裝指南
    的頭像 發(fā)表于 05-21 11:06 ?354次閱讀
    <b class='flag-5'>單</b><b class='flag-5'>節(jié)點(diǎn)</b>Elasticsearch+Filebeat+Kibana安裝指南

    如何在FX3和FX10芯片運(yùn)行/實現(xiàn)USB 3.0批量流?

    實際不會接收到任何數(shù)據(jù),并且 FX10/FX3 端永遠(yuǎn)不會調(diào)用第二個流的 HBDMA 回調(diào)。 我們可以不同的 USB 控制器(Intel 和 ASMedia)、不同的操作系統(tǒng)(Window
    發(fā)表于 05-09 06:10

    Kubernetes Helm入門指南

    Helm 是 Kubernetes 的包管理工具,它允許開發(fā)者和系統(tǒng)管理員通過定義、打包和部署應(yīng)用程序來簡化 Kubernetes 應(yīng)用的管理工作。Helm 的出現(xiàn)是為了解決 Kuberne
    的頭像 發(fā)表于 04-30 13:42 ?2260次閱讀
    <b class='flag-5'>Kubernetes</b> Helm入門指南

    Kubernetes中部署MySQL集群

    一般情況下 Kubernetes 可以通過 ReplicaSet 以一個 Pod 模板創(chuàng)建多個 pod 副本,但是它們都是無狀態(tài)的,任何時候它們都可以被一個全新的 pod 替換。
    的頭像 發(fā)表于 03-18 16:22 ?281次閱讀
    <b class='flag-5'>Kubernetes</b>中部署MySQL集群

    飛凌嵌入式ElfBoard ELF 1板卡-字符驅(qū)動之自動創(chuàng)建節(jié)點(diǎn)

    例程代碼路徑:ELF 1開發(fā)板資料包\\03-例程源碼\\03-2 驅(qū)動例程源碼\\02_字符驅(qū)動\\mydevice-auto一節(jié)寫的驅(qū)動加載后,需要手動使用mknod命令/dev下創(chuàng)建
    發(fā)表于 03-18 09:48

    Kubernetes包管理工具Helm的安裝和使用

    Helm 可以幫助我們管理 Kubernetes 應(yīng)用程序 - Helm Charts 可以定義、安裝和升級復(fù)雜的 Kubernetes 應(yīng)用程序,Charts 包很容易創(chuàng)建、版本管理、分享和分布。
    的頭像 發(fā)表于 03-13 16:06 ?907次閱讀

    Kubernetes:構(gòu)建高效的容器化應(yīng)用平臺

    Kubernetes 作為容器編排的事實標(biāo)準(zhǔn),容器化應(yīng)用部署中發(fā)揮著關(guān)鍵作用。 搭建 Kubernetes 集群是應(yīng)用的基礎(chǔ)??梢允褂胟ubeadm工具快速搭建。
    的頭像 發(fā)表于 01-23 15:22 ?317次閱讀

    重新分配pod節(jié)點(diǎn)

    和kube-proxy; 由于apiserver被nginx代理,所以升級的時候需要操作操作nginx注釋升級節(jié)點(diǎn),避免帶來無法訪問的情況; 我們的master節(jié)點(diǎn)和node都是
    的頭像 發(fā)表于 01-02 09:17 ?470次閱讀
    重新分配pod<b class='flag-5'>節(jié)點(diǎn)</b>

    如何在windowsemulate不同操作系統(tǒng)

    一、虛擬化技術(shù)概述 虛擬化技術(shù)允許單個物理機(jī)器創(chuàng)建多個虛擬機(jī),每個虛擬機(jī)都可以運(yùn)行不同的操作系統(tǒng)。這使得我們可以Windows系統(tǒng)
    的頭像 發(fā)表于 12-05 15:50 ?850次閱讀

    Windows 10將于2025年終止免費(fèi)更新,微軟力推Windows 11

    ,屆時Windows 10用戶將無法再通過官方渠道獲取這些關(guān)鍵服務(wù)。 盡管微軟表示,停止更新后,用戶的Windows 10電腦仍可繼續(xù)正常
    的頭像 發(fā)表于 11-05 10:35 ?1695次閱讀

    使用XDC工具創(chuàng)建TMS320DM6446音頻編碼示例

    電子發(fā)燒友網(wǎng)站提供《使用XDC工具創(chuàng)建TMS320DM6446音頻編碼示例.pdf》資料免費(fèi)下載
    發(fā)表于 10-15 09:18 ?0次下載
    使用XDC工具<b class='flag-5'>創(chuàng)建</b>TMS320DM6446音頻編碼<b class='flag-5'>示例</b>

    使用Velero備份Kubernetes集群

    Velero 是 heptio 團(tuán)隊(被 VMWare 收購)開源的 Kubernetes 集群備份、遷移工具。
    的頭像 發(fā)表于 08-05 15:43 ?636次閱讀
    使用Velero備份<b class='flag-5'>Kubernetes</b>集群

    為什么無法ModusToolbox Eclipse IDE中創(chuàng)建OTA_over-Etherinet_STTPS示例?

    使用\"lcs-manager-cli -- add-all\" 命令將所有示例拉到此處后,無法 ModusToolbox Eclipse IDE 中創(chuàng)建 OTA_over-Etherinet_STTPS
    發(fā)表于 07-24 06:48

    如何使用Kubeadm命令PetaExpress Ubuntu系統(tǒng)安裝Kubernetes集群

    Kubernetes,通常縮寫為K8s,是一個開源的容器編排平臺,旨在自動化容器化應(yīng)用的部署、擴(kuò)展和管理。有了Kubernetes,您可以輕松地部署、更新和擴(kuò)展應(yīng)用,而無需擔(dān)心底層基礎(chǔ)設(shè)施。
    的頭像 發(fā)表于 07-15 13:31 ?1130次閱讀
    如何使用Kubeadm命令<b class='flag-5'>在</b>PetaExpress Ubuntu系統(tǒng)<b class='flag-5'>上</b>安裝<b class='flag-5'>Kubernetes</b>集群