使用kubectl管理k8s集群(三十)

640?wx_fmt=gif


前言

Foreword

在搭建k8s集群之前,我们需要先了解下kubectl的使用,以便在集群部署出现问题时进行检查和处理。命令和语法记不住没有关系,但是请记住主要的语法和命令以及帮助命令的使用。

在下一篇,我们将讲述使用Kubeadm来创建k8s集群。

THE END



目录


使用kubectl管理k8s集群

  • 概述

  • 语法

  • 主要命令(command)说明

  • 资源类型(TYPE)说明

  • 命令标准(flags)说明

  • 格式化输出



 使用kubectl管理k8s集群


概述


Kubectl是一个命令行界面,用于运行针对Kubernetes集群的命令。Kubectl的配置文件在$HOME/.kube目录。我们可以通过设置KUBECONFIG环境变量或设置命令参数--kubeconfig来指定其他位置的kubeconfig文件。


 语法


我们可以使用以下语法kubectl从终端窗口运行命令:

kubectl [command] [TYPE] [NAME] [flags]

其中commandTYPENAME,和flags分别是:

  • command:指定要在一个或多个资源进行的操作,例如creategetdescribedelete。例如“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  -f manifest.yaml -l app=nginx

attach

附加到一个正在运行的容器,以查看输出流或与容器(stdin)交互。

autoscale

自动缩放由Replication Controller管理的pod集。

cluster-info

显示有关群集中主服务器和服务的端点信息。

config

指定kubeconfig文件。

create

从文件或标准输入流(stdin)创建一个或多个资源。例如使用pod.json创建podkubectl create -f ./pod.json”。

delete

通过文件,标准输入、指定标签选择器,名称,资源选择器或资源来删除资源。例如删除所有的podkubectl delete pods  --all”。

describe

显示一个或多个资源的详细。例如查看podcoredns-5c98db65d4-h5v9h”的详情“kubectl describe pod  coredns-5c98db65d4-h5v9h -n kube-system”,这里使用了“-n”指定了命名空间。

edit

在服务器上编辑一个资源。

exec

Pod容器中执行命令。

explain

查看资源的文档。例如pod,节点,服务等。例如“kubectl explain pods”。

expose

将复制控制器,服务或pod公开为新的Kubernetes服务。

get

列出一个或多个资源。例如“kubectl get pods -n kube-system  -o wide”命令将列出“kube-system”命名空间下的所有pod并且以表格状输出pod的相关附加信息(节点名称)。

label

添加或更新一个或多个资源的标签。

logs

输出容器在pod中的日志。例如执行以下命令“kubectl logs  etcd-k8s-master -n kube-system”将在终端中输出该容器的日志。

patch

使用patch策略更新资源的字段。

port-forward

将一个或多个本地端口转发到pod

proxy

运行代理指定到Kubernetes  API server

replace

从文件或标准输入中替换资源。

rolling-update

通过逐步替换指定的Replication  Controller及其pod来执行滚动更新。

run

在群集上运行指定的映像。例如运行Nginxkubectl run nginx  --image=nginx”。

scale

设置新的Deployment,  ReplicaSet, Replication Controller 或者 Job副本数量。例如“ubectl  scale --replicas=3 -f foo.yaml”。

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

640?wx_fmt=jpeg


资源类型(TYPE)说明


我们可以使用“kubectlapi-resources”命令来获取服务端目前支持的所有的资源类型,如下图所示:

640?wx_fmt=jpeg



 命令标准(flags)说明


同样的,我们可以使用命令“kubectl options”来输出当前支持的所有可选标志:

640?wx_fmt=jpeg

其中,在前面我们说过,“-s”可以指定Kubernetes API 服务器地址,“-n”可以指定命名空间,“--kubeconfig”可以指定kubeconfig配置文件。主要的一些说明如下所示:

640?wx_fmt=jpeg


格式化输出


默认情况下,所有的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

640?wx_fmt=png


 

往期文章



Docker最全教程——从理论到实战(一)

Docker最全教程——从理论到实战(二)

Docker最全教程——从理论到实战(三)

Docker最全教程——从理论到实战(四)

Docker最全教程——从理论到实战(五)

Docker最全教程——从理论到实战(六)

Docker最全教程——从理论到实战(七)

Docker最全教程——从理论到实战(八)    

Docker最全教程——从理论到实战(九)

Docker最全教程之使用Tencent Hub来完成CI(十)

Docker最全教程——数据库容器化(十一)

Docker最全教程——数据库容器化之持久保存数据(十二)

Docker最全教程——MongoDB容器化(十三)

Docker最全教程——Redis容器化以及排行榜实战(十四)

Docker最全教程之Ubuntu下安装Docker(十五)

