1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
| # Install kubernetes master service
export MASTER_IP="10.0.0.10"
export POD_CIDR="192.168.0.0/16"
sudo kubeadm config images pull
sudo kubeadm init \
--apiserver-advertise-address=$MASTER_IP \
--apiserver-cert-extra-sans=$MASTER_IP \
--pod-network-cidr=$POD_CIDR \
--control-plane-endpoint=master-node01 \
--cri-socket /var/run/crio/crio.sock \
--ignore-preflight-errors 'Swap,CRI'
# Setup kubeconfig
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
# Install the network plugin
curl https://docs.projectcalico.org/manifests/calico.yaml -O
kubectl apply -f calico.yaml
# Expected output
kubectl get pods -A
NAMESPACE NAME READY STATUS RESTARTS AGE
kube-system calico-kube-controllers-7c845d499-dmlgt 1/1 Running 0 3m23s
kube-system calico-node-2pqd4 1/1 Running 0 3m23s
kube-system coredns-64897985d-89bqd 1/1 Running 0 18m
kube-system coredns-64897985d-xdbf7 1/1 Running 0 18m
kube-system etcd-ubuntu-focal 1/1 Running 0 18m
kube-system kube-apiserver-ubuntu-focal 1/1 Running 0 18m
kube-system kube-controller-manager-ubuntu-focal 1/1 Running 0 18m
kube-system kube-proxy-ln8qf 1/1 Running 0 18m
kube-system kube-scheduler-ubuntu-focal 1/1 Running 0 18m
kubectl get events --sort-by='.metadata.creationTimestamp' -A
# Then it is needed to join the worker nodes to this master worker
# you can see what is the current token
kubeadm token list
# if the token expired, after 24hrs, then generate a new one
kubeadm token create
# Label nodes!
kubectl label nodes k8s02 kubernetes.io/role=worker
|