使用 Kind、Metalb 和 Ingress 在 Kubernetes 上部署聊天應用程式
本指南提供了使用 Kind、Metalb 和 Ingress 在 Kubernetes 上部署全端聊天應用程式的逐步說明。它旨在幫助開發人員建立強大的 Kubernetes 集群,以便在虛擬專用伺服器 (VPS) 上託管容器化應用程式。
部署包括設定基本的 Kubernetes 工具、配置負載平衡器、整合 SSL 以實現安全通訊以及部署前端和後端服務。此外,可選部分涵蓋使用 Prometheus 和 Grafana 監控應用程序,以增強可觀察性和效能追蹤。
無論您是部署用於生產的聊天應用程式還是探索 Kubernetes 功能,本指南都將作為一個全面的路線圖,幫助您的應用程式高效啟動和運行。
? k8s 入門
下表可協助您快速導覽至特定的工具安裝部分。
Tech stack | Installation |
---|---|
Docker | Install and configure Docker |
Kind & Kubectl | Install and configure Kind & Kubectl |
Metallb | Install Metallb |
Ingress | Install and configure Ingress |
Helm | Helm Install and configure |
SSL Certificate | Install and configure Cert Manager |
Project Deploy | Project Deploy and Others |
Monitoring | Namespace Create for Groping Prometheus and grafana and Other |
Prometheus | Install and configure Prometheus |
Grafana | Install and configure Grafana |
?實施該計畫的先決條件:
[!注意]
vps 最低需求
- 記憶體 - 4GB
- CPU - 2 核
- 儲存 - 20 GB
- 一個域
? Docker安裝與設定
sudo apt-get update sudo apt-get install docker.io -y sudo usermod -aG docker $USER && newgrp docker
? Kind 和 Kubectl 安裝與設定
使用提供的腳本安裝 KIND 和 kubectl。建立 kind_kubectl_config.yaml 檔案:
#!/bin/bash # For AMD64 / x86_64 [ $(uname -m) = x86_64 ] && curl -Lo ./kind https://kind.sigs.k8s.io/dl/v0.26.0/kind-linux-amd64 chmod +x ./kind sudo cp ./kind /usr/local/bin/kind VERSION="v1.31.0" URL="https://dl.k8s.io/release/${VERSION}/bin/linux/amd64/kubectl" INSTALL_DIR="/usr/local/bin" curl -LO "$URL" chmod +x kubectl sudo mv kubectl $INSTALL_DIR/ kubectl version --client rm -f kubectl rm -rf kind echo "kind & kubectl installation complete."
./kind_kubectl_config.yaml
[!注意]
如果您的Vps ARM64 則使用此[ $(uname -m) = x86_64 ] && curl -Lo ./kind https://kind.sigs.k8s.io/dl/v0.26.0/kind-linux- amd64
運行這個腳本,它會創建 kubectl 和友善的環境。
請安裝更多資訊
?️ 設定 KIND 叢集
建立 kind-cluster-config.yaml 檔案:
kind: Cluster apiVersion: kind.x-k8s.io/v1alpha4 nodes: - role: control-plane image: kindest/node:v1.31.2 - role: worker image: kindest/node:v1.31.2 - role: worker image: kindest/node:v1.31.2 extraPortMappings: - containerPort: 80 hostPort: 80 protocol: TCP - containerPort: 443 hostPort: 443 protocol: TCP
使用設定檔建立叢集:
kind create cluster --config kind-cluster-config.yaml --name my-kind-cluster
驗證叢集:
kubectl get nodes kubectl cluster-info
[!注意]
這裡我增加了額外的PortMappings來運行Ingress
? Metallb 安裝
[!注意]
我正在使用 Metallb 來使用 LoadBalance。假設您使用的是 Aws/Azure/DigitalOcean 等,它們提供 kubernates loadBalance 設施,然後不需要 Metallb。這裡我從一家本地公司購買VPS。他們提供一個 IP 位址來存取 VPS。
kubectl apply -f https://raw.githubusercontent.com/metallb/metallb/v0.14.9/config/manifests/metallb-frr.yaml
檢查 Metallb 設定
kubectl get all -n metallb-system
?️ 建立 Metallb_config.yaml 檔案:
apiVersion: metallb.io/v1beta1 kind: IPAddressPool metadata: name: first-pool namespace: metallb-system spec: addresses: - 160.191.163.33-160.191.163.33
套用 metallb_config.yaml 檔案
kubectl apply -f metallb_config.yaml
[!注意]
我的 VPS IP 位址是 160.191.163.33。根據您的要求更改此 IP
♻️ Ingress 安裝與設定
kubectl apply -f https://kind.sigs.k8s.io/examples/ingress/deploy-ingress-nginx.yaml
[!注意]
這裡 service/ingress-nginx-controller 顯示 EXTERNAL-IP 是您的 VPS IP。我的VPS IP是160.191.163.33。它確保我們的 Metallb LoadBalance 正常工作。
? Helm 安裝與設定
curl -fsSL -o get_helm.sh https://raw.githubusercontent.com/helm/helm/main/scripts/get-helm-3 chmod 700 get_helm.sh ./get_helm.sh
檢查 Helm 版本
helm version
?? 安裝與設定憑證管理員 || SSL 憑證
sudo apt-get update sudo apt-get install docker.io -y sudo usermod -aG docker $USER && newgrp docker
安裝憑證管理員 CRD
#!/bin/bash # For AMD64 / x86_64 [ $(uname -m) = x86_64 ] && curl -Lo ./kind https://kind.sigs.k8s.io/dl/v0.26.0/kind-linux-amd64 chmod +x ./kind sudo cp ./kind /usr/local/bin/kind VERSION="v1.31.0" URL="https://dl.k8s.io/release/${VERSION}/bin/linux/amd64/kubectl" INSTALL_DIR="/usr/local/bin" curl -LO "$URL" chmod +x kubectl sudo mv kubectl $INSTALL_DIR/ kubectl version --client rm -f kubectl rm -rf kind echo "kind & kubectl installation complete."
https://artifacthub.io/packages/helm/cert-manager/cert-manager
? 專案部署及其他
第一步
在您的 VPS 中複製以下項目
./kind_kubectl_config.yaml
第二步
進入k8s資料夾,可以看到這個檔案
第三步
創造 Nampe 空間
kind: Cluster apiVersion: kind.x-k8s.io/v1alpha4 nodes: - role: control-plane image: kindest/node:v1.31.2 - role: worker image: kindest/node:v1.31.2 - role: worker image: kindest/node:v1.31.2 extraPortMappings: - containerPort: 80 hostPort: 80 protocol: TCP - containerPort: 443 hostPort: 443 protocol: TCP
第四步
應用所有秘密文件
kind create cluster --config kind-cluster-config.yaml --name my-kind-cluster
第五步
清除 Mongodb 捲和其他
kubectl get nodes kubectl cluster-info
第六步
應用其他文件的其餘部分
kubectl apply -f https://raw.githubusercontent.com/metallb/metallb/v0.14.9/config/manifests/metallb-frr.yaml
第七步
設定SSL憑證域。開啟 ssl_certificate.yaml 並編輯您想要的網域名稱
套用 ssl_certificate.yaml 檔案
kubectl get all -n metallb-system
第八步
配置 Ingress 檔案。 開啟 ingress.yaml 並新增您所需的網域。
應用 ingress.yaml 檔案
apiVersion: metallb.io/v1beta1 kind: IPAddressPool metadata: name: first-pool namespace: metallb-system spec: addresses: - 160.191.163.33-160.191.163.33
檢查證書
檢查命名空間
kubectl apply -f metallb_config.yaml
?瀏覽器視圖
?結論
恭喜!您已成功部署 全端聊天應用程式 。現在您可以存取您的聊天應用程式。
? 監控及其他[可選]
現在我們正在做額外的功能,例如監控。它可以幫助您了解伺服器和應用程式。
建立命名空間
sudo apt-get update sudo apt-get install docker.io -y sudo usermod -aG docker $USER && newgrp docker
檢查命名空間
[!注意]
這個命名空間有助於控制所有監控應用程序,例如 Prometheus、Grafana、Loki 等
Prometheus 和 Grafana 安裝和配置
安裝
#!/bin/bash # For AMD64 / x86_64 [ $(uname -m) = x86_64 ] && curl -Lo ./kind https://kind.sigs.k8s.io/dl/v0.26.0/kind-linux-amd64 chmod +x ./kind sudo cp ./kind /usr/local/bin/kind VERSION="v1.31.0" URL="https://dl.k8s.io/release/${VERSION}/bin/linux/amd64/kubectl" INSTALL_DIR="/usr/local/bin" curl -LO "$URL" chmod +x kubectl sudo mv kubectl $INSTALL_DIR/ kubectl version --client rm -f kubectl rm -rf kind echo "kind & kubectl installation complete."
透過連接埠運行 Prometheus
./kind_kubectl_config.yaml
現在您可以使用此連接埠存取 Prometheus。喜歡
kind: Cluster apiVersion: kind.x-k8s.io/v1alpha4 nodes: - role: control-plane image: kindest/node:v1.31.2 - role: worker image: kindest/node:v1.31.2 - role: worker image: kindest/node:v1.31.2 extraPortMappings: - containerPort: 80 hostPort: 80 protocol: TCP - containerPort: 443 hostPort: 443 protocol: TCP
[!注意]
更改IP位址
Grafana 安裝與設定
透過連接埠運行 Grafana
kind create cluster --config kind-cluster-config.yaml --name my-kind-cluster
取得 Grafana 使用者名稱和密碼
使用者名稱
kubectl get nodes kubectl cluster-info
密碼
kubectl apply -f https://raw.githubusercontent.com/metallb/metallb/v0.14.9/config/manifests/metallb-frr.yaml
[!注意]
您可以更改密碼
Grafana 儀表板。
在這裡您可以選擇不同類型的演算法儀表板
僅此而已。快樂學習:) .
[如果有幫助,給儲存庫一個星星? ]
專案 Github 連結
https://github.com/kamruzzamanripon/k8-node-react-mongodb-app
以上是使用 Kind、Metalb 和 Ingress 在 Kubernetes 上部署聊天應用程式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Python更適合初學者,學習曲線平緩,語法簡潔;JavaScript適合前端開發,學習曲線較陡,語法靈活。 1.Python語法直觀,適用於數據科學和後端開發。 2.JavaScript靈活,廣泛用於前端和服務器端編程。