Docker最全教程之树莓派和Docker(十六)

Docker最全教程之使用TeamCity来完成内部CI、CD流程(十七)

Docker最全教程之使用Docker搭建Java开发环境(十八)

Docker最全教程之Go实战,墙裂推荐(十九)

Docker最全教程之使用.NET Core推送钉钉消息(二十)

Docker最全教程之使用 Visual Studio Code玩转Docker(二十一)

Docker最全教程之Python爬网实战(二十二)

使用PHP搭建个人博客站点

Docker最全教程之使用Node.js搭建团队技术文档站(二十四)

Docker最全教程之MySQL容器化 (二十五)

Docker+ Kubernetes已成为云计算的主流(二十六)

容器化之后如何节省云端成本?(二十七)

了解Kubernetes主体架构(二十八)

使用Minikube部署本地Kubernetes集群(二十九)



640?wx_fmt=jpeg


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/314876.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【启智树NOIP模拟】生存【父子分治】

题意&#xff1a;有 nnn 个城市连成一棵树&#xff0c;每个城市有 aia_iai​ 个人。接下来 mmm 天每天会发生 kik_iki​ 次灾难&#xff0c;每个灾难会让一个给定城市的人全部死掉。每个人一天可以走一条边&#xff0c;也可以不动。求最多多少人能活过这 mmm 天。 n≤106,∑ki≤…

P3435 [POI2006]OKR-Periods of Words kmp + fail指针

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 转换一下题意&#xff0c;就是求一个最小公共前后缀&#xff0c;显然可以暴跳nenene数组&#xff0c;复杂度O(n2)O(n^2)O(n2)&#xff0c;注意到我们每次都跳的话会跳到很多重复的位置&…

架构杂谈《四》

分布式一致性协议一、引言在分布式系统中&#xff0c;为了保证数据的高可用&#xff0c;通常会将数据保留多个副本(replica)&#xff0c;这些个副本会放在不同的物理机上&#xff0c;为了对用户提供正确的数据&#xff0c;我们需要保证这些放在不同物理机上的副本是一致的。为了…

【十二省联考2019】希望【点边容斥】【换根dp】【长链剖分】【线性数据结构】【回退数据结构】【离线逆元】

题意&#xff1a;给一棵树&#xff0c;两个参数 k,Lk,Lk,L,需要选择 kkk 个连通块&#xff0c;使得这 kkk 个连通块存在一个公共点&#xff0c;且该公共点到 kkk 个连通块内的任意一点的距离不超过 LLL&#xff0c;求方案数 模 998244353998244353998244353。两种方案不同当且仅…

Codeforces Round #246 (Div. 2) D. Prefixes and Suffixes kmp + dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 通过完美子串的定义&#xff0c;我们不难发现满足条件的子串就是kmpkmpkmp中ne[n]ne[n]ne[n]不断向前跳得到的串&#xff0c;现在问题就是如何求这些前缀串在串中出现的次数了。 考虑一个前…

译 | 宣布ML.NET 1.2 及模型生成器更新(用于 .NET 的机器学习)

原文&#xff1a;Cesar De la Torre翻译&#xff1a;Edi Wang我们很高兴地宣布ML.NET 1.2 和模型生成器和 CLI 的更新。ML.NET是 .NET 开发人员的开源和跨平台机器学习框架。ML.NET还包括模型生成器(Visual Studio 的简单 UI 工具)和ML.NET CLI(命令行界面),以便使用自动机器学…

【十二省联考2019】皮配【分部dp】

题意&#xff1a;有 nnn 个学校隶属于 ccc 个城市&#xff0c;每个学校有 sis_isi​ 个人。把它们放入一个 222\times 222 的格子中&#xff0c;要求同一学校的必须放在同一个格子&#xff0c;同一城市的必须放在同一行&#xff0c;并给出两行两列分别最多能放的人数C0,C1,D0,D…

Codeforces Round #590 (Div. 3) F. Yet Another Substring Reverse 子集dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 之前做过类似的题&#xff0c;翻转一个字串相当于将任意两个不相交的串连在一起。再一看字符集≤20\le20≤20&#xff0c;那就是铁子集dpdpdp了。 定义f[i]f[i]f[i]表示状态为iii的串的长度…

一个超轻量级工作流引擎:Workflow-Core

近期工作上有一个工作流的开发需求&#xff0c;自己基于面向对象和职责链模式捣鼓了一套小框架&#xff0c;后来在github上发现一个轻量级的工作流引擎轮子&#xff1a;Workflow-Core&#xff0c;看完其wiki之后决定放弃之前自己造的轮子&#xff0c;使用这个开源项目来改造&am…

