_ _ _
/ \ / \ / \
( k | 1 | s )
\_/ \_/ \_/
by 百里(github.com/yezihack/k1s)
version: 2.2.1
k1s 主要是用于 kubernetes 管理的命令行工具。对 kubectl 命令实现快捷操作。
- 支持 28 种 kubernetes 资源操作。
- 缩减命令长度。
- 使用更人性化的组合操作。如日志,进入容器等,见下文的实例。
- 支持部署或更新 YAML 前的差异显示与模拟。
- 进入工作节点调试。
直接下载脚本,仅依赖 kubectl。
wget https://raw.githubusercontent.com/yezihack/k1s/master/k1s
chmod +x k1s
sudo mv k1s /usr/sbin
设置命名空间
export K1S_NS=kube-system
基本操作命令
# 查看帮助
k1s
# 查看 pods 列表
k1s po
# 查看 pods describe
k1s po xxx desc
# 查看 pods YAML
k1s po xxx yaml
# 查看 pods 日志(xxx 表示 pods 名称)
k1s po xxx logs
# 查看先前 pods 日志(xxx 表示 pods 名称)
k1s po xxx logs p
# 查看 pods 最近10条日志(xxx 表示 pods 名称)
k1s po xxx logs 10
# 查看 pods 里 client 容器
k1s po xxx logs client
# 查看先前 pods 里 client 容器
k1s po xxx logs p client
# 进入容器内部
k1s po xxx exec
# 删除 pod
k1s po xxx del
# 强制删除 pod
k1s po xxx rm
# 查看所有服务
k1s all
# 调试 node 宿主机
k1s x <node name>
命令格式:
# 环境变量
k1s resources <param> action <extend>
资源(Resources) 列表详情, 与 api-resources 显示一致,未全列出,只列出常用的资源名称.
No | Name | ShortName | Describe |
---|---|---|---|
01 | componentstatuses | cs | k8s 组件健康状态 |
02 | configmaps | cm | 配置管理资源 |
03 | endpoints | ep | 端点 |
04 | events | ev | 事件 |
05 | limitranges | limits | 为pod自定义资源管理限制 |
06 | namespaces | ns | 命名空间 |
07 | nodes | node, no | 节点资源 |
08 | persistentvolumeclaims | pvc | 声明持久卷 |
09 | persistentvolumes | pv | 持久卷 |
10 | pods | po,ps | k8s 管理最小单元 |
11 | replicationcontrollers | rc | 副本控制器 |
12 | resourcequotas | quota | 硬性资源限额 |
13 | secrets | secret, sec | 机密数据配置资源 |
14 | services | svc | 服务负载资源 |
15 | daemonsets | ds | 守护进程资源 |
16 | deployments | deploy,d | 控制器资源 |
17 | replicasets | rs | 副本集合资源 |
18 | statefulsets | sts | 有状态控制器 |
19 | horizontalpodautoscalers | hpa | Pod 水平自动扩缩器 |
20 | cronjobs | bj | 定时任务器 |
21 | jobs | job | 一次性任务器 |
22 | ingresses | ing | 对外负载器 |
23 | ingressclasses | ingc | Ingress 分类器 |
24 | clusterrolebindings | crb | RBAC 集群角色绑定 |
25 | serviceaccounts | sa | RBAC 服务帐号 |
26 | clusterroles | cr | RBAC 集群角色 |
27 | rolebindings | rb | RBAC 角色绑定 |
28 | roles | ro | RBAC 角色 |
No | Name | ShortName | Describe |
---|---|---|---|
1 | apply | p | 开始部署/重新部署 |
2 | exec | auto, e | 进入容器 |
3 | nsenter | x | 调试 Node 节点 |
4 | clean | c | 清理无用 Pod |
5 | all | all | 查看所有服务 |
操作某资源时可以使用不同的动作(action)从而实现多功能操作。
No | Name | ShortName | Describe |
---|---|---|---|
01 | list | ls | 显示列表(默认显示) |
02 | describe | desc | 查看详情 |
03 | yaml | y,yml | 查看 YAML |
04 | wide | w | 查看更多信息 |
05 | exec | e,auto | 进入容器操作 |
06 | delete | del,rm | 删除资源操作(rm 为强制删除) |
07 | logs | log | 查看日志操作,也兼容 tail |
08 | tail | 查看 Pod 最近日志 | |
09 | tailf | 监听日志变化 | |
10 | like | 模糊查找 | |
11 | edit | 编辑 YAML |
动态的参数,如操作 logs 日志。见下面实例。
No | Extend | Describe |
---|---|---|
1 | container-name | 选择不同容器名称 |
2 | 10 | 显示日志最近条数 |
No | Name | 简写 | Default | Describe |
---|---|---|---|---|
1 | K1S_NS | K1N | default | 命名空间名称 |
2 | K1S_PATH | K1P | ~ | 构建目录,默认本用户目录下 |
2 | K1S_IMAGE | K1I | alpine:latest | 基础镜像,调试宿主机使用(K1I最后字母是大写i) |
举例说明,只列举常用资源
# 设置命名空间名称
export K1S_NS=default
## 或者
export K1N=default
# 设置构建路径,主要用于 apply 部署或重建时用到。
## 如果不设置路径则动态选择当前目录
export K1S_PATH=/home/dev/
## 或者
export K1P=/home/dev/
# 基础镜像,调试宿主机使用
export K1S_IMAGE=alpine:latest
## 或者
export K1I=alpine:latest
小技巧:对于常操作的命令空间,可以设置别名
vim ~/.bashrc
# 或
vim ~/.zshrc
alias k1s-sys='export K1S_NS=kube-system && export K1S_PATH=/opt/deploy/'
别名:logs, log
参数:
- pod名称:
kube-cc-7789c5f6d6-szqwk
- 容器名称:
client
模式:
共四种模式操作
- 普通模式:
k1s po [pod 名称] logs
- 最近模式:
k1s po [pod 名称] logs 10
查看最近10条日志 - 选择模式:
k1s po [pod 名称] logs client
查看 client 容器名称日志 - 选择最近模式:
k1s po [pod 名称] logs client 10
查看 client 容器最近10条日志
实例操作:
# 普通模式
k1s po kube-cc-7789c5f6d6-szqwk logs
# 最近模式
k1s po kube-cc-7789c5f6d6-szqwk logs 10
# 选择模式
k1s po kube-cc-7789c5f6d6-szqwk logs client
# 选择最近模式
k1s po kube-cc-7789c5f6d6-szqwk logs client 10
- 查看多容器 pod 的日志,有选择性查看容器日志。
别名:exec, auto, e
参数:
- pod名称:
kube-cc-7789c5f6d6-szqwk
- 容器名称:
client
模式:
共四种模式操作
- 普通模式:
k1s exec [pod 名称]
- 普通选择模式:
k1s exec [pod 名称] client
进入client
容器内 - 便捷模式:
k1s po [pod 名称] exec
- 选择便捷模式:
k1s po [pod 名称] exec client
进入 client 容器内
# 普通模式
k1s exec kube-cc-7789c5f6d6-szqwk
# 普通选择模式
k1s exec kube-cc-7789c5f6d6-szqwk client
# 便捷模式
k1s po kube-cc-7789c5f6d6-szqwk exec
# 选择便捷模式
k1s po kube-cc-7789c5f6d6-szqwk exec client
如果您的集群无外网,则无法下载基础镜像,需要设置内网镜像
export K1S_IMAGE="hub.local.io/alpine:lateset"
基础操作命令:
# 查看 node 列表
k1s no
NAME STATUS ROLES AGE VERSION
192.168.1.100 Ready gpu 68d v1.23.3
# 进入宿主机
k1s x 192.168.1.100
只列举常用的几种资源,其它资源查找大同小异。
- nodes
- pods
- deployments
- daemonsets
- services
支持的 action 动作:
- list 列表,默认值
- wide 更多显示
- like 模糊查找
- yaml 显示 yaml
- desc 显示详情
- exec 进入容器
- delete 删除资源
- log 日志
别名:nodes, node, no
参数:
kube
node 节点的前缀名称kube-10
node 节点完整名称
模式:
- 普通模式:
k1s no
- 模糊搜索模式:
k1s no [关键字] like
- 单模式:
k1s no [节点名称]
- YAML 模式:
k1s no [节点名称] yaml
- 详情模式:
k1s no [节点名称] desc
# 普通模式
k1s no
# 模糊搜索模式 -> 模糊查找含有 kube 的节点名称
k1s no kube like
# 单模式 -> 显示单个资源
k1s no kube-10
# YAML 模式 -> 查看资源的 YAML
k1s no kube-10 yaml
# 详情模式 -> 查看资源的 describe 详细
k1s no kube-10 desc
别名:pods, po, ps
参数:
kube-box
pod 前缀名称kube-box-685fb75bb-cvmgz
pod 的完整名称
模式:
- 普通模式:
k1s po
- 模糊搜索模式:
k1s po [关键字] like
模糊查找含有 kube 的节点名称 - 单模式:
k1s po [pod名称]
- YAML 模式:
k1s po [pod名称] yaml
- 详情模式:
k1s po [pod名称] desc
- 删除模式:
k1s po [pod名称] delete
# 普通模式 -> 简约列表
k1s po
# 模糊搜索模式 -> 模糊查找资源列表
k1s po kube-box like
# 单模式 -> 显示单个资源
k1s po kube-box-685fb75bb-cvmgz
# YAML 模式 -> 查看资源的 YAML
k1s po kube-box-685fb75bb-cvmgz yaml
# 详情模式 -> 查看资源的 describe 详细
k1s po kube-box-685fb75bb-cvmgz desc
# 删除模式
k1s po kube-box-685fb75bb-cvmgz delete
别名:deployments, deploy, d
参数:
kube
deploy 前缀名称kube-box
deploy 的完整名称
模式:
- 普通模式:
k1s d
- 模糊搜索模式:
k1s d [关键字] like
模糊查找含有 kube 的节点名称 - 单模式:
k1s d kube-box
- YAML 模式:
k1s d kube-box yaml
- 详情模式:
k1s d kube-box desc
# 普通模式 -> 简约列表
k1s d
# 模糊搜索模式 -> 模糊查找资源列表
k1s d kube-box like
# 单模式 -> 显示单个资源
k1s d kube-box
# YAML 模式 -> 查看资源的 YAML
k1s d kube-box yaml
# 详情模式 -> 查看资源的 describe 详细
k1s d kube-box desc
别名:daemonsets, ds
参数:
kube
daemonsets 前缀名称kube-proxy
daemonsets 的完整名称
模式:
- 普通模式:
k1s ds
- 模糊搜索模式:
k1s ds [关键字] like
模糊查找含有 kube 的节点名称 - 单模式:
k1s ds [daemonset 名称]
- YAML 模式:
k1s ds [daemonset 名称] yaml
- 详情模式:
k1s ds [daemonset 名称] desc
# 普通模式 -> 简约列表
k1s ds
# 模糊搜索模式 -> 模糊查找资源列表
k1s ds kube like
# 单模式 -> 显示单个资源
k1s ds kube-proxy
# YAML 模式 -> 查看资源的 YAML
k1s ds kube-proxy yaml
# 详情模式 -> 查看资源的 describe 详细
k1s ds kube-proxy desc
别名:services, svc
参数:
kube
daemonsets 前缀名称kube-dns
daemonsets 的完整名称
模式:
- 普通模式:
k1s svc
- 模糊搜索模式:
k1s svc [关键字] like
模糊查找含有 kube 的节点名称 - 单模式:
k1s svc [service名称]
- YAML 模式:
k1s svc [service名称] yaml
- 详情模式:
k1s svc [service名称] desc
# 普通模式 -> 简约列表
k1s svc
# 模糊搜索模式 -> 模糊查找资源列表
k1s svc kube like
# 单模式 -> 显示单个资源
k1s svc kube-dns
# YAML 模式 -> 查看资源的 YAML
k1s svc kube-dns yaml
# 详情模式 -> 查看资源的 describe 详细
k1s svc kube-dns desc
# 查看不同空间下统计的错误信息
k1s clean
# 清理指定空间下的错误信息
k1s clean dev