前言

本篇是Kubernetes第三篇,大家一定要把环境搭建起来,看是解决不了问题的,必须实战。本篇重要介绍kubectl的使用。

Kubernetes系列文章:
  1. Kubernetes介绍
  2. Kubernetes环境搭建

kubectl的核心功能在于通过 API Server 操作 Kubernetes 的各种资源对象,包括资源对象的创建、删除、查看、修改、配置、运行等等,学习kubectl相关命令是了解 Kubernetes 集群管理的一种手段。

kubectl语法

kubectl [command] [TYPE] [NAME] [flags]
  1. command:指定在一个或多个资源上要执行的操作。例如:create、get、describe、delete、apply;
  2. TYPE:指定资源类型。资源类型区分大小写,您可以指定单数,复数或缩写形式;
  3. Name: 指定资源的名称。名称区分大小写。如果省略名称,则会显示所有资源的详细信息;
#获取相同类型的资源信息  type name1 name2
kubectl get pod example-pod1 example-pod2
#获取不同类型对象资源  type/name type2/name2
kubectl get pod/example1 replicationcontroller/example2
#同时应用多个YAML文件,以多个-f flie参数表示
kubectl get pod -f pod1.yaml -f pod2.yaml
  1. 指定可选的标记。例如,可以使用 -s 或 --server标识来指定Kubernetes API服务器的地址和端口;-n指定名称空间;
输出格式

kubectl命令可以对结果进行多种格式化显示,输出的格式通过-o参数指定:

kubectl [command] [TYPE] [NAME] -o <output_format>

常用的输出格式如下:


img
  1. 自定义列名展示;
kubectl get pod
#value就是pod定义字段
kubectl get pods -o custom-columns=NAME:.metadata.name,UID:.metadata.uid,imageName:.spec.containers[0].image

image.png
  1. 自定义列名配置文件名称;
#自定义需要展示列名文件
vim custom-col.conf
#输入下面内容
NAME          UID          imageName                containerPort
metadata.name metadata.uid spec.containers[0].image spec.containers[0].ports[0].containerPort
#指定文件输出
kubectl get pod -o custom-columns-file=custom-col.conf

image.png
  1. json格式输出;
kubectl get pod -o json

image.png
  1. 输出jsonpath文件内容;
kubectl get pods -o jsonpath='{.items[0].metadata.name},{.items[0].spec.containers[0].image}'

image.png
  1. 通过自定义jsonpath文件输出自定义内容;
#自定义JSONPath文件
vim custom-json.conf
#输入自定义的内容
{.items[0].metadata.name},{.items[0].spec.containers[0].image},{.items[0].spec.containers[0].ports[0].containerPort}
#按照格式输出
kubectl get pod -o jsonpath-file=custom-json.conf
  1. 仅打印资源对象的名称;
kubectl get pod -o name

image.png
  1. 展示更多的Pod信息;
kubectl get pod -o wide

image.png
  1. 以yaml的格式显示结果;
kubectl get pod -o yaml

image.png

关于kubectl的命令很多,大家可以参考下官方文档,这里就不详细介绍每个命令,大家只要掌握常用的命令即可,下面的篇幅就是介绍大家常用命令;

kubectl常用命令

  1. kubectl create/replace 和 kubectl apply 部署或者替换资源,kubectl replace的执行过程,是使用新的 YAML文件中的 API 对象,替换原有的 API 对象,kubectl apply,则是执行了一个对原有 API 对象的patch 操作,这里建议大家使用kubectl apply操作;
#使用create创建一个Deployment资源对象 使用上个章节的yaml文件
kubectl create -f nginx-deployment.yaml
#修改命令 可以通过kubectl edit 还可以使用修改nginx-deployment.yaml文件,
#后使用 kubectl replace 来触发更新 我们修改限制内存的为256,这种方式我们称为命令式配置文件操作
kubectl replace -f nginx-deployment.yaml
#我们也可以使用kubectl apply创建对象资源
kubectl apply -f nginx-deployment.yaml
#然后通过修改nginx-deployment.yaml文件,执行kubectl apply就可以完成资源修改
kubectl apply -f nginx-deployment.yaml
  1. kubectl get 列出查看同一种类型一个或者多个资源对象;
