Kubectl-ice 插件展示集群容器配置信息更强大

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器镜像服务 ACR,镜像仓库100个 不限时长
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: kubectl插件ice的使用讲解

本期介绍一个实用的Kubectl插件kubectl-ice,可以让你快速的查看POD中容器正在运行的配置信息,例如你可以查看所有POD内容器镜像的拉取策略、挂载卷、端口以及可执行配置等信息,同时结合metrics server你也可以查看容器运行的CPU和内存等相关指标信息。

功能

  • 仅使用读取权限,不会调用写操作
  • 默认会列举出当前集群下命名空间内所有pod中的容器相关配置,kubectl-ice基本支持所有kubectl的选项参数;例如指定-A指定所有命令空间下的pod中的所有容器。
  • 支持选择器,与在kubectl中的使用方式类似
  • 支持对输出的内容进行排序
  • 用match标志从输出中排除行,这对于排除内存或cpu使用率低的容器很有用。Exclude rows from output using the match flag, useful to exclude containers with low memory or cpu usage
  • 使用oddity标志只列出不在范围内的cpu和内存结果。List only cpu and memory results that dont fall within range using the oddities flag

安装

安装比较简单,可以通过kubectl插件管理器krew安装,也可以通过下载二进制包进行安装,或者不嫌麻烦源码直接安装

  • krew安装
$ kubectl krew install ice
  • 源码安装
$ git clone https://github.com/NimbleArchitect/kubectl-ice.git
$ cd kubectl-ice
$ make bin

使用帮助

kubectl-ice command    # 检索在容器级别指定的命令行和任何参数
kubectl-ice cpu        # 返回CPU请求的大小,限制和每个容器的使用
kubectl-ice help       # 显示帮助信息
kubectl-ice image      # 列出每个容器的镜像以及镜像的拉取策略
kubectl-ice ip         # 列出名称空间中所有pods的IP地址
kubectl-ice memory     # 返回每个容器的内存请求大小、限制和使用情况
kubectl-ice ports      # 显示pod内容器暴露的端口
kubectl-ice probes     # 显示每个容器配置的启动、就绪和活动探针的详细信息
kubectl-ice restarts   # 显示pod中每个容器的重启计数
kubectl-ice status     # 列出pod中每个容器的状态
kubectl-ice volumes    # 列出所有具有挂载点的容器卷

使用案例

基础

  • 显示指定pod内容器的内存指标信息(T: type,其值有I/init容器,S/standard标准容器)
$ kubectl-ice memory resource-test-6c6f556b4f-lmngp
T  CONTAINER  USED      REQUEST  LIMIT  %REQ  %LIMIT
S  resource   101.18Mi  500Mi    1Gi    20.24 9.88
  • 可结合标签使用

  • 检查容器状态(以及之前的状态)

  • 使用选择器,同时可以使用--sort进行排序,注意!的使用,表示倒序

相关文章
|
Kubernetes API Docker
k8s教程(pod篇)-容器获取pod信息(Downward API)
k8s教程(pod篇)-容器获取pod信息(Downward API)
1279 0
|
2月前
|
Kubernetes 容器
Kubernetes附加组件Dashboard部署实战篇
关于如何在Kubernetes集群中部署和配置Dashboard组件的详细实战指南,涵盖了从创建证书、部署Dashboard、设置服务访问到登录认证的完整流程。
396 0
Kubernetes附加组件Dashboard部署实战篇
|
Kubernetes Ubuntu 应用服务中间件
使用Vagrant创建和管理本地Kubernetes(K8s)集群的步骤是什么
VirtualBox: 用于虚拟机管理。 Vagrant: 用于创建和配置虚拟机环境。 kubectl: Kubernetes命令行工具,用于管理Kubernetes集群。
222 0
|
弹性计算 Kubernetes Linux
容器服务Kubernetes版添加已有节点FAQ
容器服务Kubernetes版添加已有节点FAQ
|
Kubernetes Shell Perl
文档解读 | K8S中的Pod和容器配置(一)
如何给运行在Kubernetes(K8S) Pod中的容器定义环境变量、命令行和参数? 给运行在Kubernetes Pod中的容器定义环境变量 开始之前 必须有一个Kubernets集群,和一个能和集群沟通的kubectl命令行工具。
5699 0
|
Kubernetes 网络协议 Unix
Kubernetes CRI -- 容器运行时接口解析
Kubernetes CRI -- 容器运行时接口解析
Kubernetes CRI -- 容器运行时接口解析
|
应用服务中间件 nginx Perl
Kubernetes----Pod配置容器名称与镜像
Kubernetes----Pod配置容器名称与镜像
415 0
|
存储 Kubernetes API
Docker 与 K8S学习笔记(二十)—— 使用Downward API向容器注入Pod信息
Kubernetes在创建Pod时,会为Pod和容器设置一些额外的信息,比如Pod名称、Pod IP、Node IP、Label、Annotation、资源限制等,我们经常会在应用程序中使用到这些数据,比如利用Pod名称作为应用日志的字段,方便分析日志。为了能在容器内获取这些信息,我们可以使用Dow
465 0
|
调度 数据中心 网络架构
阿里云注册集群—混合集群—安装和配置容器网络插件
混合集群中的容器网络插件包括本地数据中心中运行的容器网络插件和云上计算节点上运行的容器网络插件两部分。本文将介绍混合集群中的容器网络插件配置。
494 0
阿里云注册集群—混合集群—安装和配置容器网络插件
下一篇
无影云桌面