k8s中kubectl陈述式资源管理

1、 理论

1.1、 管理k8s核心资源的三种基本方法 :

1.1.1陈述式的资源管理方法:

主要依赖命令行工具kubectl进行管理

1.1.1.1、优点:

可以满足90%以上的使用场景

对资源的增、删、查操作比较容易

1.1.1.2、缺点:

命令冗长,复杂,难以记忆

特定场景下,无法实现管理需求

对资源的修改麻烦,需要patch来使用json串更改**。**

1.1.2、声明式资源管理方法

主要依赖统一资源配置清单进行管理

1.1.3、GUI式资源管理方法

主要依赖图形化操作界面进行管理

1.2、陈述式资源管理方法

  1. kubernetes 集群管理集群资源的唯一入口是通过相应的方法调用 apiserver 的接口
  2. kubectl 是官方的CLI命令行工具,用于与 apiserver 进行通信,将用户在命令行输入的命令,组织并转化为 apiserver 能识别的信息,进而实现管理 k8s 各种资源的一种有效途径
  3. kubectl 的命令大全
  4. 对资源的增、删、查操作比较方便,但对改的操作就不容易了

k8s中文文档:http://docs.kubernetes.org.cn/683.html

2. 对资源的增、删、查操作

2.1、查看版本信息

bash 复制代码
kubectl version

2.2、查看资源对象简写

kubectl api-resources

2.3、查看集群信息

bash 复制代码
kubectl cluster-info

2.4、配置kubectl自动补全

1、直接命令行输出

bash 复制代码
source <(kubectl completion bash)

2、进入配置文件进行自动配置

bash 复制代码
vim /root/.bashrc
source <(kubectl completion bash)

2.5、node节点查看日志

bash 复制代码
journalctl -u kubelet -f

2.6、基本信息查看

kubectl get <resource> [-o wide|json|yaml] [-n namespace]

获取资源的相关信息,-n 指定命令空间,-o 指定输出格式

resource可以是具体资源名称,如pod nginx-xxx;也可以是资源类型,如pod;或者all(仅展示几种核心资源,并不完整)

--all-namespaces 或 -A :表示显示所有命令空间,

--show-labels :显示所有标签

-l app :仅显示标签为app的资源

-l app=nginx :仅显示包含app标签,且值为nginx的资源

2.7、显示所有的命名空间,详细信息

bash 复制代码
kubectl get --all namespces -A pod

2.8、查看pod wide格式相关详细信息

bash 复制代码
kubectl get pod -owide

2.9、yaml格式的

2.10、创建标签为ky29

bash 复制代码
kubectl create deployment ky29 --image=soscscs/myapp:v1

2.11查看通过标签创建的信息

bash 复制代码
kubectl get pod 

2.12、 显示所有的·app标签

2.13、查看 master 节点状态

bash 复制代码
kubectl get componentstatuses
kubectl get cs

2.14、查看命令空间

命令空间的作用:用于允许不同 命令空间 的 相同类型 的资源 重名的

bash 复制代码
kubectl get namespace
kubectl get ns

2.15、查看kube-system命名空间的所有资源

bash 复制代码
kubectl get all -n default

2.16、查看命名空间为default下面,ky29的信息

2.17、创建命名空间app

bash 复制代码
kubectl create ns app
kubectl get ns

创建命名空间ky10,并查看所有的命名空间

2.18、删除命名空间app

bash 复制代码
kubectl delete namespace app
kubectl get ns	

2.19、在命名空间ky10中创建一个创建一个名为"ky15-nginx"的部署,并使用镜像nginx

创建成功

2.20、描述某个资源的详细信息

bash 复制代码
kubectl describe pod ky15-nginx -n ky10

2.21、查看命名空间kuy10中的pod 信息

bash 复制代码
kubectl get pods -n ky10

2.22、kubectl exec可以跨主机登录容器,docker exec 只能在容器所在主机上登录

bash 复制代码
kubectl exec -it ky15-nginx bash -n ky10

2.23、删除pod资源

bash 复制代码
kubectl get pod -o wide
kubectl delete deployments.apps ky29
相关推荐
遇见火星14 分钟前
Ubuntu Docker 容器化部署教程
linux·ubuntu·docker
Panda__Panda3 小时前
docker项目打包演示项目(数字排序服务)
运维·javascript·python·docker·容器·c#
xx.ii3 小时前
Docker监控
运维·docker·容器
维尔切3 小时前
Docker 存储与数据共享
运维·docker·容器
温柔一只鬼.4 小时前
Docker快速入门——第四章Docker镜像
运维·docker·容器
程序猿费益洲4 小时前
Docker 网络详解:(三)四大网络模式
网络·docker·容器
一只代码狗4 小时前
Docker Desktop在MAC上无法强制关闭的命令清理方式
macos·docker·php
温柔一只鬼.4 小时前
Docker快速入门——Windowns系统下Docker安装(2025最新理解与完整,附带WSL1如何升级为WSL2)
运维·docker·容器
派阿喵搞电子5 小时前
关于使用docker部署srs服务器的相关指令
服务器·docker·容器
啊啊啊啊8435 小时前
Kubernetes 1.20集群部署
云原生·容器·kubernetes