#列出所有的pod
kubectl get pods
#列出某个节点上的所有的pod
kubectl get pods --field-selector=spec.nodeName=节点的名称
#筛选标签为testing=true的pod
kubectl get pod -l testing=true
  1. kubectl describe 查看资源的详细信息,kubectl describe相比于kubectl get来说,更多关注资源方面的详情,会返回节点信息、节点时间等等,kubectl get 用户查看同一种类型一个或者多个资源对象;
#查看某个pod详细信息
kubectl describe pod/nginx-deployment-776b4d7488-jfcjq
#查看某个node详细信息
kubectl describe nodes/demo-work-1
  1. kubectl delete 删除输入的指定的资源对象,也可以通过标签选择器、名称、资源选择器来删除特定资源范围;
#删除指定类型的pod
kubectl delete -f pod.yaml
#删除所有label-key:label-value的信息
kubectl delete pods -l label-key=label-value
  1. kubectl exec 在pod的容器中运行命令;
#进入/bin/bash交互界面
kubectl exec -it nginx-deployment-776b4d7488-jfcjq -- /bin/bash
  1. kubectl logs 打印Pod中容器的日志;
#打印日志
kubectl logs nginx-deployment-776b4d7488-jfcjq
#持续监控pod日志
kubectl logs -f nginx-deployment-776b4d7488-jfcjq
  1. kubectl edit 在线编辑资源对象;
#在线编辑deployment资源
kubectl edit deploy nginx-deployment
  1. 将Pod端口映射到宿主机端口;
#将Pod 80端口映射到宿主机 8888
kubectl port-forward --address 172.21.122.230,localhost pod/nginx-deployment-776b4d7488-jfcjq 8888:80
#打开另外一个界面访问
curl http://172.21.122.230:8888
  1. 容器与宿主机之间复制文件;
kubectl cp nginx-deployment-776b4d7488-jfcjq:/etc/fastab  /tmp
  1. 设置资源对象标签;
#给pod设置testing=true的标签 
kubectl label pod nginx-deployment-776b4d7488-jfcjq testing=true
#筛选标签为testing=true的pod
kubectl get pod -l testing=true
  1. 最重要的命令,帮助命令;
#列出command的类型
kubectl
#列出某种command的使用文档
kubectl command --help

结束

欢迎大家点点关注,点点赞!

