K8S的资源管理

管理K8S资源的三种基本方法:

  • 陈述式资源管理方法-使用cli工具进行管理。
  • 声明式资源管理方式-主要依耐资源配置清单。
  • GUI式资源管理方法-主要依耐图形界面。

陈述式资源管理方法

1.1 查看名称空间

kubectl get namespace
kubectl get ns # 查看名称空间中的所有资源,不带-n默认就是查询default中的资源
kubectl get all -n default

1.2 创建名称空间

kubectl create namespace app

1.3 删除名称空间

# 删除名称空间会删除里面的所有资源

kubectl delete namespace app

app 名称空间名称

管理Deployment资源

Replica Set ------------------------------ 副本集

Deployment为PodReplica Set(升级版的 Replication Controller)提供声明式更新。

你只需要在 Deployment 中描述您想要的目标状态是什么,Deployment controller 就会帮您将 Pod 和ReplicaSet 的实际状态改变到您的目标状态。您可以定义一个全新的 Deployment 来创建 ReplicaSet 或者删除已有的 Deployment 并创建一个新的来替换。

注意:您不该手动管理由 Deployment 创建的 Replica Set,否则您就篡越了 Deployment controller 的职责!下文罗列了 Deployment 对象中已经覆盖了所有的用例。如果未有覆盖您所有需要的用例,请直接在 Kubernetes 的代码库中提 issue。

典型的用例如下:

  • 使用Deployment来创建ReplicaSet。ReplicaSet在后台创建pod。检查启动状态,看它是成功还是失败。
  • 然后,通过更新Deployment的PodTemplateSpec字段来声明Pod的新状态。这会创建一个新的ReplicaSet,Deployment会按照控制的速率将pod从旧的ReplicaSet移动到新的ReplicaSet中。
  • 如果当前状态不稳定,回滚到之前的Deployment revision。每次回滚都会更新Deployment的revision。
  • 扩容Deployment以满足更高的负载。
  • 暂停Deployment来应用PodTemplateSpec的多个修复,然后恢复上线。
  • 根据Deployment 的状态判断上线是否hang住了。
  • 清除旧的不必要的 ReplicaSet。

2.1 创建deployment

kubectl create deployment nginx-dp --image=harbor.od.com/public/nginx:v1.17.9 -n kube-public

nginx-dp    # 创建的名字
--image # 需要镜像
-n # 创建在那个名称空间 kubectl get pods -n kube-public -o wide -o wide # 以扩展的方式查看

2.2 查看deployment

kubectl get deployment

kubectl get deployment -n kube-public

-o wide    # 查看扩展信息

2.3 删除deployment

kubectl delete deployment nginx-dp -n kube-public

2.4 删除pod资源~重启

kubectl delete pod <pod-name> -n namespace

kubectl delete deploy nginx-dp -n kube-public
# 如果删除了pod,没有删除控制器,控制器会让pod达到一个预设置的状态,所以pod会自动的拉起来。这也是重启pod的一种方法。 # 强制删除
kubectl delete pod nginx-ds-trrwk --grace-period=0 --force

强制删除

kubectl delete pod nginx-ds-trrwk --grace-period=0 --force

管理service资源

1.现在可以看到创建的pod IP是172.7.22.3

2.当我们使用 kubectl delete pod nginx-dp -n kube-public 命令,删除pod之后再次查看,发现pod已经重新调度到了新的节点上面,而且pod的IP也更改了。

      在实际应用中如果是pod挂了,IP地址发生了改变,这样就会影响业务。所以`service`资源就是来解决这个问题的。

3.1 创建service资源

# 创建一个service资源,暴露一个端口。提供固定的业务访问接口。
kubectl expose deployment nginx-dp --port=80 -n kube-public #把nginx-dp的副本数改为2
kubectl scale deployment nginx-dp --replicas=2 -n kube-public scale # Set a new size for a Deployment, ReplicaSet, Replication Controller, or Job
# 设置一个新的deployment、副本数、Replication Controller。

更改为了两个pod

创建的service资源,并且提供了一个CLUSTER-IP ----------192.168.145.91,这样不管是pod的IP怎么变化始终service提供的接口IP是不会变化的。

底层原理,通过LVS进行转发,同时还起到了负载均衡的效果。

3.2 查看svc

kubectl describe service -n kube-public

