이 가이드에서는 Kind, Metallb 및 Ingress를 사용하여 Kubernetes에 전체 스택 채팅 애플리케이션을 배포하기 위한 단계별 지침을 제공합니다. 이는 개발자가 VPS(가상 사설 서버)에서 컨테이너화된 애플리케이션을 호스팅하기 위한 강력한 Kubernetes 클러스터를 설정하는 데 도움을 주기 위해 설계되었습니다.
배포에는 필수 Kubernetes 도구 설정, 로드 밸런서 구성, 보안 통신을 위한 SSL 통합, 프런트엔드 및 백엔드 서비스 배포가 포함됩니다. 또한 선택적 섹션에서는 향상된 관찰 가능성 및 성능 추적을 위해 Prometheus 및 Grafana를 사용하여 애플리케이션을 모니터링하는 방법을 다룹니다.
프로덕션을 위해 채팅 애플리케이션을 배포하든 Kubernetes 기능을 탐색하든 관계없이 이 가이드는 애플리케이션을 효율적으로 시작하고 실행하기 위한 포괄적인 로드맵 역할을 할 것입니다.
아래 표는 특정 도구 설치 섹션으로 빠르게 이동하는 데 도움이 됩니다.
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 최소 필요
? 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 ] && 컬 -Lo ./kind https://kind.sigs.k8s.io/dl/v0.26.0/kind-linux-amd64
이 스크립트를 실행하면 kubectl과 친절한 환경이 생성됩니다.
종류 설치 자세한 정보
?️ KIND 클러스터 설정
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
[!참고]
여기에 Ingress 실행을 위한 extraPortMappings를 추가합니다
? Metallb 설치
[!참고]
LoadBalance를 사용하기 위해 Metallb를 사용하고 있습니다. kubernates loadBalance 기능을 제공하고 Metallb가 필요하지 않은 Aws/Azure/DigitalOcean 요법을 사용한다고 가정해 보겠습니다. 여기서는 현지 회사로부터 VPS를 구매합니다. VPS에 액세스하기 위해 하나의 IP 주소를 제공합니다.
kubectl apply -f https://raw.githubusercontent.com/metallb/metallb/v0.14.9/config/manifests/metallb-frr.yaml
Metallb 구성 확인
kubectl get all -n metallb-system
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 show 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 version
?? Cert Manager 설치 및 구성 || 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 폴더로 이동하시면 이 파일을 보실 수 있습니다
남페 공간 만들기
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.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 등의 모든 모니터링 앱을 제어하는 데 도움이 됩니다
설치
#!/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
이제 이 포트를 사용하여 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
사용자 이름
kubectl get nodes kubectl cluster-info
비밀번호
kubectl apply -f https://raw.githubusercontent.com/metallb/metallb/v0.14.9/config/manifests/metallb-frr.yaml
[!참고]
비밀번호를 변경할 수 있습니다
여기에서 다양한 유형의 알고리즘 대시보드를 선택할 수 있습니다
그게 다입니다. 즐거운 학습 :) .
[도움이 되었다면 저장소에 별점을 주실 수 있나요?]
프로젝트 Github 링크
https://github.com/kamruzzamanripon/k8-node-react-mongodb-app
위 내용은 Kind, Metallb 및 Ingress를 사용하여 Kubernetes에 채팅 앱 배포의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!