Kubernetes》》K8S》》Deployment 、Pod、Rs 、部署 nginx
Deployment
deployment文档说明



kubectl get rs,deployment,pods
删除pod 、deployment 、service
# 如果只删除pod,deployment会自动重建,所以应该先删除deployment。
# 下面演示的是删除所有deployment,可以指定只删除某个
# 删除所有 deployment
kubectl delete deployment -all
# 删除指定 deployment
kubectl delete deployment deployment名称 -n 命名空间
# 基于资源清单删除
kubectl delete -f xxx.yaml# 删除所有pod
kubectl delete pod --all
# 删除指定pod
kubectl delete pod POD_NAME -n NAMESPACE_NAME# 删除service 因为pod都删除了,对应的service就没有用了
kubectl delete svc SERVICE_NAME -n NAMESPACE_NAME
kubectl delete pod tigera-operator-c78c656bf-fww8k -n tigera-operator --grace-period=0 --force


Deployment 文档说明
apiVersion: v1 #必填,版本号,例如v1
kind: Depolyment #必填
metadata: #必填,元数据name: string #必填,Pod名称namespace: string #必填,Pod所属的命名空间labels: #自定义标签- name: string #自定义标签名字<key: value>annotations: #自定义注释列表- name: string
spec: #必填,部署的详细定义selector: matchLabels:name: string #必填,通过此标签匹配对应pod<key: value>replicas: number #必填,副本数量template: #必填,应用容器模版定义metadata: labels: name: string #必填,遇上面matchLabels的标签相同spec: containers: #必填,定义容器列表- name: string #必填,容器名称image: string #必填,容器的镜像名称imagePullPolicy: [Always | Never | IfNotPresent] #获取镜像的策略 Alawys表示下载镜像 IfnotPresent表示优先使用本地镜像,否则下载镜像,Nerver表示仅使用本地镜像command: [string] #容器的启动命令列表,如不指定,使用打包时使用的启动命令args: [string] #容器的启动命令参数列表workingDir: string #选填,容器的工作目录env: #容器运行前需设置的环境变量列表- name: string #环境变量名称value: string #环境变量的值ports: #需要暴露的端口库号列表- name: string #选填,端口号名称containerPort: int #容器需要监听的端口号hostPort: int #选填,容器所在主机需要监听的端口号,默认与Container相同protocol: string #选填,端口协议,支持TCP和UDP,默认TCPresources: #资源限制和请求的设置limits: #资源限制的设置cpu: string #Cpu的限制,单位为core数,将用于docker run --cpu-shares参数memory: string #内存限制,单位可以为Mib/Gib,将用于docker run --memory参数requests: #资源请求的设置cpu: string #Cpu请求,容器启动的初始可用数量memory: string #内存清楚,容器启动的初始可用数量volumeMounts: #挂载到容器内部的存储卷配置- name: string #引用pod定义的共享存储卷的名称,需用volumes[]部分定义的的卷名mountPath: string #存储卷在容器内mount的绝对路径,应少于512字符readOnly: boolean #是否为只读模式livenessProbe: #对Pod内个容器健康检查的设置,当探测无响应几次后将自动重启该容器,检查方法有exec、httpGet和tcpSocket,对一个容器只需设置其中一种方法即可exec: #对Pod容器内检查方式设置为exec方式command: [string] #exec方式需要制定的命令或脚本httpGet: #对Pod内个容器健康检查方法设置为HttpGet,需要制定Path、portpath: stringport: numberhost: stringscheme: stringHttpHeaders:- name: stringvalue: stringtcpSocket: #对Pod内个容器健康检查方式设置为tcpSocket方式port: numberinitialDelaySeconds: 0 #容器启动完成后首次探测的时间,单位为秒timeoutSeconds: 0 #对容器健康检查探测等待响应的超时时间,单位秒,默认1秒periodSeconds: 0 #对容器监控检查的定期探测时间设置,单位秒,默认10秒一次successThreshold: 0failureThreshold: 0securityContext:privileged:false#Pod的重启策略,Always表示一旦不管以何种方式终止运行,kubelet都将重启,OnFailure表示只有Pod以非0退出码退出才重启,Nerver表示不再重启该PodrestartPolicy: [Always | Never | OnFailure]nodeSelector: obeject #设置NodeSelector表示将该Pod调度到包含这个label的node上,以key:value的格式指定imagePullSecrets: #Pull镜像时使用的secret名称,以key:secretkey格式指定- name: stringhostNetwork:false #是否使用主机网络模式,默认为false,如果设置为true,表示使用宿主机网络volumes: #在该pod上定义共享存储卷列表- name: string #共享存储卷名称 (volumes类型有很多种)emptyDir: {} #类型为emtyDir的存储卷,与Pod同生命周期的一个临时目录。为空值hostPath: string #类型为hostPath的存储卷,表示挂载Pod所在宿主机的目录path: string #Pod所在宿主机的目录,将被用于同期中mount的目录- name: string #共享存储卷名称secret: #类型为secret的存储卷,挂载集群与定义的secre对象到容器内部scretname: string items: - key: string #选择secrets定义的某个keypath: string #文件内容路径- name: string #共享存储卷名称configMap: #类型为configMap的存储卷,挂载预定义的configMap对象到容器内部name: stringitems:- key: string #选择configmap定义的某个keypath: string #文件内容路径- name: string #共享存储卷名称persistentVolumeClaim:claimName: string #类型为PVC的持久化存储卷
》》》案例
部署nginx
apiVersion: apps/v1
kind: Deployment
metadata:name: my-deploymentlabels:app: my-app
spec:replicas: 3# 战略 更新策略》》无停机更新strategy:# ① RollingUpdate 滚动更新 更新时会逐步创建新的Pod副本,替换旧的Pod,确保应用保持在线状态 默认的策略 # 更新具体步骤:# 创建新 Pod(以符合 maxSurge 配置的上限)。 #新 Pod 变为 Ready 状态时,停止旧的 Pod。 #不断重复以上步骤,直到所有旧的 Pod 替换为新 Pod。# ②Recreate(重建)# 策略会直接停止所有旧的 Pod 并创建新的 Pod,适合无状态服务或无需保证持续在线的应用。# strategy:# type: Recreatetype: RollingUpdaterollingUpdate:# 更新过程中允许的最大不可用 Pod 数量,支持绝对值或百分比(如 75%)。maxUnavailable: 1# 更新过程中允许的最大新建 Pod 数量,同样支持绝对值或百分比。maxSurge: 1selector:matchLabels:app: my-apptemplate:metadata:labels:app: my-appspec:containers:- name: my-containerimage: nginx:latestports:- containerPort: 80envFrom:- configMapRef:name: my-configresources:limits:memory: "256Mi"cpu: "500m"requests:memory: "128Mi"cpu: "250m"livenessProbe:httpGet:path: /port: 80initialDelaySeconds: 3periodSeconds: 3

