K8s环境搭建
一、单节点安装k8s
SHTL 博客:https://www.shtlls.ltd
此文档中的4.有点问题,1.24.1版本按照此方法会报错,无法安装,1.18.4版本则能正常安装。
参考文档
1. 标准化环境
1、关闭防火墙
[root@DXC ~]# systemctl stop firewalld
[root@DXC ~]# systemctl disable firewalld
2、关闭swapoff
[root@DXC ~]# swapoff -a
关闭selinux
[root@DXC ~]# sed -i 's/^ *SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
[root@DXC ~]# setenforce 0
2. 设置iptable(注意一定要设置否则后面初始化的时候会报错)
[root@DXC ~]# cat <<EOF> /etc/sysctl.d/k8s.conf
> net.bridge.bridge-nf-call-ip6tables = 1
> net.bridge.bridge-nf-call-iptables = 1
> EOF
3. docker安装(已安装可忽略此步骤)
[root@DXC ~]# yum install -y yum-utils device-mapper-persistent-data lvm2
[root@DXC ~]# yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
[root@DXC ~]# rpm --import http://mirrors.aliyun.com/docker-ce/linux/centos/gpg
[root@DXC ~]# yum makecache fast
[root@DXC ~]# yum -y install docker-ce
[root@DXC ~]# systemctl start docker
[root@DXC ~]# systemctl status docker
[root@DXC ~]# systemctl enable docker
4. 安装kubectl
选择想安装的版本,可以在此查看:https://github.com/kubernetes/kubernetes/releases
del 此版本安装有问题 [root@DXC ~]# wget https://dl.k8s.io/v1.24.1/kubernetes-client-linux-amd64.tar.gz
[root@DXC ~]# wget https://dl.k8s.io/v1.18.4/kubernetes-client-linux-amd64.tar.gz
[root@DXC ~]# tar xf kubernetes-client-linux-amd64.tar.gz -C /usr/local/bin/
添加环境变量,新增配置
[root@DXC ~]# vim /etc/profile
export PATH="/usr/local/bin/kubernetes/client/bin/:$PATH"
重新加载
[root@DXC ~]# source /etc/profile
5. 安装minikube本地 k8s 运行环境
安装minikube: 参考url(https://minikube.sigs.k8s.io/docs/start/)
[root@DXC ~]# curl -Lo minikube https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64
[root@DXC ~]# chmod +x minikube
[root@DXC ~]# mv minikube /usr/local/bin/
安装k8s
[root@DXC ~]# curl -Lo minikube https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64
[切换到非root用户,且该用户在docker用户组下]启动minikube集群
[root@SHTL ~]# minikube start --driver=docker
如果k8s安装时报错的解决方法:yum install conntrack -y && yum install xdg-utils -y
打开控制面板
[root@DXC ~]# minikube dashboard
服务器上执行代理8001 到面板服务
并开放端口8001或关闭防火墙 ping IP地址 8001 通不通
[root@DXC ~]# kubectl proxy --address='0.0.0.0' --accept-hosts='^*$'
客户端浏览器上测试。
http://IP地址:8001/api/v1/namespaces/kubernetes-dashboard/services/http:kubernetes-dashboard:/proxy/#/overview?namespace=default
到此单节点的K8s搭建就完成了。
-
部署应用到集群中
可以参考:文档二
需要注意的是:如果k8s安装的不是在本地,而是其他的服务器,那么安装好之后本地是无法直接访问的,可以在安装的服务器上使用curl进行测试应用的访问。
二、常见问题及解决
1. minikube start --driver=docker启动失败
可参考上面链接,我之前遇到的是执行命令:
yum install -y socat
就行
2. 创建的pod status始终是 ContainerCreating
解决方法:查看/etc/docker/certs.d/registry.access.redhat.com/redhat-ca.crt(该链接就是上图中的说明) 是一个软链接,但是链接过去后并没有真实的/etc/rhsm,所以需要使用yum安装:
yum install *rhsm*
安装完成后,执行一下dockerpull registry.access.redhat.com/rhel7/pod-infrastructure:latest
然后再通过: kubectl get pod 就会发现pod status已经变成 Running 了