kubernetes组件——kubectl命令行工具管理

内容要点:
1、kubectl概述
2、kubectl语法
3、kubectl管理命令
4、create与apply命令的异同
5、实例演示
一、kubectl概述

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

二、kubectl语法

1.使用以下语法kubectl从终端窗口运行命令:

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

2.其中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服务器的地址和端口。

三、kubectl管理命令

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

四、create与apply命令的异同

  • 通过YAML文件建立
kubectl create -f FILENAME [options]
  • 通过YAML文件升级deployment
kubectl apply -f FILENAME
  • 相同点
如果yaml文件中的kind值为deployment,那么上面这两个命令都可以创建一个deployment,生成相应数量的pod
  • 不同点
create命令:是先删除所有现有的东西,重新根据yaml文件生成新的。所以要求yaml文件中的配置必须是完整的
apply命令:根据配置文件里面列出来的内容,升级现有的。所以yaml文件的内容可以只写需要升级的属性

五、实例演示:

  • 项目的生命周期

    创建->发布->更新->回滚->删除

1.创建nginx

#常用语法:kubectl run NAME --image=image [--env="key=value"参数] [--port=port端口] [--replicas=replicas副本集] [--dry-run=bool状态] [--overrides=inline-json] [--command命令] -- [COMMAND] [args...] [options]`
kubectl run nginx-deployment --image=nginx --port=80 --replicas=3

#查看pod节点
kubectl get pods

2.发布nginx service提供负载均衡的功能

#常用语法:kubectl expose (-f FILENAME | TYPE NAME) [--port=port群集之间内部通信的端口] [--protocol=TCP|UDP|SCTP] [--target-port对外暴露的端口=number-or-name] [--name=name指定名称] [--external-ip=external-ip-of-service] [--type=type指定类型] [options]
kubectl expose deployment nginx-deployment --port=80 --target-port=80 --name=nginx-deployment-service --type=NodePort

#查看服务发布,此处svc位service服务组件的缩写
kubectl get pods,svc

#查看后端关联的节点
kubectl get endpoints

#查看网络状态详细信息
kubectl get pods -o wide

#查看服务的端口
kubectl get svc

#kubernetes里kube-proxy支持三种模式,在v1.8之前我们使用的是iptables 以及 userspace两种模式,在kubernetes 1.8之后引入了ipvs模式

#node节点安装ipvsadmin工具查看服务端口
yum install ipvsadm -y

ipvsadm -L -n
#使用工具查看,可见调度算法为rr轮询模式
#master端查看访问日志
kubectl get pods

3.更新nginx 为1.14版本

  • 谷歌浏览器重新加载刷新页面查看nginx版本信息
查看nginx版本步骤:F12打开开发者选项->F5刷新访问->找到network ->点击name ->找到headers头部信息
kubectl set image deployment/nginx-deployment nginx-deployment=nginx:1.14

4.回滚nginx

#查看历史版本
kubectl rollout history deployment/nginx-deployment

#执行回滚到上一次版本
kubectl rollout undo deployment/nginx-deployment

#检查回滚状态
kubectl rollout status deployment/nginx-deployment

5.删除nginx

#删除deployment
kubectl delete deployment/nginx-deployment

#删除服务SVC
kubectl get svc

6.其他命令

  • 查看具体资源的详细信息
kubectl describe (-f FILENAME | TYPE [NAME_PREFIX | -l label] | TYPE/NAME) [options]
  • 查看deployment资源
kubectl describe deployment/nginx-deployment
  • 查看资源对象简写
kubectl api-resources
  • 进入相应pod中
kubectl exec POD [-c CONTAINER] -- COMMAND [args...] [options]
  • 查看生成的YAML格式文件
kubectl run nginx-deployment --image=nginx --port=80 --replicas=3 --dry-run -o yaml
  • 查看生成的JSON格式文件
kubectl run nginx-deployment --image=nginx --port=80 --replicas=3 --dry-run -o json
  • 生成YAML 、 JSON文件导出
kubectl run nginx-deployment --image=nginx --port=80 --replicas=3 --dry-run -o json(yaml) > test.json(yaml)
  • 将现有资源进行导出
kubectl get svc/nginx-svc --export -o yaml > nginx-svc.yaml
  • 测试命令正确性,不执行(类似shell脚本中的sh -n)
kubectl run nginx --image=nginx --port=80 --replicas=2 --dry-run

原文地址:https://blog.51cto.com/14475876/2472118

时间: 2024-11-01 10:38:49

kubernetes组件——kubectl命令行工具管理的相关文章

K8s之kubectl命令行工具常用命令

kubectl管理 Kubectl是管理k8s集群的命令行工具,通过生成的json格式传递给apiserver进行创建.查看.管理的操作 注意:此处需要用到我们之前部署的K8s多节点的部署环境,如果还未部署的可以参考我的上篇文章:https://blog.csdn.net/JarryZho/article/details/104212822 常用命令行: `查看帮助命令` [[email protected] ~]# kubectl --help kubectl controls the Kub