更新操作

# 》》方法一 通过yaml文件更新
# 编辑 YAML 文件并重新应用。
kubectl apply -f my-deployment.yaml# 》》方法二:直接设置新镜像更新
kubectl set image deployment/my-deployment my-container=nginx:1.25# 查看更新状态
# 查看对应的deployment的更新状态kubectl rollout status deployment my-deployment
# 在滚动更新中,您可以选择暂停更新,以便在每一步观察应用行为。
# 暂停更新:指定具体要暂停更新的 deployment名称
kubectl rollout pause deployment my-deployment
# 恢复更新:指定具体要恢复更新的 deployment名称
kubectl rollout resume deployment my-deployment
Deployment 回滚
# 如果更新发生错误或出现异常,可以将 Deployment 回滚到上一个稳定版本:
# 执行回滚 指定具体要回归的 deployment名称
kubectl rollout undo deployment my-deployment# 查看历史记录:指定具体要历史记录的 deployment名称
kubectl rollout history deployment my-deployment# 回滚到指定版本:如果有多个历史记录,可以通过 --to-revision 指定回滚的版本。
# 将版本回滚到第三个版本
kubectl rollout undo deployment my-deployment --to-revision=3
Deployment 扩容和缩容详解
# Deployment 支持动态扩容和缩容,通过更改 replicas 数量来控制 Pod 的副本数量。
#(1)手动扩容或缩容: 指名具体的 deployment名称
kubectl scale deployment my-deployment --replicas=5
# (2)自动扩容(HPA)
# Kubernetes 支持基于 HorizontalPodAutoscaler(HPA)进行自动扩容,根据负载动态调整 Pod 副本数量:
kubectl autoscale deployment my-deployment --min=3 --max=5 --cpu-percent=85
Deployment 探针配置
探针(Probe)用于监测 Pod 是否健康,Kubernetes 提供了三种探针类型:
》》Liveness Probe:检测 Pod 是否正常工作。如果检测失败,会重启 Pod,如果在重启后 Liveness 探针仍然失败,Pod 将被标记为失败。。
》》Readiness Probe:检测Pod是否准备好接收流量。如果检测失败,Pod 不会参与负载均衡,这确保了新版本的容器在完全准备好之前不会接收到流量,从而避免对应用的不良影响。。
》》Startup Probe:用于启动检测,尤其适合启动时间较长的应用。
containers:- name: my-containerimage: nginx:1.25ports:- containerPort: 80livenessProbe: # 存活探针httpGet:path: /port: 80# 在容器启动后首次探测前的延迟时间。initialDelaySeconds: 5# 两次探测之间的时间间隔periodSeconds: 5readinessProbe: # 就绪探针httpGet:path: /port: 80initialDelaySeconds: 5periodSeconds: 5startupProbe: # 启动探针httpGet:path: /port: 80# 如果探测失败超过该值,容器会被重启或标记为不可用。failureThreshold: 30periodSeconds: 10
相关文章:
Kubernetes》》K8S》》Deployment 、Pod、Rs 、部署 nginx
Deployment deployment文档说明 kubectl get rs,deployment,pods 删除pod 、deployment 、service # 如果只删除pod,deployment会自动重建,所以应该先删除deployment。 # 下面演示的是删除所有deployment,可以指定只删除某个 # 删除所有…...
链表(C++)
这是本人第二次学习链表,第一次学习链表是在大一上的C语言课上,首次接触,感到有些难;第二次是在大一下学习数据结构时(就是这次),使用C再次理解链表。同时,这也是开启数据结构学习写…...
nginx 设置隐藏版本号
Nginx默认会在Server头里包含版本信息,比如“nginx/1.18.0”,这可能存在安全隐患,因为攻击者知道了版本号后,可以针对特定版本的漏洞进行攻击。所以,隐藏版本号是一个常见的安全措施。 可通过在http块里加上server_to…...
29_项目
目录 http.js 1、先注册账号 register.html 2、再登录 login.html 3、首页 index.html 4 详情 details.html cart.html css index.css register.css details.css 演示 进阶 http.js let baseURL "http://localhost:8888"; let resgiterApi baseURL &…...
排序算法1--插入排序
目录 1.常见排序算法 2.排序算法的预定函数 2.1交换函数 2.2测试算法运行时间的函数 3.插入排序 3.1直接插入排序 3.2希尔排序 3.3插入排序的时间复杂度分析 4.总结 1.常见排序算法 我将分别讲解五种排序算法,但是不代表只有五种固定的代码,之后…...
PolarDB数据库表恢复实战指南:通过控制台恢复表的完整操作流程
在数据库运维过程中,表数据恢复是一项常见且关键的操作。本文将详细介绍如何通过阿里云PolarDB控制台从备份中恢复特定表,并通过表重命名操作确保业务平稳过渡。 一、背景介绍 在日常数据库运维中,我们可能会遇到以下场景需要从备份中恢复表: 表数据被误删或损坏需要获取历…...
业之峰与宏图智能战略携手,开启家装数字化新篇章
3月8日,业之峰装饰集团董事长张钧携高管团队与宏图智能董事长庭治宏及核心团队,在业之峰总部隆重举行了战略合作签约仪式,标志着双方将携手探索业之峰的数字化转型之路,共同推动家装行业的变革与发展。 近年来,家装行业…...
matplotlib标题比x,y轴字体大,明明标题字体更大?
原始代码: plt.xlabel(训练轮次(Epochs), fontsize14, fontweightbold, fontpropertieschinese_font) # 设置中文字体、加大、加粗 plt.ylabel(R值, fontsize14, fontweightbold, fontpropertieschinese_font) # 设置中文字体、加大、加粗…...
【云原生】docker 搭建单机PostgreSQL操作详解
目录 一、前言 二、前置准备 2.1 服务器环境 2.2 docker环境 三、docker安装PostgreSQL过程 3.1 获取PostgreSQL镜像 3.2 启动容器 3.2.1 创建数据卷目录 3.2.2 启动pg容器 3.3 客户端测试连接数据库 四、创建数据库与授权 4.1 进入PG容器 4.2 PG常用操作命令 4.2…...
解决 Gradle 构建错误:Could not get unknown property ‘withoutJclOverSlf4J’
解决 Gradle 构建错误:Could not get unknown property ‘withoutJclOverSlf4J’ 在构建 Spring 源码或其他基于 Gradle 的项目时,可能会遇到如下错误: Could not get unknown property withoutJclOverSlf4J for object of type org.gradle…...
免费使用!OpenAI 全量开放 GPT-4o 图像生成能力!
2025年3月26日,OpenAI正式推出GPT-4o原生图像生成功能,这一更新不仅标志着多模态AI技术的重大突破,更引发了全球AI厂商的激烈竞争。从免费用户到企业开发者,从创意设计到科学可视化,GPT-4o正在重塑图像生成的边界。本文…...
jetson orin nano super AI模型部署之路(三)stable diffusion部署
先看一下部署后的界面和生成的图片。 在jetson orin nano super上部署stable diffusion比较简单,有现成的docker image和代码可用。 docker image拉取 使用的docker image是dustynv/stable-diffusion-webui,对于jetson orin nano super的jetpack6.2来说…...
深入理解:阻塞IO、非阻塞IO、水平触发与边缘触发
深入理解:阻塞IO、非阻塞IO、水平触发与边缘触发 在网络编程和并发处理中,理解不同的 I/O 模型和事件通知机制至关重要。本文将深入探讨阻塞IO(Blocking IO)、非阻塞IO(Non-Blocking IO)、水平触发&#x…...
WebRTC的ICE之TURN协议的交互流程中继转发Relay媒体数据的turnserver的测试
WebRTC的ICE之TURN协议的交互流程和中继转发Relay媒体数据的turnserver的测试 WebRTC的ICE之TURN协议的交互流程中继转发Relay媒体数据的turnserver的测试 WebRTC的ICE之TURN协议的交互流程和中继转发Relay媒体数据的turnserver的测试前言一、TURN协议1、连接Turn Server 流程①…...
HTTP---基础知识
天天开心!!! 文章目录 一、HTTP基本概念1. 什么是HTTP,又有什么用?2. 一次HTTP请求的过程3.HTTP的协议头4.POST和GET的区别5. HTTP状态码6.HTTP的优缺点 二、HTTP的版本演进1.各个版本的应用场景2、注意要点 三、HTTP与…...
Redis6数据结构之List类型
redis的List类型底层结构是双向链表,插入删除时间复杂度O(1)快,查找为O(n)慢。 应用场景:简单队列、最新评论列表、非实时排行榜(定时计算榜单,如笔记本日销榜单)。 常用命令: lpush将一个或多个值从左边…...
DeepSeek接入飞书多维表格,效率起飞!
今天教大家把DeepSeek接入飞书表格使用。 准备工作:安装并登录飞书;可以准备一些要处理的数据,确保数据格式正确,如 Excel、CSV 等,也可直接存储到飞书多维表格。 创建飞书多维表格:打开飞书,点…...
[FGPA基础学习]分秒计数器的制作
分秒计数器设计 本次实验内容为:DE2-115板子上用 Verilog编程实现一个 分秒计数器,并具备按键暂停、按键消抖功能 一、系统架构设计 顶层模块划分 顶层模块(top) ├── 按键消抖模块(key_debounce) ├…...
【Spring Boot 与 Spring Cloud 深度 Mape 之十】体系整合、部署运维与进阶展望
【Spring Boot 与 Spring Cloud 深度 Mape 之十】体系整合、部署运维与进阶展望 #微服务实战 #Docker #Kubernetes #SpringSecurity #OAuth2 #分布式事务 #Seata #ServiceMesh #总结 #SpringCloud #SpringBoot 系列终章:经过前九篇 [【深度 Mape 系列】] 的系统学习…...
【商城实战(97)】ELK日志管理系统的全面应用
【商城实战】专栏重磅来袭!这是一份专为开发者与电商从业者打造的超详细指南。从项目基础搭建,运用 uniapp、Element Plus、SpringBoot 搭建商城框架,到用户、商品、订单等核心模块开发,再到性能优化、安全加固、多端适配,乃至运营推广策略,102 章内容层层递进。无论是想…...
高并发系统下的订单号生成服务设计与实现
目录 引言 订单号设计的关键考量因素 基础需求分析 唯一性保障 数据量预估 可读性设计 系统架构考量 分库分表兼容 可扩展性设计 技术选型与比较 性能优化 高可用性保障 实践案例:高并发系统订单号结构设计 结构详解 业务类型标识(2位) 唯一标识部分…...
每日算法-250329
记录今天学习的三道算法题:两道滑动窗口和一道栈的应用。 2904. 最短且字典序最小的美丽子字符串 题目描述 思路 滑动窗口 解题过程 题目要求找到包含 k 个 ‘1’ 的子字符串,并且需要满足两个条件: 最短长度:在所有包含 k 个 …...
向量数据库学习笔记(2) —— pgvector 用法 与 最佳实践
关于向量的基础概念,可以参考:向量数据库学习笔记(1) —— 基础概念-CSDN博客 一、 pgvector简介 pgvector 是一款开源的、基于pg的、向量相似性搜索 插件,将您的向量数据与其他数据统一存储在pg中。支持功能包括&…...
蓝桥杯 之 二分
文章目录 习题肖恩的n次根分巧克力2.卡牌 二分是十分重要的一个算法,常常用于求解一定范围内,找到满足条件的边界值的情况主要分为浮点数二分和整数二分二分问题,最主要是写出这个check函数,这个check函数最主要就是使用模拟的方法…...
从零开始研发GPS接收机连载——18、北斗B1的捕获和跟踪
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 从零开始研发GPS接收机连载——18、北斗B1的捕获和跟踪 B1信号的捕获B1信号的跟踪 前面已经验证了射频能够接收到B1的信号,通过FPGA采集了IQ信号之后能够通过matl…...
sqlalchemy:将mysql切换到OpenGauss
说明 之前python的项目使用的mysql,近期要切换到国产数据库OpenGauss。 之前的方案是fastapisqlalchemy,测试下来发现不用改代码,只要改下配置即可。 切换方案 安装openGauss-connector-python-psycopg2 其代码工程在:https:…...
memtest86检测内存
上次在R730安装万兆网卡的时候,使用过memtest64进行测试。这个操作肯定是有用的,我就用这个方法查出有问题的内存条,及时找商家进行了更换。 但是该方案有个问题,只能锁定部分内存,如下图,只测试到了23G左…...
OpenCV图像拼接(10)用于实现图像拼接过程中的时间流逝(timelapse)效果的一个类cv::detail::Timelapser
操作系统:ubuntu22.04 OpenCV版本:OpenCV4.9 IDE:Visual Studio Code 编程语言:C11 算法描述 cv::detail::Timelapser 是 OpenCV 库中用于实现图像拼接过程中的时间流逝(timelapse)效果的一个类。它通常用于将一系列…...
验证linux多进程时间片切换的程序
一、软件需求 在同时运行一个或多个一味消耗 CPU 时间执行处理的进程时,采集以下统计信息。 ・在某一时间点运行在逻辑 CPU 上的进程是哪一个 ・每个进程的运行进度 通过分析这些信息,来确认本章开头对调度器的描述是否正确。实验程序的…...
【Basys3】外设-灯和数码管
灯 约束文件 set_property PACKAGE_PIN W5 [get_ports CLK] set_property PACKAGE_PIN U18 [get_ports rst] set_property PACKAGE_PIN U16 [get_ports {led[0]}] set_property PACKAGE_PIN E19 [get_ports {led[1]}] set_property PACKAGE_PIN U19 [get_ports {led[2]}] set…...