Codeforces Round #590 (Div. 3) E. Special Permutations 差分 + 思维

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 思路&#xff1a; 直接考虑比较难想&#xff0c;这种公式题基本都是将部分答案看成一个整体&#xff0c;考虑xi,xi1x_i,x_{i1}xi​,xi1​的贡献的。 假设当前的xix,xi1y,x<yx_ix,x_{i1}y,x<yxi​x,xi1…

【THUSC 2017】如果奇迹有颜色【polya引理】【矩阵】【计数dp】【BM打表+线性递推】

题意&#xff1a;长度为 nnn 的环染 mmm 种颜色&#xff0c;要求任意相邻 mmm 个元素不能包含全部的颜色。求方案数 模 109710^971097&#xff0c;循环同构。 n≤109,m≤7n\leq 10^9,m\leq7n≤109,m≤7 为啥我现在天天都在打表啊 先上 polya&#xff0c;对于移动 iii 位的置换…

ASP.NET Core 3.0中支持AI的生物识别安全

本文共两个部分&#xff0c;这是第一部分&#xff0c;其中介绍了 ASP.NET Core 3 中旨在将授权逻辑与基本的用户角色相分离的基于策略的授权模型。此部分提供了此授权进程的基于生物识别信息&#xff08;如人脸识别或语音识别&#xff09;的具体示例。在此示例中&#xff0c;检…

Codeforces Round #588 (Div. 2) D. Marcin and Training Camp 思维

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 有nnn个人&#xff0c;每个人都有一个能力值bib_ibi​以及他会的技能aia_iai​&#xff0c;当他会第xxx个技能的时候&#xff0c;aia_iai​的第xxx位是111。定义当xxx不会某个技能但是yyy会的时候&#xff0…

架构杂谈《五》

保证最终一致性的模式在大规模、高并发服务化系统中&#xff0c;一个功能被拆分成多个具有功能单一的子功能&#xff0c;一个流程会有多个系统的多个单一功能的服务组合实现&#xff0c;如果使用两阶段提交协议和三阶段提交协议&#xff0c;确实能解决系统间的一致性问题。其实…

【ROI 2019 Day2】课桌【贪心】【决策单调性】【分治】

题意&#xff1a;有 mmm 个班&#xff0c;每个班有 2n2n2n 个人&#xff0c;他们的身高给定。有 kkk 种双人桌&#xff0c;每张桌子有两个属性值 Li,RiL_i,R_iLi​,Ri​,一个身高为 hhh 的人坐第 iii 种桌子的不舒适度为 hhh 到区间 [Li,Ri][L_i,R_i][Li​,Ri​] 的最小距离。你…

Codeforces Round #588 (Div. 2) E. Kamil and Making a Stream 数学 + 暴力

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你一颗树&#xff0c;其中根是111&#xff0c;每个点有一个点权&#xff0c;求每个点到根的所有路径的gcdgcdgcd之和。 n≤1e5n\le1e5n≤1e5 思路&#xff1a; 一看到以为是个点分治&#xff0c;让后发现…

【NOIP模拟】彩色树【树形dp】【树链剖分性质】【复杂度分析】

题意&#xff1a;一棵初始时为空的树&#xff0c;依次加入 nnn 个叶结点&#xff0c;每次加入后询问 用若干不同颜色的路径将树边染色后 每个点到根经过的颜色数 的最大值 的最小值。 n≤106n\leq 10^6n≤106 首先发现这个路径没啥用&#xff0c;其实就是个剖分方案。 然后我…

在Linux的Windows子系统上(WSL)使用Docker(Ubuntu)

背景平时开发大部人都是在提供了高效GUI的window下工作&#xff0c;但是真正部署环境普遍都是在Linux中&#xff0c;所以为了让开发环境和部署环境统一&#xff0c;我们需要在windows模拟LInux环境&#xff0c;以前我们可能通过虚拟机的方式实现&#xff0c;不过自从微软拥抱开…

NOIP2020 赛前总结

没有一眼秒的题都必须对拍&#xff0c;这里对拍包括疯狂造小数据人工检查。所以不会的话放心打暴力吧&#xff0c;反正写出来了也要对拍。码农题最后码。预估可能会失误&#xff0c;不要认为写一半就丢了很可惜&#xff0c;其他更可做的题没碰更可惜。想起了就把文件夹复制一遍…

.net持续集成cake篇之cake介绍及简单示例

cake介绍Cake 是.net平台下的一款自动化构建工具,可以完成对.net项目的编译,打包,运行单元测试,集成测试甚至发布项目等等.如果有些特征Cake没有实现,我们还可以很容易地通过扩展Cake来实现我们想要的功能.Cake有以下特点1) 使用c#语言编写,可以在Cake脚本里使用C#语言来实现我…