JavaScript在Web開發中的主要用途包括客戶端交互、表單驗證和異步通信。 1)通過DOM操作實現動態內容更新和用戶交互;2)在用戶提交數據前進行客戶端驗證,提高用戶體驗;3)通過AJAX技術實現與服務器的無刷新通信。

JavaScript在現實世界中的應用包括前端和後端開發。 1)通過構建TODO列表應用展示前端應用,涉及DOM操作和事件處理。 2)通過Node.js和Express構建RESTfulAPI展示後端應用。

理解JavaScript引擎內部工作原理對開發者重要,因為它能幫助編寫更高效的代碼並理解性能瓶頸和優化策略。 1)引擎的工作流程包括解析、編譯和執行三個階段;2)執行過程中,引擎會進行動態優化,如內聯緩存和隱藏類;3)最佳實踐包括避免全局變量、優化循環、使用const和let,以及避免過度使用閉包。

Python和JavaScript在開發環境上的選擇都很重要。 1)Python的開發環境包括PyCharm、JupyterNotebook和Anaconda,適合數據科學和快速原型開發。 2)JavaScript的開發環境包括Node.js、VSCode和Webpack,適用於前端和後端開發。根據項目需求選擇合適的工具可以提高開發效率和項目成功率。

C和C 在JavaScript引擎中扮演了至关重要的角色,主要用于实现解释器和JIT编译器。1)C 用于解析JavaScript源码并生成抽象语法树。2)C 负责生成和执行字节码。3)C 实现JIT编译器,在运行时优化和编译热点代码,显著提高JavaScript的执行效率。

JavaScript在網站、移動應用、桌面應用和服務器端編程中均有廣泛應用。 1)在網站開發中,JavaScript與HTML、CSS一起操作DOM,實現動態效果,並支持如jQuery、React等框架。 2)通過ReactNative和Ionic,JavaScript用於開發跨平台移動應用。 3)Electron框架使JavaScript能構建桌面應用。 4)Node.js讓JavaScript在服務器端運行,支持高並發請求。

Python更適合數據科學和自動化,JavaScript更適合前端和全棧開發。 1.Python在數據科學和機器學習中表現出色,使用NumPy、Pandas等庫進行數據處理和建模。 2.Python在自動化和腳本編寫方面簡潔高效。 3.JavaScript在前端開發中不可或缺,用於構建動態網頁和單頁面應用。 4.JavaScript通過Node.js在後端開發中發揮作用,支持全棧開發。
