利用kubeadm在centos7中安装k8s单节点集群
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
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
上一篇: centos7下用kubeadm安装k8s集群 ipvs
下一篇: https无需生成证书直接访问