kubectl describe svc -n kube-public

describe    # 显示详细的信息

总结

陈述式资源管理方法可以满足90%以上的资源管理需求,但它的缺点也很明显:

  • 命令冗长
  • 特定场景下,无法实现需求
  • 对资源增、删、查操作比较容易,改的话就非常不方便。

声明式资源管理方法

声明式资源管理方法,使用-----资源配置清单(yaml\json)

获取资源配置请单

[root@hdss7-21 ~]# kubectl get svc nginx-dp -n kube-public -o yaml

apiVersion: v1
kind: Service
metadata:
creationTimestamp: "2021-04-13T07:21:39Z"
labels:
app: nginx-dp
name: nginx-dp
namespace: kube-public
resourceVersion: "40542"
selfLink: /api/v1/namespaces/kube-public/services/nginx-dp
uid: 92efaf9c-0af4-4576-ad03-12cec6fdfb35
spec:
clusterIP: 192.168.145.91
ports:
- port: 80
protocol: TCP
targetPort: 80
selector:
app: nginx-dp
sessionAffinity: None
type: ClusterIP
status:
loadBalancer: {} # 必须要有的三个段
apiVersion:
kind:
metadata:
spec: # 查看帮助文档
kubectl explain deployment.kind

使用资源配置清单暴露service接口

cat>>nginx-ds-svc.yaml<<EOF
apiVersion: v1
kind: Service
metadata:
labels:
app: nginx-ds
name: nginx-ds
namespace: default
spec:
ports:
- port: 80
protocol: TCP
targetPort: 80
selector:
app: nginx-ds
type: ClusterIP
EOF # 应用资源配置清单
kubectl apply -f nginx-ds-svc.yaml # 查看资源
kubectl get svc nginx-ds -o wide

离线更改service暴露的端口

vi nginx-ds-svc.yaml

apiVersion: v1
kind: Service
metadata:
labels:
app: nginx-ds
name: nginx-ds
namespace: default
spec:
ports:
- port: 8080
protocol: TCP
targetPort: 80
selector:
app: nginx-ds
type: ClusterIP [root@hdss7-21 ~]# kubectl apply -f nginx-ds-svc.yaml
service/nginx-ds configured

在线更改

kubectl edit svc nginx-ds

删除资源配置

陈述式删除

kubectl delete svc nginx-ds

声明式

kubectl delete -f nginx-ds-svc.yaml

最新文章

  1. JavaEE学习文章汇总-ssm框架
  2. python 函数式编程
  3. C语言文件的读写
  4. 加州大学伯克利分校Stat2.2x Probability 概率初步学习笔记: Section 2 Random sampling with and without replacement
  5. 常用jquery插件资料
  6. 初识HTTP 1.1与HTTP 1.0
  7. linux 源码编译(转)
  8. C# 利用WORD模板和标签(bookmark) 批量生成WORD
  9. oracle内置sql函数(转)
  10. JavaScript使用技巧
  11. Matlab基础知识
  12. rsync unison+inotify双向实时同步
  13. 淘宝的数据库拆分(TDDL)(转)
  14. Linux 查找命令汇总
  15. UOJ Round #15 [构造 | 计数 | 异或哈希 kmp]
  16. 苹果IOS与谷歌 android系统的UI设计原则
  17. SVN 服务器端权限管理
  18. P2157 [SDOI2009]学校食堂
  19. 对osg节点添加glsl特效(片断着色器FragmentShader)
  20. git pull refusing to merge unrelated histories

热门文章

  1. 201871030106-陈鑫莲 实验三 结对项目—《D{0-1}KP 实例数据集算法实验平台》项目报告
  2. 通过Dapr实现一个简单的基于.net的微服务电商系统
  3. Vim快速使用教程
  4. Mediapipe 在RK3399PRO上的初探(一)(编译、运行CPU和GPU Demo, RK OpenglES 填坑,编译bazel)
  5. kubeadm安装kubernetes1.18.5
  6. ML.NET 示例:图像分类模型训练-首选API(基于原生TensorFlow迁移学习)
  7. 1.7.1- HTML表格table
  8. 【动态数据源切换失败】由于事务@Transactional注解导致动态数据源切换失效的问题
  9. hdu1815 2sat + 二分 + 建图
  10. POJ3122贪心或者二分(分蛋糕)