人手一套的K8S命令集合,它来了!

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: K8S在容器技术盛行的时代已经称为标配技术,本文瑞哥开始给大家介绍了K8S的基本知识,然后列举了K8S的命令列表,最后还给大家提炼出高频使用的命令,希望本文能够给您带来帮助。

你好,这里是网络技术联盟站。

上次给大家介绍了Docker常用的命令,反响不错,评论区有小伙伴想要K8S的命令合集,那么今天瑞哥就来安排一下!

在开始列举K8S命令集前,先给大家简单介绍一下K8S的基本理论。

什么是K8S?

K8S其实是Kubernetes,由于Kubernetes读起来像K8S,所以久而久之,大家就将Kubernetes简称为K8S了。

K8S 最初由 Google 开发,其实就是一个容器或微服务平台,用于编排计算、网络和存储基础设施工作负载。

所谓容器,就是提供了一种打包代码、运行时、系统工具、系统库和配置的方法,也就是就是说有了这个容器,不管你将此放到哪个相同系统的服务器上,都能完好的运行程序,最好的例子就是Docker。

K8S的优势

K8S的优势就是为啥大多数企业和组织选择K8S,简单来说一般有以下四个优点:

1、提升工作效率

K8S提供一个PaaS平台,创建了一个硬件抽象层,使用者可以快速有效地请求他们需要的资源,如果他们需要更多资源来处理额外的工作,也可以快速的扩展,只需点一点就能快速配置,并且可以利用 Kubernetes 开发的工具来实现自动化打包、部署和测试。

2、灵活性

容器引擎是运行容器的程序,K8S支持多种类型的容器运行时和基础设施,只要它们具有某些版本的 Linux 或 Windows,K8s 的可移植性使开发团队可以轻松切换引擎、服务器或环境配置。

3、节约成本

K8S不仅可以节省人力成本、还能节省物力成本,通过动态和智能的容器管理,K8S可以帮助企业节省其生态系统管理,确保跨多个环境的可扩展性。资源分配会根据实际应用程序需求自动调整,同时减少基础架构上的低级手动操作。有了自动化,IT 团队不再需要执行大量与系统管理相关的操作任务,可以将大量的精力用在更有意义的事情上,这极大的节省了企业的成本。

4、开源

K8S是一个完全开源的、由社区主导的项目,由 CNCF 监督,它有几家主要的企业赞助商,对于许多企业来说,这种开源策略使K8S优于闭源编排器。

K8S命令备忘录

1、列举资源

生成所有命名空间的纯文本列表:

kubectl get namespaces

显示所有 pod 的纯文本列表:

kubectl get pods

生成所有 pod 的详细纯文本列表,包含节点名称等信息:

kubectl get pods -o wide

显示在特定节点服务器上运行的所有 pod 的列表:

kubectl get pods --field-selector=spec.nodeName=[server-name]

以纯文本形式列出特定的复制控制器:

kubectl get replicationcontroller [replication-controller-name]

生成所有复制控制器和服务的纯文本列表:

kubectl get replicationcontroller,services

显示所有守护程序集的纯文本列表:

kubectl get daemonset

2、部署

创建一个新的部署

kubectl create deployment <deployment_name>

列出一个或多个部署

kubectl get deployment

列出一个或多个部署的详细状态

kubectl describe deployment <deployment_name>

删除部署

kubectl delete deployment<deployment_name>

3、命名空间相关

按给定名称创建命名空间

kubectl create namespace <namespace_name>

列出集群中的当前命名空间

kubectl get namespace

显示一个或多个命名空间的详细状态

kubectl describe namespace <namespace_name>

删除命名空间

kubectl delete namespace <namespace_name>

编辑和更新命名空间的定义

kubectl edit namespace <namespace_name>

4、执行命令

接收在 pod 中的第一个容器上运行的命令的输出:

kubectl exec [pod-name] -- [command]

从在 pod 中的特定容器上运行的命令获取输出:

kubectl exec [pod-name] -c [container-name] -- [command]

从特定的 pod运行/bin/bash 。接收到的输出来自第一个容器:

kubectl exec -ti [pod-name] -- /bin/bash

5、守护进程

列出一个或多个守护程序集

kubectl get daemonset

编辑和更新一个或多个守护程序集的定义

kubectl edit daemonset <daemonset_name>

删除守护程序集

kubectl delete daemonset <daemonset_name>

创建一个新的守护进程

kubectl create daemonset <daemonset_name>

管理守护程序集的推出

kubectl rollout daemonset

显示命名空间中守护程序集的详细状态

kubectl describe ds <daemonset_name> -n <namespace_name

8、打印容器日志

打印 pod 的日志

kubectl logs <pod_name>

打印 pod 上一小时的日志

kubectl logs --since=1h <pod_name>

获取最近的 20 行日志

kubectl logs --tail=20 <pod_name>

从服务获取日志并可选择选择哪个容器

kubectl logs -f <service_name> [-c <$container>]

打印 pod 的日志并关注新日志

kubectl logs -f <pod_name>

打印 pod 中容器的日志

kubectl logs -c <container_name> <pod_name>

将 pod 的日志输出到名为“pod.log”的文件中

