centos

如何自定义centos上的k8s部署配置

小樊
50
2025-06-20 16:50:49
栏目: 智能运维

在CentOS上自定义Kubernetes(k8s)部署配置涉及多个步骤,包括环境准备、安装必要的软件、配置网络、初始化Kubernetes集群等。以下是一个详细的步骤指南,帮助你根据具体需求自定义部署配置:

环境准备

  1. 关闭防火墙

    systemctl stop firewalld
    systemctl disable firewalld
    
  2. 关闭SELinux

    setenforce 0
    sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
    
  3. 禁用交换分区

    swapoff -a
    sed -i 's/.*swap.*/#&/' /etc/fstab
    
  4. 设置主机名

    hostnamectl set-hostname k8s-master
    
  5. 配置主机名解析: 编辑 /etc/hosts 文件,添加所有节点的IP和对应主机名。

  6. 配置网络参数: 创建 /etc/sysctl.d/k8s.conf 文件,添加以下内容:

    net.bridge.bridge-nf-call-ip6tables = 1
    net.bridge.bridge-nf-call-iptables = 1
    net.ipv4.ip_forward = 1
    

    然后应用配置:

    sysctl --system
    
  7. 时间同步

    yum install ntpdate -y
    ntpdate time.windows.com
    

安装Docker

  1. 添加Docker镜像源

    curl -o /etc/yum.repos.d/docker-ce.repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
    
  2. 安装Docker

    yum install -y docker-ce docker-ce-cli containerd.io
    systemctl enable docker && systemctl start docker
    

安装Kubernetes组件

  1. 添加Kubernetes镜像源

    cat <<EOF > /etc/yum.repos.d/kubernetes.repo
    [kubernetes]
    name=Kubernetes
    baseurl=https://mirrors.aliyuncs.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
    enabled=1
    gpgcheck=0
    repo_gpgcheck=0
    gpgkey=https://mirrors.aliyuncs.com/kubernetes/yum/doc/yum-key.gpg
    EOF
    
  2. 安装kubeadm、kubelet和kubectl

    yum install -y kubelet kubeadm kubectl
    systemctl enable kubelet && systemctl start kubelet
    

初始化Kubernetes集群

  1. 初始化Master节点

    kubeadm init --apiserver-advertise-address <master-ip> --image-repository registry.aliyuncs.com/google_containers --kubernetes-version <k8s-version> --service-cidr <service-cidr> --pod-network-cidr <pod-network-cidr>
    
  2. 配置kubectl

    mkdir -p $HOME/.kube
    sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
    sudo chown $(id -u):$(id -g) $HOME/.kube/config
    
  3. 添加Worker节点: 在Master节点获取Join命令:

    kubeadm token create --print-join-command
    

    在Worker节点上执行Join命令:

    kubeadm join <master-ip>:6443 --token <token> --discovery-token-ca-cert-hash sha256:<hash>
    

部署CNI网络插件

  1. 安装Calico
    kubectl apply -f https://docs.projectcalico.org/manifests/calico.yaml
    

验证部署

  1. 检查节点状态

    kubectl get nodes
    
  2. 检查所有Pods是否正常运行

    kubectl get pods --all-namespaces
    

以上步骤涵盖了在CentOS上配置Kubernetes集群的基本流程。请根据实际需求和环境调整细节,例如选择不同的CNI插件、调整内核参数等。建议参考最新的官方文档或教程以确保部署成功。

0
看了该问题的人还看了