Kubernetes-kubectl介绍的更多相关文章

  1. 附001.kubectl介绍及使用

    一 kubectl介绍 1.1 kubectl概要 kubectl控制Kubernetes集群管理器,使用Kubernetes命令行工具kubectl在Kubernetes上部署和管理应用程序.使用k ...

  2. 三十五、kubernetes NameSpace介绍

    Kubernetes NameSpace 介绍 Kubernetes使用命名空间的概念帮助解决集群中在管理对象时的复杂性问题.命名空间允许将对象分组到一起,便于将它们作为一个单元进行筛选和控制.无论是 ...

  3. 三十四、kubernetes证书介绍

    Kubernetes 证书介绍 一.证书机制说明 Kubernetes 作为一个分布式集群的管理工具,保证集群的安全性是其一个重要的任务.API Server 是集群内部各个组件通信的中介,也是外部控 ...

  4. 三十一、kubernetes网络介绍

    Kubernetes 网络介绍 Service是Kubernetes的核心概念,通过创建Service,可以为一组具有相同功能的容器应用提供一个统一的入口地址,并且将请求负载分发到后端的各个容器应用上 ...

  5. Kubernetes --- 详细介绍和架构详解

    Kubernetes是一个跨主机集群的开源的容器调度平台,它可以自动化应用容器的部署,扩展和操作,提供以容器为中心的基础架构 目录 一. Kubernetes用途 二. Kubernetes特点 三. ...

  6. Kubernetes kubectl 命令概述

    kubectl用于运行Kubernetes集群命令的管理工具. 语法 kubectl [command] [TYPE] [NAME] [flags] command:指定要在一个或多个资源执行的操作 ...

  7. K8S Kubernetes 简单介绍 转自 http://time-track.cn/kubernetes-trial.html Kubernetes初体验

    这段时间学习了一下 git jenkins docker  最近也在看  Kubernetes  感觉写得很赞  也是对自己对于K8S 有了进一步得理解  感谢 倪 大神得Blog 也希望看到这篇Bl ...

  8. 第一篇:《Kubernetes 入门介绍》

    前言:本文是一篇 kubernetes(下文用 k8s 代替)的入门文章,将会涉及 k8s 的技术历史背景.架构.集群搭建.一个 Redis 的例子,以及如何使用 operator-sdk 开发 op ...

  9. Kubernetes组件介绍

    一.api-server   基本概念 该端口默认值为6443,可通过启动参数"--secure-port"的值来修改默认值. 默认IP地址为非本地(Non-Localhost)网 ...

  10. Kubernetes kubectl 命令

    kubectl 命令用来操作 Kubernetes 集群中的资源对象,包括对资源的创建.删除.查看.修改.配置.运行等 命令语法:kubectl [command] [TYPE] [NAME] [fl ...

随机推荐

  1. 解决:CannotAcquireResourceException: A ResourcePool could not acquire a resource from its primary factory or source.

    log4j给出的异常信息有下面几句: Caused by: org.hibernate.exception.GenericJDBCException: Unable to acquire JDBC C ...

  2. Qt学习-ListView的拖拽

    最近在学习Qt 里面的QML, 使用DropArea和MouseArea实现了ListView的拖拽. 想起了当年用Delphi, 差不多一样的东西, 不过那是2000了. Delphi也是不争气啊, ...

  3. 免费,好用的天气预报API

    不多说直接上! 一.API服务,天气API 网站:http://api.help.bj.cn/api/ 怎么使用网站有很详细的解释 $.ajax({ type: "GET", // ...

  4. 时间-i春秋

    记一道跑脚本的题 进入页面拿到一段代码. <?php header("content-type:text/html;charset=utf-8"); '天下武功唯快不破'; ...

  5. MapReduce框架原理-MapTask和ReduceTask工作机制

    MapTask工作机制 并行度决定机制 1)问题引出 maptask的并行度决定map阶段的任务处理并发度,进而影响到整个job的处理速度.那么,mapTask并行任务是否越多越好呢? 2)MapTa ...

  6. springcloud搭建高可用注册中心的时候注册中心在unavailable-replicas中的问题

    在搭建springcloud eureka高可用注册中心时,发现另一个注册中心一直在unavailable-replicas不可用分片,原因为原来为单个注册中心的时候,禁止了注册中心自主注册为服务和检 ...

  7. Adaptive AUTOSAR 学习笔记 14 - 车辆诊断

    本系列学习笔记基于 AUTOSAR Adaptive Platform 官方文档 R20-11 版本 AUTOSAR_EXP_PlatformDesign.pdf.作者:Zijian/TENG 原文地 ...

  8. Linux命令(九)之安装mysql

    .personSunflowerP { background: rgba(51, 153, 0, 0.66); border-bottom: 1px solid rgba(0, 102, 0, 1); ...

  9. 批量删除gmail邮件

    以删除tor.com发送的邮件为例说明. 首先点击邮件搜索框右边的三角,在"发件人"下面写上"tor.com": 点"搜索"按钮,看一下范围 ...

  10. 《手把手教你》系列技巧篇(十九)-java+ selenium自动化测试-元素定位大法之By css下卷(详细教程)

    1.简介 按计划今天宏哥继续讲解css的定位元素的方法.但是今天最后一种宏哥介绍给大家,了解就可以了,因为实际中很少用. 2.常用定位方法(8种) (1)id(2)name(3)class name( ...