本指南提供了使用 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中文网其他相关文章!

JavaScript字符串替换方法详解及常见问题解答 本文将探讨两种在JavaScript中替换字符串字符的方法:在JavaScript代码内部替换和在网页HTML内部替换。 在JavaScript代码内部替换字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 该方法仅替换第一个匹配项。要替换所有匹配项,需使用正则表达式并添加全局标志g: str = str.replace(/fi

因此,在这里,您准备好了解所有称为Ajax的东西。但是,到底是什么? AJAX一词是指用于创建动态,交互式Web内容的一系列宽松的技术。 Ajax一词,最初由Jesse J创造

10款趣味横生的jQuery游戏插件,让您的网站更具吸引力,提升用户粘性!虽然Flash仍然是开发休闲网页游戏的最佳软件,但jQuery也能创造出令人惊喜的效果,虽然无法与纯动作Flash游戏媲美,但在某些情况下,您也能在浏览器中获得意想不到的乐趣。 jQuery井字棋游戏 游戏编程的“Hello world”,现在有了jQuery版本。 源码 jQuery疯狂填词游戏 这是一个填空游戏,由于不知道单词的上下文,可能会产生一些古怪的结果。 源码 jQuery扫雷游戏

本教程演示了如何使用jQuery创建迷人的视差背景效果。 我们将构建一个带有分层图像的标题横幅,从而创造出令人惊叹的视觉深度。 更新的插件可与JQuery 1.6.4及更高版本一起使用。 下载

本文讨论了在浏览器中优化JavaScript性能的策略,重点是减少执行时间并最大程度地减少对页面负载速度的影响。

本文演示了如何使用jQuery和ajax自动每5秒自动刷新DIV的内容。 该示例从RSS提要中获取并显示了最新的博客文章以及最后的刷新时间戳。 加载图像是选择

Matter.js是一个用JavaScript编写的2D刚体物理引擎。此库可以帮助您轻松地在浏览器中模拟2D物理。它提供了许多功能,例如创建刚体并为其分配质量、面积或密度等物理属性的能力。您还可以模拟不同类型的碰撞和力,例如重力摩擦力。 Matter.js支持所有主流浏览器。此外,它也适用于移动设备,因为它可以检测触摸并具有响应能力。所有这些功能都使其值得您投入时间学习如何使用该引擎,因为这样您就可以轻松创建基于物理的2D游戏或模拟。在本教程中,我将介绍此库的基础知识,包括其安装和用法,并提供一


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

ZendStudio 13.5.1 Mac
功能强大的PHP集成开发环境

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。

WebStorm Mac版
好用的JavaScript开发工具

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中