kubectl基本命令介绍

x33g5p2x  于2021-10-31 转载在 其他  
字(1.9k)|赞(0)|评价(0)|浏览(240)

1.K8S集群管理工具kubectl

1.1概述

kubectl 是 Kubernetes 集群的命令行工具,通过 kubectl 能够对集群本身进行管理,并能
够在集群上进行容器化应用的安装部署

1.2.kubectl 命令的语法

kubectl [command] [type] [name] [flags]

comand:指定要对资源执行的操作,例如 create、get、describe 和 delete
*
type:指定资源类型,资源类型是大小写敏感的,开发者能够以单数、复数和缩略的
形式。例如

[root@localhost ~]# kubectl get nodes
NAME         STATUS   ROLES                  AGE   VERSION
k8s-master   Ready    control-plane,master   34m   v1.22.3
k8s-node1    Ready    <none>                 27m   v1.22.3
k8s-node2    Ready    <none>                 27m   v1.22.3
  • name:指定资源的名称,名称也大小写敏感的。如果省略名称,则会显示所有的资源,
    例如
[root@localhost ~]# kubectl get pods
NAME                     READY   STATUS    RESTARTS   AGE
nginx-6799fc88d8-n692z   1/1     Running   0          41s
  • flags:指定可选的参数。例如,可用-s 或者–server 参数指定 Kubernetes API
    server 的地址和端口

2.命令介绍

获取kubectl的命令

kubectl --help

获取某个命令的介绍和使用

kubectl get --help

2.1基础命令

2.1.1常见的基础命令
命令介绍
create通过文件名或标准输入创建资源
run在集群中运行一个特定的镜像
expose将一个资源公开为一个新的Service
set在对象上设置特定的功能
get显示一个或多个资源
explain文档参考资料
edit使用默认的编辑器编辑一个资源
delete通过文件名,标准输入,资源名称或标签来删除资源
2.1.2部署命令
命令介绍
rollout管理资源的发布
rolling-update对给定的复制控制器滚动更新
scale扩容或缩容Pod数量,Deployment、ReplicaSet、RC或Job
autoscale创建一个自动选择扩容或缩容并设置Pod数量
2.2.3集群管理命令
命令介绍
certificate修改证书资源
cluster-info显示集群信息
top显示资源(CPU/M)
cordon标记节点不可调度
uncordon标记节点可被调度
drain驱逐节点上的应用,准备下线维护
taint修改节点taint标记
2.2.4故障和调试命令
命令介绍
describe显示特定资源或资源组的详细信息
logs在一个Pod中打印一个容器日志,如果Pod只有一个容器,容器名称是可选的
attach附加到一个运行的容器
exec执行命令到容器
port-forward转发一个或多个
proxy运行一个proxy到Kubernetes API Server
cp拷贝文件或目录到容器中
auth检查授权
2.2.5其它命令
命令介绍
apply通过文件名或标准输入对资源应用配置
patch使用补丁修改、更新资源的字段
replace通过文件名或标准输入替换一个资源
convert不同的API版本之间转换配置文件
label更新资源上的标签
annotate更新资源上的注释
completion用于实现kubectl工具自动补全
api-versionsapi-versions 打印受支持的API版本
config修改kubeconfig文件(用于访问API,比如配置认证信息)
help所有命令帮助
plugin运行一个命令行插件
version打印客户端和服务版本信息
2.2.6目前使用的命令

创建一个nginx镜像
kubectl create deployment nginx --image=nginx

对外暴露端口
kubectl expose deployment nginx --port=80 --type=NodePort

查看资源
kubectl get pod, svc

查看集群服务健康状态
kubectl get cs

[root@localhost manifests]# kubectl get cs
Warning: v1 ComponentStatus is deprecated in v1.19+
NAME                 STATUS    MESSAGE                         ERROR
scheduler            Healthy   ok
controller-manager   Healthy   ok
etcd-0               Healthy   {"health":"true","reason":""}

相关文章