k8s的陈述式资源管理(命令行操作)

2023-12-30 06:36

本文主要是介绍k8s的陈述式资源管理(命令行操作),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

(一)k8s的陈述式资源管理

1、命令行:kubectl命令行工具——用于一般的资源管理

1优点:90%以上ce场景都可以满足
2特点:对资源的增、删、查比较方便,对改不是很友好
3缺点:命令比较冗长,复杂,难记

2、声明式:k8s当中的yaml文件来实现资源管理——用于配置部署服务

3、GUI:图形化工具的管理

(二)kubectl命令的详解:查看、部署、查看pod的情况(详细信息和日志,发布和回滚)

kubectl命令的详解

kubectl命令行大全:http://docs.kubernetes.org.cn/683.html

先声明动作:create、delete、get、describe

对象:ns、pod、service

对象的名称:hyde nginx

查看

查看版本

kubectl version

查看所有api的资源对象的名称

kubectl api-resources

查看k8s的集群信息

kubectl cluster-info

基本信息查看:

查看master节点的状态

kubectl get cs

查看默认命令空间内的pod信息

kubectl get pod/pods

查看当前集群的所有命名空间

kubectl get ns

查看指定命名空间内的pod信息

kubectl get pod -n kube-system命名空间的名称

查看默认命名空间内pod的详细信息(IP、节点信息)

kubectl get pod -o wide

查看指定命名空间内pod的详细信息

kubectl get pod -o wide -n kube-system

查看node节点的信息和状态

kubectl get nodes/node

查看node节点的详细信息

kubectl get node -o wide

查看已经部署好的pod的详细信息

kubectl describe pod nginx-6799fc88d8-89g2npod的名称

查看指定命名空间内pod的详细信息

kubectl describe pod -n kube-system etcd-master

查看pod的日志

kubectl logs nginx-6799fc88d8-89g2n

动态查看pod的日志

kubectl logs -f nginx-6799fc88d8-89g2n

查看指定命名空间内的日志

kubectl logs -n kube-system etcd-master

创建命名空间

kubectl create ns hyde

删除命名空间

kubectl delete ns hyde

删除pod

kubectl delete pod nginx-6799fc88d8-89g2npod名称)——实际上并没有删除

deployment的部署pod

deployment部署的方式:陈述式部署(命令行)、声明式部署(yml文件)

deployment部署的特点:

①滚动更新:不是一次性的把所有pod全部部署,而是一个一个来,pod更新时使用,逐步的引入新的pod,逐步的减少旧的pod

②自我修复:如果有pod节点发生故障,deployment会自动启动新的pod来进行代替,如果更新有问题,deployment会提供还原点,可以手动还原到未更新前的状态

③扩容和缩容:deployment可以随时调整pod的数量,以适应流量的变化

* 上述的功能必须是基于deployment创建的服务才可以,大多数的pod都是使用deployment创建的

* 基于deployment创建的pod,或者是daemonset方式创建的pod,是由控制器创建的pod,使用delete删除pod是删除不掉,相当于重启pod

查看命名空间内通过deployment创建的pod

kubectl get deployments

查看指定命名空间内通过deployment创建的pod

kubectl get deployments -n kube-system

查看命名空间内通过daemonset创建的pod

kubectl get daemonsets

查看指定命名空间内通过daemonset创建的pod

kubectl get daemonsets -n kube-system

* daemonset部署不能通过命令行创建,只能在yml文件中定义这种创建方式。

* daemonset后台运行创建,在每个节点上都创建一个相同方式的,相同版本的容器运行的pod,一般都是依赖环境和重要组件,一般也不会对这些资源进行操作

创建deployment副本

kubectl create deployment nginx-dn --image=nginx

在指定命名空间创建deployment

kubectl create deployment nginx-dn --image=nginx --replicas=3 -n hyde

删除pod(一旦删除deployment,基于deployment创建的pod都会被删除)——慎用

kubectl delete deployments.apps nginx-dn -n hyde

不是基于控制器deployment创建的pod,用delete可以直接删除

kubectl run nginx2 --image=nginx很少使用

kubectl delete pod nginx2

远程进入节点容器

kubectl exec -it nginx-6799fc88d8-blx25 bash

docker的exec只能在本机内部使用,不能跨主机,kubectl的exec可以跨主机进入容器

指定命名空间进入容器

kubectl exec -it  nginx-6799fc88d8-4zqld bash -n hyde

kubectl delete pod nginx1-6f54f4bd96-gmkdb --force --grace-period=0

主要用于结束卡在Terminating销毁状态的pod

grace-period

表示过度的存活期,默认是30秒,可以让pod优雅的结束容器内的进程,然后退出pod;0表示立刻停止pod,必须要force

对基于deployment创建的pod进行扩容和缩容:

扩容

kubectl scale deployment nginx-dn --replicas=3

缩容

kubectl scale deployment nginx-dn --replicas=1

发布服务的service:

service的类型:生产中用ExternalName做域名映射+NodePort对外提供访问

