欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

利用kubeadm在centos7中安装k8s单节点集群

程序员文章站 2022-03-07 11:09:30
...

1、关闭防火墙

systemctl stop firewalld
systemctl disable firewalld

2 禁用SELinux

setenforce 0

编辑文件/etc/selinux/config,将SELINUX修改为disabled,如下:

SELINUX=disabled

3 关闭系统Swap

Kubernetes 1.8开始要求关闭系统的Swap,如果不关闭,默认配置下kubelet将无法启动。方法一,通过kubelet的启动参数–fail-swap-on=false更改这个限制。方法二,关闭系统的Swap。

swapoff -a

修改/etc/fstab文件,注释掉SWAP的自动挂载,使用free -m确认swap已经关闭。

4 添加阿里源: 

    rm -rfv /etc/yum.repos.d/* #不想直接删除可先备份
    curl -o /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo

5 配置主机名:

     主要添加 master 那一行,master 前面的 ip 为本机 cnetos 系统 ip

     利用kubeadm在centos7中安装k8s单节点集群

6 配置内核参数,将桥接的IPv4流量传递到iptables的链:

    cat > /etc/sysctl.d/k8s.conf <<EOF
    net.bridge.bridge-nf-call-ip6tables = 1
    net.bridge.bridge-nf-call-iptables = 1
    EOF
    sysctl --system

7 安装常用包

     使用命令yum install vim bash-completion net-tools gcc -y

8 使用阿里云源安装docker-ce:

    yum install -y yum-utils device-mapper-persistent-data lvm2
    yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
    yum -y install docker-ce

9 添加阿里云仓库加速器:

    mkdir -p /etc/docker
    tee /etc/docker/daemon.json <<-'EOF'
    {
      "registry-mirrors": ["https://fl791z1h.mirror.aliyuncs.com"]
    }
    EOF
    systemctl daemon-reload
    systemctl restart docker

10 安装kubelet kubectl kubeadm:

添加阿里云源

    cat <<EOF > /etc/yum.repos.d/kubernetes.repo
    [kubernetes]
    name=Kubernetes
    baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
    enabled=1
    gpgcheck=1
    repo_gpgcheck=1
    gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
    EOF

安装:

    yum install kubectl-1.8.0 kubelet kubeadm-1.8.0
    systemctl enable kubelet

初始化k8s集群:

使用下面的命令,其中我的 kubectl、kubeadm 及 kubelet 版本为 1.18.4,kubernetes-version 要用 1.18.0,1.18.4 在阿里云的仓库中不存在。 apiserver-advertiseaddress 为 master 的 ip 地址(即本机ip), 必须指定 image-repository,否则将由于从外网拉取镜像而导致失败。

kubeadm init --kubernetes-version=1.18.0 --apiserver-advertise-address=192.168.56.121  --image-repository registry.aliyuncs.com/google_containers --service-cidr=10.10.0.0/16 --pod-network-cidr=10.122.0.0/16

11 初始化成功后根据提示创建 kubectl:

    mkdir -p $HOME/.kube
    sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
    sudo chown $(id -u):$(id -g) $HOME/.kube/config

    使 kubectl 可以自动补充:

    source <(kubectl completion bash)

12 查看 node 及 pod

发现 master 节点状态为 NotReady,原因是 corednspod 没有启动,缺少网络 pod

    kubectl get node
    kubectl get pod --all-namespace

13    安装 calico 网络:

执行如下命令,完成后再次查看 node 发现 master 变为 Ready,至此,k8s 单机部署完成。

1、下载配置文件

wget https://docs.projectcalico.org/v3.8/getting-started/kubernetes/installation/hosted/kubernetes-datastore/calico-networking/1.7/calico.yaml

2、安装

kubectl create -f calico.yaml
 

注意:

重新执行kubeadm init 后一定要执行以下命令:

rm -rf $HOME/.kube  

mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config