Kubernetes集群操作

查看集群信息:

kubectl get nodes

删除节点

(⽆效且显示的也可以删除)

后期如果 要删除某个节点,为了不增加其他节点的访问压力,先增加一个节点,再删除要删除的节点

语法 :kubect delete node 节点名

如果删除后,该节点需要再次加入集群,在master重置token,打印加入的命令

kubeadm token create --print-join-command

拿着打印的命令,再要加入的node节点执行

kubeadm reset

kubeadm join 192.168.88.110:6443 --token lbstm5.q1ebkuj09swyok2z --discovery-token-ca-cert-hash sha256:96c19c5b7d281678b7c80be1b6145a05bb337012658c8e6bc6419928acbc84ab

单独查看某⼀个节点

(节点名称可以用空格隔开写多个)

kubectl get node k8s-node1

使用 kubectl describe 命令,查看⼀个 API 对象的详细信息:

注意:Events(事件) 值得你特别关注

在 Kubernetes 执⾏的过程中,对 API 对象的所有重要操作,都会被记录在这个对象的 Events ⾥,并且显示在 kubectl describe 指令返回的结果中。

这个部分正是我们将来进⾏ Debug 的重要依据。如果有异常发⽣,⼀定要第⼀时间查看这些 Events,往往可以看到⾮常详细的错误信息。

查看node的详细信息

kubectl describe node k8s-node1

#注意:最后被查看的节点名称只能用get nodes⾥⾯查到的name!

cpu

Requests: 200m (10%) --- 表示容器请求的 CPU 资源为 200 毫核(milli-cores),即 0.2 个核心,占据了总 CPU 资源的 10%。

Limits: 100m (5%) --- 表示容器的 CPU 限制为 100 毫核,即 0.1 个核心,占据了总 CPU 资源的 5%。

memory

Requests: 100Mi (2%) --- 表示容器请求的内存资源为 100 MiB,占据了总内存资源的 2%。

Limits: 50Mi (1%) --- 表示容器的内存限制为 50 MiB,占据了总内存资源的 1%。

ephemeral-storage

Requests: 0 (0%) --- 表示容器请求的临时存储资源为 0。

Limits: 0 (0%) --- 表示容器的临时存储限制为 0。

hugepages-1Gi

解释

Requests 是容器启动时 Kubernetes 调度器用来决定节点上可用资源的基础。它代表了容器正常运行所需的最低资源量。

Limits 是容器可以使用的最大资源量。超出这个限制,容器可能会被限制或终止。

查看各组件信息:

NAME: kubernetes --- 这是服务的名称。

TYPE: ClusterIP --- 这是服务的类型。ClusterIP 类型的服务只能在集群内部访问,无法从外部直接访问。

CLUSTER-IP: 10.96.0.1 --- 这是服务在集群内部的虚拟 IP 地址。它用于将流量路由到服务后端的 Pods。

EXTERNAL-IP: <none> --- 这个字段显示为 <none>,意味着该服务没有配置外部 IP,也就是说,外部网络不能直接访问这个服务。ClusterIP 类型的服务默认没有外部 IP。

PORT(S): 443/TCP --- 这是服务监听的端口和协议。这里是 TCP 协议的 443 端口。

AGE: 19h --- 这是服务创建的时间,从创建到现在已经过去了 19 小时。

在不同的namespace⾥⾯查看service:

在不同的namespace⾥⾯查看service:

[root@kub-k8s-master ~]# kubectl get service -n kube-system

-n:namespace名称空间

查看所有名称空间内的资源:

[root@kub-k8s-master ~]# kubectl get pods --all-namespaces

同时查看多种资源信息:

[root@kub-k8s-master ~]# kubectl get pod,service -n kube-system

查看主节点:

[root@k8s-master prome]# kubectl cluster-info

api查询:

[root@kub-k8s-master ~]# kubectl api-versions

创建名称空间

1.编写yaml文件

[root@kub-k8s-master ~]# mkdir prome

[root@kub-k8s-master ~]# cd prome/

[root@kub-k8s-master prome]# vim namespace.yml

--- # yaml开始的标记

apiVersion: v1 #api版本

kind: Namespace #类型---固定的

metadata: #元数据

name: ns-monitor #给命名空间起个名字

labels: #用于给这个 Namespace 添加标签。标签是键值对,可以用于标识、组织和选择资源

name: ns-monitor # 该namespace的标签

2.创建资源

[root@k8s-master prome]# kubectl apply -f namespace.yml

3.查看资源

[root@k8s-master prome]# kubectl get namespace

注:

namespace 可以缩写为 ns

既:

kubectl get ns

4.查看某⼀个namespace

[root@k8s-master prome]# kubectl get namespace ns-monitor

5.根据标签名查询命名空间

而我们在上面输入的lable中的name的值 monitor_hah_lale,是给这个命名空间打的一个标签,键值对形式出现,可以用于标签查询,查询有特定标签的namespace

[root@k8s-master prome]# kubectl get namespaces --selector=name=monitor_hah_lale

6.查看某个namespace的详细信息

Annotations: <none> # 没有注释

Status: Active #表示处于正常状态
7.修改名称空间的名字

不能直接修改,删除原有的命名空间,创建新的命名空间

kubectl create namespace new-namespace-name

或者 修改yml文件,重新创建


apiVersion: v1

kind: Namespace

metadata:

name: ns-monitor1 # 从ns-monitor 改为 ns-monitor1

labels:

name: monitor_hah_lale

删除老的命名空间

[root@k8s-master prome]# kubectl delete namespace ns-monitor

namespace "ns-monitor" deleted

[root@k8s-master prome]# kubectl get ns

7.删除名称空间

[root@k8s-master prome]## kubectl delete -f namespace.yml

[root@k8s-master prome]## kubectl delete namespace ns-monitor

相关推荐
恩爸编程1 小时前
探索 Nginx:Web 世界的幕后英雄
运维·nginx·nginx反向代理·nginx是什么·nginx静态资源服务器·nginx服务器·nginx解决哪些问题
Michaelwubo2 小时前
Docker dockerfile镜像编码 centos7
运维·docker·容器
远游客07132 小时前
centos stream 8下载安装遇到的坑
linux·服务器·centos
马甲是掉不了一点的<.<2 小时前
本地电脑使用命令行上传文件至远程服务器
linux·scp·cmd·远程文件上传
jingyu飞鸟2 小时前
centos-stream9系统安装docker
linux·docker·centos
好像是个likun2 小时前
使用docker拉取镜像很慢或者总是超时的问题
运维·docker·容器
超爱吃士力架3 小时前
邀请逻辑
java·linux·后端
LIKEYYLL4 小时前
GNU Octave:特性、使用案例、工具箱、环境与界面
服务器·gnu
云云3215 小时前
搭建云手机平台的技术要求?
服务器·线性代数·安全·智能手机·矩阵
云云3215 小时前
云手机有哪些用途?云手机选择推荐
服务器·线性代数·安全·智能手机·矩阵