前言
在搭建k8s集群之前,我们需要先了解下kubectl的使用,以便在集群部署出现问题时进行检查和处理。命令和语法记不住没有关系,但是请记住主要的语法和命令以及帮助命令的使用。
在下一篇,我们将讲述使用Kubeadm来创建k8s集群。
目录
使用kubectl管理k8s集群
- 概述
- 语法
- 主要命令(command)说明
- 资源类型(TYPE)说明
- 命令标准(flags)说明
- 格式化输出
使用kubectl管理k8s集群
概述
Kubectl是一个命令行界面,用于运行针对Kubernetes集群的命令。Kubectl的配置文件在$HOME/.kube目录。我们可以通过设置KUBECONFIG环境变量或设置命令参数--kubeconfig来指定其他位置的kubeconfig文件。
语法
我们可以使用以下语法kubectl从终端窗口运行命令:
kubectl [command] [TYPE] [NAME] [flags]
其中command,TYPE,NAME,和flags分别是:
- command:指定要在一个或多个资源进行的操作,例如create,get,describe,delete。例如“kubectl get cs”。
- TYPE:指定资源类型。资源类型不区分大小写,可以指定单数,复数或缩写形式。例如,以下命令产生相同的输出:
kubectl get pod pod1
kubectl get pods pod1
kubectl get po pod1
- NAME:指定资源的名称。名称区分大小写。如果省略名称,则显示所有资源的详细信息,如“kubectl get pods”。
在对多个资源执行操作时,我们可以按类型和名称指定每个资源,或指定一个或多个文件:
1) 要按类型和名称指定资源:
- 如果资源类型相同,则对资源进行分组:TYPE1 name1 name2 name<#>。
例:kubectl
get pod example-pod1 example-pod2 - 分别指定多种资源类型:TYPE1/name1 TYPE1/name2 TYPE2/name3
TYPE<#>/name<#>。
例:kubectl
get pod/example-pod1 replicationcontroller/example-rc1
2)
要使用一个或多个文件指定资源: -f file1 -f file2 -f file<#>
- 注意使用YAML而不是JSON,因为YAML往往更加用户友好,特别是对于配置文件。
例:kubectl
get pod -f ./pod.yaml - flags:指定的可选标志,不过值得注意的是,使用命令行指定参数会覆盖默认值以及相关的环境变量。例如,我们可以使用-s或--server标志来指定Kubernetes API服务器的地址和端口。
主要命令(command)说明
Kubectl的主体操作命令如下表所示:
操作 |
描述 |
annotate |
添加或更新一个或多个资源的注释。 |
api-versions |
列出可用的API版本。 |
apply |
通过文件名或标准输入流(stdin)对资源进行配置,例如“kubectl apply --prune |
attach |
附加到一个正在运行的容器,以查看输出流或与容器(stdin)交互。 |
autoscale |
自动缩放由Replication Controller管理的pod集。 |
cluster-info |
显示有关群集中主服务器和服务的端点信息。 |
config |
指定kubeconfig文件。 |
create |
从文件或标准输入流(stdin)创建一个或多个资源。例如使用pod.json创建pod“kubectl create -f ./pod.json”。 |
delete |
通过文件,标准输入、指定标签选择器,名称,资源选择器或资源来删除资源。例如删除所有的pod“kubectl delete pods |
describe |
显示一个或多个资源的详细。例如查看pod“coredns-5c98db65d4-h5v9h”的详情“kubectl describe pod |
edit |
在服务器上编辑一个资源。 |
exec |
在Pod容器中执行命令。 |
explain |
查看资源的文档。例如pod,节点,服务等。例如“kubectl explain pods”。 |
expose |
将复制控制器,服务或pod公开为新的Kubernetes服务。 |
get |
列出一个或多个资源。例如“kubectl get pods -n kube-system |
label |
添加或更新一个或多个资源的标签。 |
logs |
输出容器在pod中的日志。例如执行以下命令“kubectl logs |
patch |
使用patch策略更新资源的字段。 |
port-forward |
将一个或多个本地端口转发到pod。 |
proxy |
运行代理指定到Kubernetes |
replace |
从文件或标准输入中替换资源。 |
rolling-update |
通过逐步替换指定的Replication |
run |
在群集上运行指定的映像。例如运行Nginx“kubectl run nginx |
scale |
设置新的Deployment, |
version |
显示客户端和服务器上运行的Kubernetes版本。 |
api-resources |
输出服务端支持的所有的API资源类型。 |
api-versions |
输出服务端支持的API版本。 |
更多命令,我们可以执行“kubectl help”来查看当前所有支持的命令,也可以访问官方地址“https://kubernetes.io/docs/reference/generated/kubectl/kubectl-commands”来查看所有的命令说明。在使用的过程中,如果我们不了解单个命令的具体语法,我们可以使用“kubectl <command> --help”来获取详细介绍,如:
kubectl scale --help
资源类型(TYPE)说明
我们可以使用“kubectl
api-resources”命令来获取服务端目前支持的所有的资源类型,如下图所示:
命令标准(flags)说明
同样的,我们可以使用命令“kubectl
options”来输出当前支持的所有可选标志:
其中,在前面我们说过,“-s”可以指定Kubernetes API 服务器地址,“-n”可以指定命名空间,“--kubeconfig”可以指定kubeconfig配置文件。主要的一些说明如下所示:
格式化输出
默认情况下,所有的kubectl命令默认输出格式是可读的纯文本格式。要以特定格式将详细信息输出到终端窗口,我们需要使用“-o”或多个“-output”标志。
语法:
kubectl [command] [TYPE] [NAME]
-o=<output_format>
支持的输出格式如下表所示:
输出格式 |
描述 |
-o=custom-columns=<spec> |
输入指定的逗号分隔的列名列表来打印表格 。 |
-o=custom-columns-file=<filename> |
使用文件中的自定义列模板来打印表。 |
-o=json |
输出JSON格式的API对象。 |
-o=jsonpath=<template> |
打印在jsonpath表达式中定义的字段 |
-o=jsonpath-file=<filename> |
打印由文件中的jsonpath表达式定义的字段。 |
-o=name |
仅打印资源名称。 |
-o=wide |
以纯文本格式输出任何附加信息。对于pod,包括节点名称。 |
-o=yaml |
输出YAML格式的API对象。 |
例如:
kubectl get pods -n kube-system -o wide
往期内容链接
Docker最全教程之使用Tencent Hub来完成CI(九)
Docker最全教程——Redis容器化以及排行榜实战(十三)
Docker最全教程之Ubuntu下安装Docker(十四)
Docker最全教程之使用TeamCity来完成内部CI、CD流程(十六)
Docker最全教程之使用Docker搭建Java开发环境(十七)
Docker最全教程之使用.NET Core推送钉钉消息(十九)
Docker最全教程之使用 Visual Studio Code玩转Docker(二十)
Docker最全教程之使用Node.js搭建团队技术文档站(二十三)
使用kubectl管理k8s集群(二十九)的更多相关文章
-
在node节点部署kubectl管理k8s集群
感谢!原文链接:https://blog.csdn.net/sinat_35930259/article/details/79994078 kubectl是k8s的客户端程序,也是k8s的命令行工具, ...
-
kubectl管理kubernetes集群
[root@master ~]# kubectl get nodes 查看集群节点NAME STATUS AGEnode1 Ready 25mnode2 Re ...
-
基于 kubeadm 搭建高可用的kubernetes 1.18.2 (k8s)集群二 搭建高可用集群
1. 部署keepalived - apiserver高可用(任选两个master节点) 1.1 安装keepalived # 在两个主节点上安装keepalived(一主一备) $ yum inst ...
-
使用Kubeadm创建k8s集群之部署规划(三十)
前言 上一篇我们讲述了使用Kubectl管理k8s集群,那么接下来,我们将使用kubeadm来启动k8s集群. 部署k8s集群存在一定的挑战,尤其是部署高可用的k8s集群更是颇为复杂(后续会讲).因此 ...
-
使用Kubeadm创建k8s集群之节点部署(三十一)
前言 本篇部署教程将讲述k8s集群的节点(master和工作节点)部署,请先按照上一篇教程完成节点的准备.本篇教程中的操作全部使用脚本完成,并且对于某些情况(比如镜像拉取问题)还提供了多种解决方案.不 ...
-
k8s集群部分常见问题处理
目录 部分常见问题处理 Coredns CrashLoopBackOff 导致无法成功添加工作节点的问题 添加工作节点时提示token过期 kubectl 执行命令报“The connection t ...
-
K8s集群部署(二)------ Master节点部署
Master节点要部署三个服务:API Server.Scheduler.Controller Manager. apiserver提供集群管理的REST API接口,包括认证授权.数据校验以 及集群 ...
-
Kubernetes 系列(一):本地k8s集群搭建
我们需要做以下工作: (1)安装VMware,运行CentOs系统,一个做master,一个做node. (2)安装K8s. (3)安装docker和部分镜像会需要访问外网,所以你需要做些网络方面的准 ...
-
使用RKE快速部署k8s集群
一.环境准备 1.1环境信息 IP地址 角色 部署软件 10.10.100.5 K8s Master Etcd.Control 10.10.100.17 K8s Worker1 Worker 10.1 ...
随机推荐
- github仓库的克隆、修改、上传方法(图)
-
Android 内存优化 (防Memory Leak)
在之前的 Android 内存管理 &Memory Leak & OOM 分析 中,说到了Android的内存管理相关的原理,也能了解到Android Memory Leak 和 ...
-
decode行转列,case when,
1.行转列 转之前:
-
java异常处理机制 (转载)
java异常处理机制 本文来自:曹胜欢博客专栏.转载请注明出处:http://blog.csdn.net/csh624366188 异常处理是程序设计中一个非常重要的方面,也是程序设计的一大难点,从C ...
-
addEventListener 用法
addEventListener 用于注册事件处理程序,IE 中为 attachEvent,我们为什么讲 addEventListener 而不讲 attachEvent 呢?一来 attachEve ...
-
在线QQ客服
代码一: <a target="_blank" href="http://wpa.qq.com/msgrd?v=3&uin=451314789&si ...
-
python2.7学习笔记-split用一个分隔符分割、多个分隔符分割、在有汉字存在的情况下split分割
还是直接上程序吧,暂且就叫它为程序吧: ''' 按照多个分隔符分割,split的用法 ''' import re s='hi!chu?lan!heihei' re.split('[!?]',s) '' ...
-
谈谈书本《c#物联网程序设计基础》中的技术瑕疵,如果你将要读本书,请进来看看!
今天去书店看到一本名为<c#物联网程序设计基础>的书,对物联网感兴趣的我抓起来就看,书中的项目都是上位机开发项目,较简单,如果物联网开发只是这样,看起来我做物联网开发也是绰绰有余.这边书我 ...
-
openssl命令实例
基本知识 1,证书标准 X.509 X.509 - 这是一种证书标准,主要定义了证书中应该包含哪些内容.其详情可以参考RFC5280,SSL使用的就是这种证书标准. X.509的证书文件,一般以.cr ...
-
K-mer分析
0. 基本参数 基因组大小:G Read读长:L 总Read条数:n_r 1. 碱基深度分布 单条Read测序覆盖到某一个碱基的概率:L/G 因为L/G很小,n_r很大,每个碱基覆盖深度服从泊松分布. ...