-Control Plane
→ 사양 : cpu x 2, ram 2g
→ 포트 (inbound) : 6443, 2379-2380, 10250, 10259, 10257
→ 포트 확인 : nc 127.0.0.1 6443 -zv -w 2 → packet forwarding 설정 :
cat <<EOF | sudo tee /etc/sysctl.d/k8s.conf
net.ipv4.ip_forward = 1
EOF
: sudo sysctl --system
: sysctl net.ipv4.ip_forward
-진행순서
→ 패키지 업데이트 : sudo apt update && sudo apt upgrade -y
→ 스왑 비활성화 : sudo swapoff -a sudo sed -i '/swap/d' /etc/fstab
→ docker 혹은 containerd 설치 : sudo apt install containerd -y
→ containerd 기본 설정 : sudo mkdir -p /etc/containerd containerd config default | sudo tee /etc/containerd/config.toml
→ systemd cgroup 활성화 : sudo sed -i 's/SystemdCgroup = false/SystemdCgroup = true/' /etc/containerd/config.toml → containerd 재시작 : sudo systemctl restart containerd sudo systemctl enable containerd
→ 공개키 다운로드 : sudo mkdir -p /etc/apt/keyrings curl -fsSL https://pkgs.k8s.io/core:/stable:/v1.30/deb/Release.key | \ sudo gpg --dearmor -o /etc/apt/keyrings/kubernetes-apt.gpg
→ 신규 repo 추가 : echo "deb [signed-by=/etc/apt/keyrings/kubernetes-apt.gpg] \ https://pkgs.k8s.io/core:/stable:/v1.30/deb/ /" | \ sudo tee /etc/apt/sources.list.d/kubernetes.list
→ apt 업데이트 : sudo apt update
→ kubeadm / kubelet / kubectl 설치 : sudo apt install -y kubeadm kubelet kubectl sudo apt-mark hold kubeadm kubelet kubectl
→ kubeadm으로 control plane 초기화 (cni에 따라서 다름) : sudo kubeadm init --pod-network-cidr=192.168.0.0/16
→ 완료 메시지가 나오면 아래의 명령어를 실행 : mkdir -p $HOME/.kube sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config sudo chown $(id -u):$(id -g) $HOME/.kube/config
→ 네트워크 플러그인 설치(calico CNI) : kubectl apply -f https://raw.githubusercontent.com/projectcalico/calico/v3.28.0/manifests/calico.yaml : 설치시 vm자체의 방화벽 혹은 nsg같은 곳에서 6443 포트가 허용이 되어 있는지 확인 필요
→ 그래도 안되면 아래의 명령어를 입력 : mkdir -p $HOME/.kube
sudo cp /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
export KUBECONFIG=$HOME/.kube/config
→ calico가 정상적으로 설치가 되었는지 확인 : kubectl get pods -n kube-system
→ 각 노드가 Ready 상태가 되었는지 확인 : kubectl get nodes
→ 전체 흐름 요약 :
- VM 준비 (고정 IP / 포트 개방)
- containerd 설치
- kubeadm, kubelet, kubectl 설치
- kubeadm init 실행 → Control Plane 생성
- ~/.kube/config 복사
- CNI(flannel or calico) 설치
- 클러스터 정상 확인
- Worker join
'ops > kubernetes' 카테고리의 다른 글
| kubernetes 설정 - 5 (워커노드 설정) (0) | 2025.11.27 |
|---|---|
| kubernetes 설정 - 4 (클라이언트와 kubernetes 클러스터 연결하기) (0) | 2025.11.27 |
| kubernetes 설정 - 3 (kubectl 설치하기) (0) | 2025.11.26 |
| kubernetes 설정 - 2(join token 설정) (0) | 2025.11.26 |
| [Kubernetes] Command - "kubectl port-forward" (0) | 2024.06.21 |