虚拟机ubuntu ens33没有inet_K8S集群安装(新手向-ubuntu版本)
修改注:删除了一些无用的踩坑和说明,优化调整了结构与版面环境部署准备四台虚拟机,安装ubuntu18.04版本配置网络环境以一台虚拟机为例,其他的等同首先确定虚拟机的设置正确(一般初始化就是这样不需要改动)配置主机的NAT模式具体参数这里写图片描述记住网关配置笔记本主机具体VMnet8本地地址参数:说明:下图中的IP地址随意设置,但是要保证不能跟你要设置虚拟机的固定IP一样。我设置的是:192.1
修改注:删除了一些无用的踩坑和说明,优化调整了结构与版面
环境部署
准备四台虚拟机,安装ubuntu18.04版本
配置网络环境
以一台虚拟机为例,其他的等同
首先确定虚拟机的设置正确(一般初始化就是这样不需要改动)
data:image/s3,"s3://crabby-images/cab04/cab042b176c0c7544e8efbf3efb7739656720556" alt="0f5d326d0a639586bd79b00de04b2f31.png"
配置主机的NAT模式具体参数
data:image/s3,"s3://crabby-images/2ed42/2ed42e4c840e54155fd4946439ae9548d351f969" alt="42ae0b01140db053d3b23dc2e8e1e3dd.png"
这里写图片描述
data:image/s3,"s3://crabby-images/48845/48845f32e950d9fdf7d16df85a4c2738552851ea" alt="bcb5fa7cc56dfa3b3432a99037e35dbc.png"
记住网关
data:image/s3,"s3://crabby-images/e2ae1/e2ae1506d69a7ef249e40cc55fa14655b0eab248" alt="5372877b9c06a98ff373cf6bf9beed55.png"
配置笔记本主机具体VMnet8本地地址参数:
data:image/s3,"s3://crabby-images/2b6c2/2b6c2230b146ebeece464d950b0aa8e039d0c8db" alt="8af49b4677971218ecf73b448a4fe7b3.png"
说明:下图中的IP地址随意设置,但是要保证不能跟你要设置虚拟机的固定IP一样。我设置的是:192.168.153.1
data:image/s3,"s3://crabby-images/58552/58552bc786d7f20c4bdc7c0793c23cbdfb69a7c0" alt="b70ec81c40d1b5989eb022209c64937a.png"
修改虚拟机中系统为固定ip的配置文件
虚拟机中启动命令行
sudo gedit /etc/netplan/01-network-manager-all.yaml
修改后为
# Let NetworkManager manage all devices on this system
network:
version: 2
renderer: NetworkManager
ethernets:
ens33: #配置的网卡名称,使用ifconfig -a查看得到
addresses: [192.168.153.101/24] #your ip for this vm
gateway4: 192.168.153.2 #the gateway set before
nameservers:
addresses: [192.168.153.2]
有个我卡住的很憨很憨的坑,新手注意每个属性冒号:后要有一个空格。
执行命令
sudo netplan apply
查询Ip地址后应该可以看到修改后的ip
可以选做,能够提高运行效率:
ubuntu关闭图形用户界面
sudo systemctl set-default multi-user.target sudo reboot
ubuntu启用图形用户界面
sudo systemctl set-default graphical.target sudo reboot
K8S安装
- 安装docker
sudo apt-get install docker.io
为了不在每次使用docker时都用root用户,就改一下它的group,让平民也可以用。
sudo usermod -aG docker $USER
正式启用Docker:
sudo systemctl start docker
sudo systemctl enable docker
2. 安装curl
sudo apt-get update
sudo apt install -y curl
sudo curl https://mirrors.aliyun.com/kubernetes/apt/doc/apt-key.gpg | apt-key add
如果出现This command can only be used by root.的错误,就切换到根目录
su: Authentication failure问题:sudo passwd root
3. 添加安装源
sudo apt-add-repository "deb https://mirrors.aliyun.com/kubernetes/apt/ kubernetes-xenial main"
#安装k8s的重要组件
sudo apt-get install kubeadm kubelet kubectl -y
设置主机名hostname
sudo hostnamectl set-hostname HOSTNAME #(用master,node1,node2替换)
修改host文件
sudo gedit /etc/hosts
127.0.0.1 localhost
127.0.1.1 ubuntu(改这里,改成master)
# The following lines are desirable for IPv6 capable hosts
::1 ip6-localhost ip6-loopback
fe00::0 ip6-localnet
ff00::0 ip6-mcastprefix
ff02::1 ip6-allnodes
ff02::2 ip6-allrouters
sudo swapoff -a
初始化master
sudo kubeadm init --image-repository registry.aliyuncs.com/google_containers --kubernetes-version v1.19.3 --pod-network-cidr=192.168.153.101/24
把ip换成自己在master设置的静态ip地址
报以下错误就要把虚拟机配置修改一下
[ERROR NumCPU]: the number of available CPUs 1 is less than the required 2
data:image/s3,"s3://crabby-images/eeaa8/eeaa8e3e0d4d553fc3fc07fe4ee7d5041a4b94dd" alt="f067579f0577e7e1905c8fdacd108154.png"
成功后
Your Kubernetes control-plane has initialized successfully!
To start using your cluster, you need to run the following as a regular user:
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
You should now deploy a pod network to the cluster.
Run "kubectl apply -f [podnetwork].yaml" with one of the options listed at:
https://kubernetes.io/docs/concepts/cluster-administration/addons/
Then you can join any number of worker nodes by running the following on each as root:
kubeadm join 192.168.153.101:6443 --token 51tl72.gt63iey7eq5xe8y8
--discovery-token-ca-cert-hash sha256:98a23691705d7a0d02589fdd05c5254ea5fe255e5b5084ff67ef386659bf640b
然后仅在master做下面的操作:
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
接下来仅在每个node上做下面的操作,即复制上个图片里的最后一行:
sudo kubeadm join 192.168.153.101:6443 --token rqhtn1.1e4cbbc6dg85krye
--discovery-token-ca-cert-hash sha256:e89f384ffda27cbed75a6c1d7975061b5232e472370ec4ce304fc7032b3e0234
成功
data:image/s3,"s3://crabby-images/8e7ee/8e7eed38cce98c698ea92eb018ecb66f15452dff" alt="d3b13a15b1426a64dfb17a5792835d2b.png"
遇到的一些坑:
node节点中遇到以下问题时:
- Unfortunately, an error has occurred:
timed out waiting for the condition
data:image/s3,"s3://crabby-images/f0bfb/f0bfb712d7d807184131af7de25cce2d6e5d472f" alt="ed288f5d3a6c68c1b5c4f83dee924300.png"
下面的方法没用
swapoff -a # will turn off the swap
kubeadm reset
systemctl daemon-reload
systemctl restart kubelet
iptables -F && iptables -t nat -F && iptables -t mangle -F && iptables -X # will reset iptables
解决方案:
重新安装系统。。。注意步骤是否出错。
最后在master中,查看部署状态:
kubectl get nodes
多等一会。。。。。很无语,找了半天方法解决notready的问题,结果过了一会自己好了。
data:image/s3,"s3://crabby-images/15765/157654f0b26c03f81406e103a7c454db47e71652" alt="9c89347e776cfef471a084a23652a948.png"
2. 出现了以上的错误之后,尝试以下方法//:
重启。
data:image/s3,"s3://crabby-images/54318/54318d36782f5ff32d3c8b291f82a6e481a6877b" alt="1cce1ab79ea961a2d437caec5a43c22e.png"
好了。。。。。。乌鸡鲅鱼
最后注释一下重启系统后应该输的命令:
sudo -i
swapoff -a
exit
strace -eopenat kubectl version
还有就是有个问题。。。虚拟机非常卡,非常非常卡,这是正常的吗(衰
更多推荐
所有评论(0)