Kubernetes菜鳥教程詳解

一、Kubernetes介紹

Kubernetes(簡稱K8s)是一個自動化容器部署、容器調度、以及容器集群管理的開源平台,通過提供API接口,實現容器應用程序部署、服務擴展、故障恢復、自動化操作、彈性伸縮等功能。它由谷歌公司開發並捐贈給雲原生基金會(CNCF),目前已成為容器應用程序部署和管理領域的事實標準。

Kubernetes提供了豐富的功能,包括:

1、容器的自動部署和伸縮

2、自動化容器應用程序的發布和滾動更新

3、自動化容器應用程序的健康檢查和故障修復

4、容器存儲與網絡的自動化管理

二、Kubernetes架構

Kubernetes的架構非常複雜,主要包括以下幾個核心組件:

1、Master:Kubernetes集群的控制中心,負責集群中的任務調度、服務發現、故障恢復等任務。

2、Node:Kubernetes集群中的工作節點,負責執行Master分配的任務。

3、Pod:是Kubernetes中的最小部署單元,是一個由一個或多個容器組成的集合。

4、Service:用於實現Pod集合的網絡服務,它為Pod集合提供了一個固定的IP地址和端口號。

5、Replication Controller:用於自動對Pod進行副本管理和彈性伸縮。

6、Label:用於對Pod、Service等對象進行標記,用於篩選和管理對象。

三、Kubernetes安裝

Kubernetes的安裝方式有多種,官方提供了多種方式的安裝文檔,如:通過二進制文件安裝、通過Kubeadm安裝、通過Minikube安裝等。本文介紹基於Kubeadm安裝的方法。

1、安裝Docker和Kubeadm

// 安裝Docker
$ apt-get update && apt-get install -y apt-transport-https ca-certificates curl software-properties-common
$ curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
$ add-apt-repository "deb [arch=amd64] https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"
$ apt-get update && apt-get install -y docker-ce=18.06.2~ce~3-0~ubuntu

// 安裝Kubeadm
$ apt-get install -y apt-transport-https curl
$ curl -s https://mirrors.aliyun.com/kubernetes/apt/doc/apt-key.gpg | apt-key add -
$ cat </etc/apt/sources.list.d/kubernetes.list
deb https://mirrors.aliyun.com/kubernetes/apt/ kubernetes-xenial main
EOF
$ apt-get update && apt-get install -y kubelet=1.19.11-00 kubeadm=1.19.11-00 kubectl=1.19.11-00

2、創建Kubernetes集群

$ kubeadm init --image-repository registry.aliyuncs.com/google_containers --kubernetes-version 1.19.11 --pod-network-cidr=10.244.0.0/16

3、加入節點

$ kubeadm join ...

四、Kubernetes入門

Kubernetes入門分為以下幾個步驟:

1、創建Deployment

apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
spec:
  selector:
    matchLabels:
      app: nginx
  replicas: 2
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:1.14.2
        ports:
        - containerPort: 80

2、創建Service

apiVersion: v1
kind: Service
metadata:
  name: nginx-service
spec:
  selector:
    app: nginx
  ports:
  - protocol: TCP
    port: 80
    targetPort: 80
  type: ClusterIP

3、使用瀏覽器訪問Service的ClusterIP地址即可訪問到Nginx應用

五、Kubernetes擴展

Kubernetes提供了多種擴展機制,如策略擴展、資源擴展、API擴展等。其中策略擴展是最常用的擴展機制之一,通過策略擴展可以實現對Pod、Service等對象的訪問控制、網絡策略、限流等功能。

下面是一個簡單的網絡策略實現:

1、創建網絡策略

apiVersion: networking.k8s.io/v1
kind: NetworkPolicy
metadata:
  name: allow-paid-service
spec:
  podSelector:
    matchLabels:
      app: paid-service
  ingress:
    - from:
      - podSelector:
          matchLabels:
            tier: frontend
  policyTypes:
  - Ingress

2、添加標籤