巧用命令行工具UCloud CLI,轻量操作API管理云资源

截止目前,UCloud已提供Python/Java/Golang等不同语言的API SDK.为进一步降低用户的运维人力投入,又推出了基于Golang SDK的命令行工具CLI(Command Line Interface),提供轻量化的API命令行调用方式,并在GitHub开源(https://github.com/ucloud/ucloud-cli).CLI的命令行交互方式更符合研发运维的操作习惯,并且一些典型使用场景通过CLI也更容易代码化的沉淀和维护. 下面是一些用户遇到的实际场景, 用C

使用命令行工具对LSI阵列卡进行高效管理

LSI公司(LSI Corporation)(NASDAQ:LSI)(中文:艾萨华)是一家总部位于加利福尼亚州米尔皮塔斯 (Milpitas) 的半导体和软件领先供应商,其主要产品包括:RAID控制器.SSD控制器.ReadChannel.Preamp.Axxia网络处理器和定制ASIC等,为加速数据存储中心与移动网络性能提供了许多领先的解决方案. 在目前各大知名品牌服务器厂商:IBM.DELL.HP.华为.联想.宝德.浪潮.中科曙光等服务器都使用LSI品牌的阵列卡作为服务器存储控制器,而且其性

ActiveMQ命令行工具

命令行工具 命令行工具 n        activemq——运行activemq代理 n activemq-admin——管理代理的实例 在5.0之前activemq-admin被分成多个脚本,例如: n        shutdown——关闭activemq代理 n        list——列出所有在指定JMX上下文中运行的代理 n        query——查询JMX上下文中的代理统计和信息. n        bstat——预定义查询,显示有用的代理统计信息. n        br

FFmpeg命令行工具和批处理脚本进行简单的音视频文件编辑

FFmpeg_Tutorial FFmpeg工具和sdk库的使用demo 一.使用FFmpeg命令行工具和批处理脚本进行简单的音视频文件编辑 1.基本介绍 对于每一个从事音视频技术开发的工程师,想必没有一个人对FFmpeg这个名称感到陌生.FFmpeg是一套非常知名的音视频处理的开源工具,它包含了开发完成的工具软件.封装好的函数库以及源代码供我们按需使用.FFmpeg提供了非常强大的功能,可以完成音视频的编码.解码.转码.视频采集.后处理(抓图.水印.封装/解封装.格式转换等),还有流媒体服务等

3 .8 命令行工具

3 .8 命令行工具SQL Server 2008提供了相当多的优秀的图形工具,可以用来完成几乎所有需要执行的 任 务 ,但 是有时候简单的命令行工具就是完成工作的最佳工具.市面上目前有一小部分命 令行工具,本节将介绍其中最突出的两个工具-- SQLCMD(以前的OSQL)和 B C P,同时 还 将 介 绍 Microsoft最新的.可能也是最强大的命令行实用 工 具 PowerShelk3.8.1 SQLCMDSQLCMD实用工具取代OSQL成为了在命令提示符下执行T-SQL语句.存储过程和

【Kubernetes】kubectl命令详解 &#646984;

目录 用法概述 子命令详解 参数列表 输出格式 操作示例 原文: http://blog.gqylpy.com/gqy/385 @ 用法概述 kubectl 命令行的语法如下: kubectl [command] [TYPE] [NAME] [flags] command:子命令,用于操作 Kubernetes 集群资源对象的命令,例如 create.delete.describe.get.apply 等. TYPE:资源对象类型,区分大小写,能以单数.复数形式或者简写形式表达. NAME:资源

windows下的命令行工具babun

什么是babun babun是windows上的一个第三方shell,在这个shell上面你可以使用几乎所有linux,unix上面的命令,他几乎可以取代windows的shell.用官方的题目说就是A Windows shell you will love! babun的几个特点 使用babun无需管理员权限先进的安装包管理器(类似于linux上面的apt-get或yum)预先配置了Cygwin和很多插件拥有256色的兼容控制台HTTP(S)的代理支持面向插件的体系结构可以使用它来配置你的gi

显示器 Linux 性能 18 (一个命令行工具传递)

对于系统和网络管理员来说每天监控和调试Linux系统的性能问题是一项繁重的工作.在IT领域作为一名Linux系统的管理员工作5年后,我逐渐认识到监控和保持系统启动并执行是多么的不easy.基于此原因.我们已编写了最常使用的18个命令行工具列表,这些工具将有助于每一个Linux/Unix 系统管理员的工作.这些命令行工具能够在各种Linux系统下使用.能够用于监控和查找产生性能问题的解决办法.这个命令行工具列表提供了足够的工具.您能够挑选适用于您的监控场景的工具. 1.Top-Linux进程监控