问题说明:node
一个POD里放了百个容器,而后让K8S集群部署上百个POD,获得可运行上万个容器的实验目的。docker
实验环境:3台DELL裸机服务器,16核+64G,硬盘容量忽略吧,上T了,确定够。数据库
1.一开始运行5000多个容器的时候(也就50个POD),集群部署后,10几分钟就起来了,感受还不错。服务器
2.增长压力,把50个POD增长到100个POD,感受也不会很长时间,都等到下班后又过了半个小时,仍是没有起来,集群连接缓慢,使用kubect里面的命令,很久都出不来信息,UI界面显示服务器超时。ssh
心想,完了,起不来了,把服务器撑死了。让其晚上慢慢启动吧,明天早上查看。spa
当当当,早上来上班了资源
打开服务器,使用SSH链接 master 节点,挺好,链接挺快,使用kubectl命令获取pods 信息,竟然报服务器错误了,基本都是服务器超时的错误。……部署
而后用ssh链接 node 节点,直接连不上,本地一致在转圈圈,去机房接显示屏链接,直接也没有反应。get
这下子坏了,难道要从新装服务器了,键盘鼠标 CPU都给他分配资源了。这不坏了嘛。。ast
敲重点……还好,master节点很好,能够链接。这一点Kubernetes作的比较好(我三台服务器的配置同样),有Master节点在就不用担忧。
解决方案,上网,问大神,给的方法是 用etcd ,进入集群的专用数据库etcd,删除其POD,而后让服务器转起来
又呵呵了,对与我这样的小白,压根都不会ETCD数据库,K8S集群才刚搭建起来玩玩,怎么会那么高深的操做。
这下会不会被炒鱿鱼!!!!!!!!
忽然想到了一个绝招 ,用Docker 呀,看看Docker 是否好用,这也是本次实验的杀手锏了。。下面开始着重讲述了
1.链接master节点,而后输入docker images 和docker ps 和docker ps -a 命令也就会这三个,下了一跳 ,上万个容器僵死在那里,怪不得服务器起不来,上图
2.先把全部的容器 stop掉 ,或者把你认为想stop掉的容器均可以停掉,看下 面个人操做
1 docker stop $(docker ps -q -f name=k8s_hello-ros-10*) //就是中止掉前缀名字为 k8s_hello-ros-10 的容器
3.把停到的容器 删除掉,容器太多,这一步运行的有点慢(上面的代码和此次代码作了一个合并)
1 docker stop $(docker ps -q -f name=k8s_hello-ros-10*) & docker rm $(docker ps -aq -f name=k8s_hello-ros-10*)
4.处理完以后,迅速回到Master节点的kubectl命令下,此时K8S集群有反应了,先把你的建立的pod时用的yaml 文件删除,输入命令
1 kubuetc delete -f XXX.yaml
5. 删除你的部署名,由于我是建立POD时,使用Deployments 部署的,因此删除部署,省的根据副本控制器本身又建立POD,那又陷入死循环了
1 1. kubeclt get deployments -n namespace名字 2 2.找到命令空间,删除 3 kubectl delete deployemtns XXX -n XXX命名空间
6.准备关机重启吧
先关闭NODE节点机,再关闭MASTER机器,重启看看吧
顺利成功,K8S集群启动后,原先的POD已所有删除,剩下了系统要用的POD,集群正常运转。
一次危机就这么化解了……
而后又部署了5000个容器,不敢玩大了,下面图