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
4) 환경설정2
sudo mkdir -p /etc/containerd
containerd config default | sudo tee /etc/containerd/config.toml > /dev/null
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) 확인해보기
kubelet --version
kubeadm version
kubectl version --output=yaml
인증서 발급
kubeadm certs check-expiration
image pull
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
watch kubectl get pods -n calico-system
kubectl get node
master node 연결
kubectl get node
kubectl describe node {node 이름} | grep Taints
kubectl taint nodes --all node-role.kubernetes.io/control-plane-
kubectl run hello-world --image=hello-world --restart=Never
kubectl get pod