$ kubectl label pods paid-service tier=backend
$ kubectl label pods frontend tier=frontend

六、Kubernetes應用部署

Kubernetes應用程序的部署可以通過多種方式實現,如Kubectl、Helm、Jenkins等工具。下面介紹一種簡單的基於Kubectl的部署方式:

1、創建Deployment

$ kubectl create deployment nginx --image=nginx

2、創建Service

$ kubectl expose deployment/nginx --port=80 --type=NodePort

3、通過瀏覽器訪問NodePort即可訪問Nginx應用

七、參考資料

1、官方文檔:https://kubernetes.io/docs/home/

2、Kubernetes中文社區:https://www.kubernetes.org.cn/

3、Kubernetes教程:https://www.runoob.com/kubernetes/kubernetes-tutorial.html

原創文章,作者:AWIJR,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/349313.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
AWIJR的頭像AWIJR
上一篇 2025-02-15 17:09
下一篇 2025-02-15 17:09

相關推薦

  • MQTT使用教程

    MQTT是一種輕量級的消息傳輸協議,適用於物聯網領域中的設備與雲端、設備與設備之間的數據傳輸。本文將介紹使用MQTT實現設備與雲端數據傳輸的方法和注意事項。 一、準備工作 在使用M…

    編程 2025-04-29
  • Python3.6.5下載安裝教程

    Python是一種面向對象、解釋型計算機程序語言。它是一門動態語言,因為它不會對程序員提前聲明變量類型,而是在變量第一次賦值時自動識別該變量的類型。 Python3.6.5是Pyt…

    編程 2025-04-29
  • Deepin系統分區設置教程

    本教程將會詳細介紹Deepin系統如何進行分區設置,分享多種方式讓您了解如何規劃您的硬盤。 一、分區的基本知識 在進行Deepin系統分區設置之前,我們需要了解一些基本分區概念。 …

    編程 2025-04-29
  • 寫代碼新手教程

    本文將從語言選擇、學習方法、編碼規範以及常見問題解答等多個方面,為編程新手提供實用、簡明的教程。 一、語言選擇 作為編程新手,選擇一門編程語言是很關鍵的一步。以下是幾個有代表性的編…

    編程 2025-04-29
  • Qt雷達探測教程

    本文主要介紹如何使用Qt開發雷達探測程序,並展示一個簡單的雷達探測示例。 一、環境準備 在開始本教程之前,需要確保你的開發環境已經安裝Qt和Qt Creator。如果沒有安裝,可以…

    編程 2025-04-29
  • 猿編程python免費全套教程400集

    想要學習Python編程嗎?猿編程python免費全套教程400集是一個不錯的選擇!下面我們來詳細了解一下這個教程。 一、課程內容 猿編程python免費全套教程400集包含了從P…

    編程 2025-04-29
  • Python煙花教程

    Python煙花代碼在近年來越來越受到人們的歡迎,因為它可以讓我們在終端里玩煙花,不僅具有視覺美感,還可以通過代碼實現動畫和音效。本教程將詳細介紹Python煙花代碼的實現原理和模…

    編程 2025-04-29
  • 使用Snare服務收集日誌:完整教程

    本教程將介紹如何使用Snare服務收集Windows服務器上的日誌,並將其發送到遠程服務器進行集中管理。 一、安裝和配置Snare 1、下載Snare安裝程序並安裝。 https:…

    編程 2025-04-29
  • Python畫K線教程

    本教程將從以下幾個方面詳細介紹Python畫K線的方法及技巧,包括數據處理、圖表繪製、基本設置等等。 一、數據處理 1、獲取數據 在Python中可以使用Pandas庫獲取K線數據…

    編程 2025-04-28
  • Python語言程序設計教程PDF趙璐百度網盤介紹

    Python語言程序設計教程PDF趙璐百度網盤是一本介紹Python語言編程的入門教材,本文將從以下幾個方面對其進行詳細闡述。 一、Python語言的特點 Python語言屬於解釋…

    編程 2025-04-28

發表回復

登錄後才能評論