ClusterIP

创建service的默认类型,提供一个集群内部的虚拟IP地址,这是service的默认类型,通过这个虚拟IP可以直接访问pod 的资源,无法对外提供访问

NodePort

会在每一个node节点上都开放一个相同的端口,外部可以通过node的本机IP+端口,访问pod资源(集群外部访问service的一种方式,四层代理方式),访问方式是nodeip:nodeport,nodeport可以随机指派,也可以指定(范围30000-32767)

LoadBalancer

如果service的类型设定为LoadBalancer,映射地址(云平台提供LoadBalancer的地址),这种用法仅用于公有云服务供应商在云平台上设置的service的场景,外部来访问,实现负载均衡,LoadBalancer的地址是要付费的。创建好了service,指定类型为LoadBalancer,会给你提供一个地址来代理pod内部的IP地址

ExternalName

DNS映射,给service分配一个域名,通过域名来访问后端的pod资源,ExternalName的service类型,不能提供负载均衡,必须要设置一个LoadBalancer的地址才能实现

查看集群中的service

kubectl get svc

删除service

kubectl delete svc nginx

查看指定命名空间的service

kubectl get svc -n kube-system

①创建pod:kubectl create deployment nginx --image=nginx:1.10 --replicas=3

②基于deployment创建service:

kubectl expose deployment nginx --port=80 --target-port=80 --name=nginx-service --type=NodePort

* --port=80:service集群内部的端口,是service和容器映射的端口,任意

* --target-port=80:pod内部容器的端口

NodePort  10.96.112.70:集群内部的IP地址,外部可不易访问这个IP地址

80:32168/TCP

* 80:对应的内部的service的端口

* 32168:和内部的service的80端口做映射(本机的端口)

③实现负载均衡:

④修改service中nodeport的地址:

更新和回滚,以及发布的方式:

项目的生命周期:创建——发布——更新——回滚——删除

更新

kubectl set image deployment nginx nginx=nginx:1.20

curl -I 20.0.0.71:31000

回滚

①查看回滚点:kubectl rollout history deployment nginx

②记录回滚点变更:kubectl set image deployment nginx nginx=:1.15 --record

③回滚:kubectl rollout undo deployment nginx --to-revision=2

查看回滚的状态

kubectl rollout status deployment nginx

②kubectl get pod -w:动态查看pod的更新情况

查看集群内部的所有信息

kubectl get all

这篇关于k8s的陈述式资源管理(命令行操作)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/552001

相关文章

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

k8s中实现mysql主备过程详解

《k8s中实现mysql主备过程详解》文章讲解了在K8s中使用StatefulSet部署MySQL主备架构,包含NFS安装、storageClass配置、MySQL部署及同步检查步骤,确保主备数据一致... 目录一、k8s中实现mysql主备1.1 环境信息1.2 部署nfs-provisioner1.2.

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

Python内存管理机制之垃圾回收与引用计数操作全过程

《Python内存管理机制之垃圾回收与引用计数操作全过程》SQLAlchemy是Python中最流行的ORM(对象关系映射)框架之一,它提供了高效且灵活的数据库操作方式,本文将介绍如何使用SQLAlc... 目录安装核心概念连接数据库定义数据模型创建数据库表基本CRUD操作创建数据读取数据更新数据删除数据查

Go语言中json操作的实现

《Go语言中json操作的实现》本文主要介绍了Go语言中的json操作的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录 一、jsOChina编程N 与 Go 类型对应关系️ 二、基本操作:编码与解码 三、结构体标签(Struc

k8s admin用户生成token方式

《k8sadmin用户生成token方式》用户使用Kubernetes1.28创建admin命名空间并部署,通过ClusterRoleBinding为jenkins用户授权集群级权限,生成并获取其t... 目录k8s admin用户生成token创建一个admin的命名空间查看k8s namespace 的

k8s搭建nfs共享存储实践

《k8s搭建nfs共享存储实践》本文介绍NFS服务端搭建与客户端配置,涵盖安装工具、目录设置及服务启动,随后讲解K8S中NFS动态存储部署,包括创建命名空间、ServiceAccount、RBAC权限... 目录1. NFS搭建1.1 部署NFS服务端1.1.1 下载nfs-utils和rpcbind1.1

Java 字符串操作之contains 和 substring 方法最佳实践与常见问题

《Java字符串操作之contains和substring方法最佳实践与常见问题》本文给大家详细介绍Java字符串操作之contains和substring方法最佳实践与常见问题,本文结合实例... 目录一、contains 方法详解1. 方法定义与语法2. 底层实现原理3. 使用示例4. 注意事项二、su

k8s容器放开锁内存限制问题

《k8s容器放开锁内存限制问题》nccl-test容器运行mpirun时因NCCL_BUFFSIZE过大导致OOM,需通过修改docker服务配置文件,将LimitMEMLOCK设为infinity并... 目录问题问题确认放开容器max locked memory限制总结参考:https://Access