记一次k8s集群的调度调整

集群信息

  1. master节点:3台,slaver节点:9台
  2. etcd运行在三台master节点上

遇到的问题

  1. 在每天pod的启动时,发现pod从Pending --> CreateContainer --> Running所花费的时间很长,一般会用到6-10Min。
  2. 删除节点的时候也是需要花费3-5分钟才能完成一个pod的删除。
  3. 在master节点上面启动或者删除一个pod都会花费更长的时间。

排查

统计pod在节点的分配情况

我把

kubectl describe pod -n namespace | grep Node:

的输出重定向到一个文件里面,再对文件进行简单的k-v统计之后,发现所有节点的调度都集中在三个节点上[可能有master节点,可能都不是master节点]。

查看yaml文件

查看yaml文件之后,发现:

  1. 在containers里面,对于每一个container都没有声明资源相关的配置。
  2. 没有对于pod的亲和性设置。

解决问题

对于遇到的问题中的前两个,我感觉应该是pod集中分配到几个节点上面,造成那几个节点压力太大。一方面需要不能让pod分配到master节点上面,另一方面需要把pod均分到其他节点。

不让pod分配到master节点

这个可以在yaml文件里面设置node亲和性:

spec:
  affinity:
    nodeAffinity:
       requiredDuringSchedulingIgnoredDuringExecution:
         nodeSelectorTerms:
         - matchExpressions:
           - key: kubernetes.io/hostname
             operator: NotIn
             values:
             - master01
             - master02
             - master03

这个亲和性的设置,可以在官方文档上面看到详细的设置方法。这个亲和性可以避免pod分配到相关的节点上面。

均分pod到非master节点

这个需要设置一下资源的使用,让master节点自己去选取合适的节点放置pod:

containers:
- name: container_first_name
  ...
  ...
  ...
  resources:
    requests:
      memory: xxx
      cpu: xxx
    limits:
      memory: xxx
      cpu: xxx

相关的文档在:官方文档

结果

添加这两个配置之后,发现现在的pod会均分到非master节点上面了,并且启动时间缩短到了1分钟之内,节省了很多的时间。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值