kubectl logs <pod_name> pod.log

查看以前失败的 pod 的日志

kubectl logs --previous <pod_name>

获取所有以 pod_prefix 命名的 pod 的日志

kubetail <pod_prefix>

包括最近 5 分钟的日志

kubetail <pod_prefix> -s 5m

11、其他命令

文档

获取 pod 清单的文档

kubectl explain pod

获取服务清单的文档

kubectl explain service
别名

在 linux 上创建别名

alias k=kubectl

在 Windows 上创建别名

Set-Alias -Name k -Value kubectl
节点

获取节点

kubectl get nodes

获取特定节点

kubectl get nodes <node>

显示节点指标

kubectl top node <node>
服务帐号

列出服务帐号

kubectl get serviceaccounts

获取服务帐号

kubectl get serviceaccount <serviceaccount>

创建服务帐号

kubectl create serviceaccount <serviceaccount>

删除服务帐号

kubectl delete serviceaccount <serviceaccount>

描述服务帐号

kubectl describe serviceaccount <serviceaccount>

10、格式化输出

如果想要以特定格式将详细信息输出到终端窗口,可以在K8S命令中加上-o参数。

使用逗号分隔的自定义列列表打印表格

-o=custom-columns=<spec>

使用文件中的自定义列模板打印表格

-o=custom-columns-file=<filename><filename>

输出 JSON 格式的 API 对象

-o=json

打印jsonpath表达式中定义的字段

-o=jsonpath=<template>

打印文件中jsonpath表达式定义的字段\<filename\>

-o=jsonpath-file=<filename>

仅打印资源名称,不打印其他内容

-o=name

以纯文本格式输出任何附加信息,对于 pod,包括节点名称

-o=wide

输出 YAML 格式的 API 对象

-o=yaml

以上就是K8S的命令列表,下面给大家列举一下高频使用的命令,希望大家能够牢记!!!

K8S高频使用的命令

1、列出所有命名空间服务

查看当前命名空间中所有服务的列表:

kubectl get services

查看所有命名空间中的服务列表:

kubectl get pods --all-namespaces
2、检索节点上的详细信息

查看节点的整体状态:

kubectl get nodes
3、创建一个具有唯一名称的新命名空间

创建一个新的命名空间:

kubectl create ns hello-there
4、利用文件来配置 Kubernetes

利用配置文件并更改资源:

kubectl apply -f config.yaml
5、列出命名空间中所有正在运行的 pod
kubectl get pods --field-selector=status.phase=Running
6、集群服务

显示集群主节点和服务的端点信息:

kubectl cluster-info
7、服务日志 ⭐
kubectl logs -f <service_name>
8、密钥

获取所有 Kubernetes 密钥的列表:

kubectl get secrets
9、事件

查看所有基于资源的事件的列表:

kubectl get events
10、创建新的 DaemonSet
kubectl create daemonset <daemonset_name>

总结

K8S在容器技术盛行的时代已经称为标配技术,本文瑞哥开始给大家介绍了K8S的基本知识,然后列举了K8S的命令列表,最后还给大家提炼出高频使用的命令,希望本文能够给您带来帮助。

最后感谢您的阅读,如果觉得文章对您有帮助,别忘了点赞👍、收藏⭐哦!有任何问题,欢迎在下方评论区与我讨论!!!

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
8月前
|
运维 Kubernetes 监控
揭秘高效运维:如何用kubectl top命令实时监控K8s资源使用情况?
揭秘高效运维:如何用kubectl top命令实时监控K8s资源使用情况?
2302 0
|
8月前
|
Kubernetes 应用服务中间件 API
Kubernetes(K8S)命令指南
Kubernetes(K8S)命令指南
269 0
|
Kubernetes 调度 数据中心
K8S常用命令
K8S常用命令
186 0
|
Kubernetes 容器 Perl
k8s查看日志命令—2023.02
k8s查看日志命令—2023.02
217 0
|
8月前
|
运维 Kubernetes 容器
K8S运维命令必备kubectl命令总结
K8S运维命令必备kubectl命令总结
113 3
|
8月前
|
iOS开发 MacOS Windows
|
3月前
|
缓存 Kubernetes 应用服务中间件
k8s学习--helm的详细解释及安装和常用命令
k8s学习--helm的详细解释及安装和常用命令
k8s学习--helm的详细解释及安装和常用命令
|
5月前
|
Kubernetes Shell Docker
在K8S中,如果容器没有bash命令,如何进⼊容器排查问题?
在K8S中,如果容器没有bash命令,如何进⼊容器排查问题?
|
5月前
|
Kubernetes Docker 容器
Kubernetes(K8S) 常用命令
Kubernetes(K8S) 常用命令
67 0
|
5月前
|
Kubernetes 监控 Shell
掌握Kubernetes故障排除技巧:kubectl命令的基本指南
以上是使用 `kubectl` 进行故障排除的一些基本指南。熟悉这些命令能够帮助您快速定位和解决在Kubernetes集群中遇到的问题。在实际使用中,您可能还需要结合其他工具和资源,如官方文档、社区论坛以及第三方监控和日志服务来进行更深入的故障诊断和排除。
112 0

热门文章

最新文章