关于metrics-server

原有的kubernetes容器监控服务heapster,从kubernetes 1.11版本开始逐渐退休,如下图所示,红框中显示新的监控服务即metrics-server :
在这里插入图片描述
metrics-server的github地址:https://github.com/kubernetes-sigs/metrics-server

实战环境信息

  1. 本次实战环境由三台CensOS7服务器组成,已部署了kubernetes 1.15版本;
  2. 即将部署的metrics-server版本为v0.3.6,与kubernetes版本的匹配关系如下:
    在这里插入图片描述
    接下来开始部署;

下载metrics-server

  1. ssh登录kubernetes机器;
  2. 从GitHub下载metrics-server的发布包:
wget https://github.com/kubernetes-sigs/metrics-server/archive/v0.3.6.tar.gz
  1. 解压下载的文件:
tar -zxvf v0.3.6.tar.gz
  1. 得到名为metrics-server-0.3.6的文件夹,下载工作完成;

解决问题

接下来还不能立即部署服务,有两个问题要先解决:

  1. metrics-server默认使用的是hostname,但是coredns中并没有三台物理机器的hostname和IP地址的关系,需要改为使用主机IP地址;

  2. 验证客户端证书的问题,需要改为不验证;

上述问题通过以下步骤解决:

  1. 进入目录metrics-server-0.3.6/deploy/1.8+/
cd metrics-server-0.3.6/deploy/1.8+/
  1. 打开文件metrics-server-deployment.yaml,新增一些内容,如下图,红框中为新增的内容:
    在这里插入图片描述

部署metrics-server

  1. 还是在目录metrics-server-0.3.6/deploy/1.8+/,执行命令kubectl apply -f ./
  2. 控制台提示多种资源被创建,如下图:
    在这里插入图片描述
  3. 等待metrics-server的pod为running状态,如下图:
    在这里插入图片描述
  4. 至此,metrics-server部署已经完成,接下来验证服务是否正常;

验证功能

  1. 执行命令kubectl top node查看服务器节点情况:
    在这里插入图片描述
  2. 执行命令kubectl top pod -n kube-system查看kube-system这个namespace下所有pod的基本情况:
    在这里插入图片描述
  3. 再来试试metrics-server的API服务,执行命令kubectl proxy --port=8080,用来开代理端口;
  4. 再开打一个同样的ssh连接,执行命令curl localhost:8080/apis/metrics.k8s.io/v1beta1/,如下图,可以看到API返回的内容:
    在这里插入图片描述
  5. 查看名为kube-apiserver-node1的pod的基本信息,命令是:curl localhost:8080/apis/metrics.k8s.io/v1beta1/namespaces/kube-system/pods/kube-apiserver-node1,如下图:
    在这里插入图片描述
    至此,kubernetes环境的metrics-server部署和验证都完成了,希望能给您一些参考;

欢迎关注我的公众号:程序员欣宸

在这里插入图片描述

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