在CentOS上部署Kubernetes(k8s)集群时,网络配置是一个关键步骤。以下是详细的网络配置步骤:
环境准备:
关闭防火墙:
systemctl stop firewalld
systemctl disable firewalld
关闭SELinux:
setenforce 0
sed -i 's/enforcing/disabled/' /etc/selinux/config
禁用交换分区:
swapoff -a
sed -i '/swap/s///#/' /etc/fstab
配置静态IP:
/etc/sysconfig/network-scripts/ifcfg-eth0
,将其中的 BOOTPROTO
设置为 static
,并添加所需的IP地址、子网掩码、网关和DNS服务器信息。IPADDR=192.168.0.100
NETMASK=255.255.255.0
GATEWAY=192.168.0.1
DNS1=8.8.8.8
DNS2=8.8.4.4
ONBOOT=yes
systemctl restart network
配置主机名:
hostnamectl
命令设置主机名,例如:hostnamectl set-hostname k8s-master
配置 /etc/hosts
文件:
/etc/hosts
文件,添加集群中所有节点的IP地址和主机名:192.168.0.100 k8s-master
192.168.0.101 k8s-node1
192.168.0.102 k8s-node2
安装网络插件:
wget https://docs.projectcalico.org/manifests/calico.yaml
kubectl apply -f calico.yaml
初始化Kubernetes集群:
kubeadm init
命令来初始化集群。这将配置API服务器、控制器管理器和调度器。kubeadm init --apiserver-advertise-address <Master_IP> --image-repository registry.aliyuncs.com/google_containers --kubernetes-version <Kubernetes_Version> --service-cidr <Service_CIDR> --pod-network-cidr <Pod_Network_CIDR>
配置 kubectl
:
kubeconfig
文件复制到本地,以便可以使用 kubectl
命令管理集群。mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
加入工作节点:
kubeadm join
命令,使用Master节点提供的命令加入集群。kubeadm join <Master_IP>:6443 --token <Token> --discovery-token-ca-cert-hash sha256:<Hash>
以上步骤是在CentOS上配置Kubernetes网络的基本流程。根据具体需求,可能还需要进行其他网络相关的配置,例如设置VLAN、配置DHCP等。此外,确保所有节点的时间同步也很重要,可以使用NTP服务进行时间同步。