kubernetics 설치

yoon__0_0·2024년 6월 4일
0

이어드림 수업

목록 보기
59/103

1) 설치 명령어(ec2 환경)

sudo modprobe br_netfilter
sudo sysctl net.bridge.bridge-nf-call-iptables=1
sudo sysctl net.ipv4.ip_forward=1

2) 환경설정

sudo vim /etc/sysctl.conf

# 이 파일에서 제일 밑에 추가할것들 
net.bridge.bridge-nf-call-iptables=1
net.ipv4.ip_forward=1

3) 메모리 환경 확인

free -h
cat /proc/swaps
  • 두개 모두 0이나 아무것도 나오지 말아야함.

4) 환경설정2

sudo mkdir -p /etc/containerd

containerd config default | sudo tee /etc/containerd/config.toml > /dev/null
  • /etc/containerd/config.toml 에 systemdCgroup을 true 로변경시켜주기
  • 파일속으로 들어가기
sudo vim /etc/containerd/config.toml

5) 재시작

sudo systemctl restart containerd
sudo systemctl enable containerd
sudo systemctl status containerd

-> containerd만 쿠버네틱스에서 활용함.

6) 설치

sudo apt-get update
sudo apt-get install -y apt-transport-https ca-certificates curl

7) 디렉토리 추가

sudo mkdir -p /etc/apt/keyrings

8) 쿠버네틱스 1.29 버전 설치 명령어

sudo curl -fsSL https://pkgs.k8s.io/core:/stable:/v1.29/deb/Release.key | sudo gpg --dearmor -o /etc/apt/keyrings/kubernetes-apt-keyring.gpg

echo "deb [signed-by=/etc/apt/keyrings/kubernetes-apt-keyring.gpg] https://pkgs.k8s.io/core:/stable:/v1.29/deb/ /" | sudo tee /etc/apt/sources.list.d/kubernetes.list

9) 업데이트

sudo apt-get update

10) 찐 설치

sudo apt-get install -y kubelet kubeadm kubectl

11) version 고정

sudo apt-mark hold kubelet kubeadm kubectl

12) 확인해보기

  • 3개 명령어 잘 나오면 된것 .
kubelet --version

kubeadm version

kubectl version --output=yaml

인증서 발급

  • 현재상태 => 모두 missing
kubeadm certs check-expiration


image pull

  • containerd를 소켓으로 하여 image를 가지고 오겠다. (sudo -i 로 들어가서 치기)
kubeadm config images pull --cri-socket /run/containerd/containerd.sock
kubeadm init --apiserver-advertise-address=프라이빗IP --pod-network-cidr=192.168.0.0/16 --cri-socket /run/containerd/containerd.sock

인증상태 다시 확인

kubeadm certs check-expiration

mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config

kubectl create -f https://raw.githubusercontent.com/projectcalico/calico/v3.28.0/manifests/tigera-operator.yaml
curl https://raw.githubusercontent.com/projectcalico/calico/v3.28.0/manifests/custom-resources.yaml -O
  • 아래 파일 생성됨을 알 수 있음
  • 만들기
kubectl create -f custom-resources.yaml
  • running 인지 확인하기
watch kubectl get pods -n calico-system

  • ready인지 확인
kubectl get node

  • control-plane : 마스터 노드

master node 연결

  • node 이름 확인
kubectl get node
  • Taints 확인
kubectl describe node {node 이름} | grep Taints

  • taint를 untaint로 만들어 줘야함 .
kubectl taint nodes --all node-role.kubernetes.io/control-plane-
  • 쿠버네틱스 시작해보기
kubectl run hello-world --image=hello-world --restart=Never

kubectl get pod

profile
신윤재입니다

0개의 댓글