当前位置: 首页 > news >正文

k8s pod根据指标自动扩缩容举例

目录

基于 内存 指标实现pod自动扩缩容 举例配置

基于 cpu 指标实现pod自动扩缩容 举例配置

基于请求数(次/秒) 指标实现pod自动扩缩容  举例配置

基于 http请求响应时间 (ms) 指标实现pod自动扩缩容  举例配置

基于 Java GC暂停时间 (ms) 指标实现pod自动扩缩容 举例配置

扩展点

prometheus对所有pod进行流量监控 配置举例



基于 内存 指标实现pod自动扩缩容 举例配置

首先,需要在Kubernetes集群中部署一个HPA(Horizontal Pod Autoscaler),它可以基于内存使用量自动调整Pod的数量。

以下是HPA的示例配置:

apiVersion: autoscaling/v2beta2  
kind: HorizontalPodAutoscaler  
metadata:  name: my-app-hpa  
spec:  scaleTargetRef:  apiVersion: apps/v1  kind: Deployment  name: my-app-deployment  minReplicas: 2  maxReplicas: 10  metrics:  - type: Resource  resource:  name: memory  targetAverageUtilization: 80 # 目标内存使用率(%)

上述配置中,HPA会根据内存使用量自动调整Pod的数量。

scaleTargetRef指定了要扩展的Pod对象(这里是一个Deployment)。

minReplicasmaxReplicas分别指定了Pod的最小和最大数量。

metrics指定了度量指标,这里使用的是内存使用量。

targetAverageUtilization设置了一个目标内存使用率,当内存使用率超过这个值时,HPA会自动扩展Pod的数量。

为了能够正确地监测内存使用量,需要为Pod配置相应的监控指标。这可以通过加入resources字段来实现,如下所示:

apiVersion: v1  
kind: Pod  
metadata:  name: my-app-pod  
spec:  containers:  - name: my-app-container  resources:  requests:  memory: "64Mi" # 请求64MB内存  limits:  memory: "128Mi" # 限制128MB内存  # ...其他配置...

在这个例子中,Pod中的容器会根据配置的内存限制来运行。

requests指定了Pod启动所需的最小内存,而limits则指定了Pod运行过程中所能够使用的最大内存。

这些配置可以帮助Kubernetes更好地管理资源,避免资源浪费和竞争。

基于 cpu 指标实现pod自动扩缩容 举例配置

下面是一个基于CPU使用率实现Kubernetes Pod自动扩展的示例配置。

首先,需要在Kubernetes集群中部署一个HPA(Horizontal Pod Autoscaler),它可以基于CPU使用率自动调整Pod的数量。

以下是HPA的示例配置:

apiVersion: autoscaling/v2beta2  
kind: HorizontalPodAutoscaler  
metadata:  name: my-app-hpa  
spec:  scaleTargetRef:  apiVersion: apps/v1  kind: Deployment  name: my-app-deployment  minReplicas: 2  maxReplicas: 10  metrics:  - type: Resource  resource:  name: cpu  targetAverageUtilization: 80 # 目标CPU使用率(%)

上述配置中,HPA会根据CPU使用率自动调整Pod的数量。

scaleTargetRef指定了要扩展的Pod对象(这里是一个Deployment)。

minReplicasmaxReplicas分别指定了Pod的最小和最大数量。

metrics指定了度量指标,这里使用的是CPU使用率。

targetAverageUtilization设置了一个目标CPU使用率,当CPU使用率超过这个值时,HPA会自动扩展Pod的数量。

需要注意的是,为了能够正确地监测CPU使用率,需要为Pod配置相应的监控指标。这可以通过在Pod中加入resources字段来实现,例如:

apiVersion: v1  
kind: Pod  
metadata:  name: my-app-pod  
spec:  containers:  - name: my-app-container  resources:  requests:  cpu: "100m" # 请求1个CPU核心100毫核(m核)  limits:  cpu: "200m" # 限制2个CPU核心200毫核(m核)  # ...其他配置...

在这个例子中,Pod中的容器会根据配置的CPU资源限制来运行。

requests指定了Pod启动所需的最小CPU资源,

limits则指定了Pod运行过程中所能够使用的最大CPU资源。

基于请求数(次/秒) 指标实现pod自动扩缩容  举例配置

下面是一个基于每秒请求数(Requests per second,RPS)实现Kubernetes Pod自动扩展的示例配置。

首先,需要使用一个HTTP代理或服务来监控每个Pod的RPS,比如一个Prometheus Operator。以下是一个Prometheus Operator的示例配置:

apiVersion: rbac.authorization.k8s.io/v1beta1  
kind: ClusterRoleBinding  
metadata:  name: prometheus-operator  
subjects:  
- kind: ServiceAccount  name: prometheus-operator  namespace: kube-system  
roleRef:  kind: ClusterRole  name: prometheus-operator

接下来,创建一个Prometheus ServiceMonitor资源以监视HTTP代理的RPS

apiVersion: monitoring.coreos.com/v1  
kind: ServiceMonitor  
metadata:  name: myapp-requests  
spec:  jobLabel: "myapp"  selector:  matchLabels:  myapp: my-app  relabelings:  - sourceLabels: [__meta_service_namespace, __meta_service_name]  targetLabel: source  action: keep  - sourceLabels: [__meta_kubernetes_pod_container_id]  targetLabel: container_id  action: keep  - sourceLabels: [__meta_kubernetes_pod_name]  targetLabel: pod_name  action: keep  - sourceLabels: [__meta_kubernetes_pod_label_myapp]  targetLabel: myapp  action: keep  metricsPath: /metrics  scheme: http  httpGet:  path: /metrics  port: 8000

在这个示例中,ServiceMonitor资源将根据Pod的标签选择器和HTTP Get请求监视my-app服务的RPS。请注意,您需要根据您的应用程序和环境进行自定义。

最后,创建一个HPA(Horizontal Pod Autoscaler)来根据RPS自动调整Pod的数量:

apiVersion: autoscaling/v2beta2  
kind: HorizontalPodAutoscaler  
metadata:  name: my-app-hpa  
spec:  scaleTargetRef:  apiVersion: apps/v1  kind: Deployment  name: my-app-deployment  minReplicas: 2  maxReplicas: 100  metrics:  - type: PodsMetricSource  podsMetricSource:  metricName: "requests_per_second" # 指定要监视的指标名称(例如:requests_per_second)  targetAverageValue: 10 # 目标RPS(例如:每秒10个请求)

在这个示例中,HPA将根据Pod的RPS自动调整Pod的数量。当RPS超过设定的目标值时,HPA将增加更多的Pod,以保持服务的高可用性和响应能力。

基于 http请求响应时间 (ms) 指标实现pod自动扩缩容  举例配置

首先,需要创建一个自定义度量源(Custom Metric Source),这里假设你的度量源是由Prometheus Operator提供的,可以按照以下步骤进行操作:

apiVersion: monitoring.coreos.com/v1  
kind: Prometheus  
metadata:  name: my-app-http-response-time  
spec:  http:  servicePort: 9090  metrics:  - name: http_response_time_seconds_count  help: Count of HTTP requests with response time greater than 1 second.  expression: sum(rate(http_request_duration_seconds_count{job="my-app"}[1m])) by (job)

上述配置中定义了一个Prometheus资源,用于收集HTTP请求的响应时间指标。http_request_duration_seconds_count是一个Prometheus指标,用于表示每秒HTTP请求的计数,通过rate()函数计算每分钟的平均请求速率,并使用sum()函数对所有job进行聚合。最终,通过by(job)对每个job进行分组,以便与Pod数量进行关联。

接下来,使用以下配置创建一个HPA对象:

apiVersion: autoscaling/v2beta2  
kind: HorizontalPodAutoscaler  
metadata:  name: my-app-hpa  
spec:  scaleTargetRef:  apiVersion: apps/v1  kind: Deployment  name: my-app-deployment  minReplicas: 2  maxReplicas: 10  metrics:  - type: PodsMetricSource  podsMetricSource:  metricName: http_response_time_seconds_count  targetAverageValue: 100 # 目标平均响应时间(秒)  thresholds:  - type: PodsMetricSource  podsMetricSource:  metricName: http_response_time_seconds_count  targetAverageValue: 5 # 每秒HTTP请求的目标计数(可根据需求调整)

上述配置中,HPA使用了PodsMetricSource类型的度量源,该度量源从Pod级别的度量指标中获取数据。

metricName设置为http_response_time_seconds_count,表示使用之前创建的自定义度量源来收集HTTP请求响应时间的指标数据。

targetAverageValue设置了一个目标响应时间的平均值,单位为秒。在此示例中,目标响应时间为5秒。

同时,为了更好地控制扩缩容的灵敏度,还添加了一个额外的阈值(threshold),该阈值使用相同的度量指标,但设置了每秒HTTP请求的目标计数。在此示例中,如果每秒HTTP请求的数量超过5,HPA将触发扩容操作。

请注意,上述示例仅为了演示如何基于HTTP请求响应时间实现Pod自动扩缩容,并提供了基本的配置示例。实际应用中,可能需要根据具体需求进行调整和优化。

基于 Java GC暂停时间 (ms) 指标实现pod自动扩缩容 举例配置

基于Java GC暂停时间实现自动扩缩容可以用来优化应用性能,避免由于GC暂停时间过长导致的应用延迟或卡顿。以下是一个基于GC暂停时间实现Pod自动扩缩容的示例配置,假设使用Kubernetes和Prometheus作为监控工具。

创建自定义度量源:

首先,需要从Prometheus中获取GC暂停时间的指标数据。可以使用以下配置创建一个自定义度量源,从Prometheus中获取GC暂停时间的指标数据:

apiVersion: monitoring.coreos.com/v1  
kind: Prometheus  
metadata:  name: my-app-gc-pause-time  
spec:  http:  servicePort: 9091  metrics:  - name: gc_pause_time_seconds_sum  help: Total GC pause time in seconds.  expression: sum(irate(gc_pause_time_seconds_sum[5m])) by (pod)

上述配置中,创建了一个Prometheus资源,用于收集GC暂停时间的指标数据。gc_pause_time_seconds_sum表示GC暂停时间的总和,使用irate()函数计算最近5分钟内每分钟的平均暂停时间,并使用sum()函数对所有Pod进行聚合。最终,通过by(pod)对每个Pod进行分组,以便与Pod数量进行关联。

接下来,使用以下配置创建一个HPA对象:

apiVersion: autoscaling/v2beta2  
kind: HorizontalPodAutoscaler  
metadata:  name: my-app-hpa  
spec:  scaleTargetRef:  apiVersion: apps/v1  kind: Deployment  name: my-app-deployment  minReplicas: 2  maxReplicas: 10  metrics:  - type: PodsMetricSource  podsMetricSource:  metricName: gc_pause_time_seconds_sum  targetAverageValue: 10 # 目标平均GC暂停时间(秒)  thresholds:  - type: PodsMetricSource  podsMetricSource:  metricName: gc_pause_time_seconds_sum  targetAverageValue: 2 # 每分钟GC暂停时间的目标计数(可根据需求调整)

上述配置中,HPA使用了PodsMetricSource类型的度量源,该度量源从Pod级别的度量指标中获取数据。

metricName设置为gc_pause_time_seconds_sum,表示使用之前创建的自定义度量源来收集GC暂停时间的指标数据。

targetAverageValue设置了一个目标GC暂停时间的平均值。在此示例中,目标GC暂停时间为2秒。

同时,为了更好地控制扩缩容的灵敏度,还添加了一个额外的阈值(threshold),该阈值使用相同的度量指标,但设置了每分钟GC暂停时间的目标计数。在此示例中,如果每分钟GC暂停时间超过2,HPA将触发扩容操作。

请注意,上述示例仅为了演示如何基于Java GC暂停时间实现Pod自动扩缩容,并提供了基本的配置示例。实际应用中,可能需要根据具体的应用场景、GC类型、监控工具等进行调整和优化。

扩展点

prometheus对所有pod进行流量监控 配置举例

Prometheus是一个开源的监控和告警工具,它可以用于监控各种系统和应用程序的性能。要使用Prometheus监控所有Pod的流量,您可以按照以下步骤进行设置:

  1. 安装和配置Prometheus:首先,您需要在您的Kubernetes集群中安装和配置Prometheus。这可以通过使用Kubernetes的Helm Chart或类似的工具来完成。您可以参考Prometheus的官方文档以获取更详细的安装和配置说明。

  2. 创建ServiceMonitor资源:在您的Kubernetes集群中,为每个要监控的Pod或服务创建一个ServiceMonitor资源。ServiceMonitor资源允许Prometheus监控指定服务的指标。以下是一个示例ServiceMonitor资源的配置:

apiVersion: monitoring.coreos.com/v1  
kind: ServiceMonitor  
metadata:  name: my-pod-service-monitor  
spec:  namespace: your-namespace # 指定要监控的Pod所属的命名空间  selector:  matchLabels:  app: your-pod-app-label # 指定要监控的Pod的标签  endpoints:  - basicAuth:  password:  name: your-pod-metrics-password # 指定metrics服务的密码  key: password  username: your-pod-metrics-username # 指定metrics服务的用户名  path: /metrics # 指定metrics服务的路径  port: your-pod-metrics-port # 指定metrics服务的端口

根据您的实际情况修改上述示例中的命名空间、标签、用户名、密码和端口等信息

3. 创建Prometheus目标:在Prometheus的配置文件(通常是prometheus.yml)中,创建一个新的目标,用于监控Pod的流量。以下是一个示例配置:

scrape_configs:  - job_name: 'pod-traffic'  kubernetes_sd_configs:  - role: pod  relabel_configs:  - source_labels: [__meta_kubernetes_pod_label_app]  target_label: pod_app_label  - source_labels: [__meta_kubernetes_pod_container_id]  target_label: pod_container_id  - source_labels: [__address__]  target_label: pod_address  regex: ([^:]+)(?::\d+)?  - source_labels: [__metrics_path__]  target_label: pod_metrics_path

上述配置中,我们指定了job_namepod-traffic,并配置了kubernetes_sd_configs以发现Pod。relabel_configs用于重标记指标的元数据,以便更方便地识别和组织指标数据。

4. 重新加载Prometheus配置:保存并关闭Prometheus的配置文件后,使用以下命令重新加载Prometheus配置:

curl -X POST http://<prometheus-address>:9090/-/reload

其中<prometheus-address>是Prometheus服务的主机名或IP地址。

5. 监视Pod流量:现在,Prometheus将会收集所有指定Pod的流量指标,并在其查询界面上显示它们。您可以使用Prometheus的查询语言(PromQL)来编写查询,以获取有关Pod流量的度量标准和趋势等信息。例如,以下查询可以获取所有Pod的总请求计数:

sum(rate(http_requests_total{job="pod-traffic"}[1m])) by (pod_app_label)

相关文章:

k8s pod根据指标自动扩缩容举例

目录 基于 内存 指标实现pod自动扩缩容 举例配置 基于 cpu 指标实现pod自动扩缩容 举例配置 基于请求数&#xff08;次/秒&#xff09; 指标实现pod自动扩缩容 举例配置 基于 http请求响应时间 (ms) 指标实现pod自动扩缩容 举例配置 基于 Java GC暂停时间 (ms) 指标实现…...

深、浅拷贝之间的关系

深、浅拷贝之间的关系 什么是赋值 赋值是将某一数值或对象赋给某个变量的过程&#xff0c;分为下面 2 部分 基本数据类型&#xff1a;赋值&#xff0c;赋值之后两个变量互不影响引用数据类型&#xff1a;赋址&#xff0c;两个变量具有相同的引用&#xff0c;指向同一个对象&…...

服务器数据恢复-某银行服务器硬盘数据恢复案例

服务器故障&分析&#xff1a; 某银行的某一业务模块崩溃&#xff0c;无法正常使用。排查服务器故障&#xff0c;发现运行该业务模块的服务器中多块硬盘离线&#xff0c;导致上层应用崩溃。 故障服务器内多块硬盘掉线&#xff0c;硬盘掉线数量超过服务器raid阵列冗余级别所允…...

仪器器材经营小程序商城的作用是什么

互联网发展下&#xff0c;数字化转型已经成为常态&#xff0c;仅依赖传统线下经营模式将很难再增长。 作为产品销售及客户维护度高的仪器器材行业&#xff0c;拥有自营商城平台是必要的&#xff0c;不仅可以解决以上难题&#xff0c;还利于打造自身品牌多渠道传播&#xff0c;…...

京东数据分析:2023年9月京东洗烘套装品牌销量排行榜!

鲸参谋监测的京东平台9月份洗烘套装市场销售数据已出炉&#xff01; 根据鲸参谋平台的数据显示&#xff0c;今年9月份&#xff0c;京东平台洗烘套装的销量为7100&#xff0c;环比下降约37%&#xff0c;同比增长约87%&#xff1b;销售额为6000万&#xff0c;环比下降约48%&#…...

论文阅读-多目标强化学习-envelope MOQ-learning

introduction 一种多目标强化学习算法&#xff0c;来自2019 Nips《A Generalized Algorithm for Multi-Objective Reinforcement Learning and Policy Adaptation》本文引用代码全部来源于论文中的链接。主要参考run_e3c_double.py文件 1 总体思想 1.将输入中加入多目标的偏…...

【原创】【考法总结】指针*与++结合的题目考法总结

代码均已调试出结果&#xff0c;放心食用&#xff0c;大致总共5种考法 【理论铺垫】①a[i]恒等价于(ai)即*(&a[0]i)&#xff1b;i类似偏移量&#xff08;别忘a代表数组首元素地址即&a[0]&#xff09; ②*(&a[i])恒等价于a[i]&#xff1a;&a[i]表示a[i]的地址&a…...

react dispatch不生效的坑

一、前言 最近写react antd项目&#xff0c;在A页面中使用了dispatch方法&#xff0c;然后B页面中嵌套A页面&#xff0c;没有问题&#xff1b; 但是在C页面中嵌套A页面的时候&#xff0c;就发现dispatch方法没有执行&#xff0c;也不报错&#xff0c;就很奇怪&#xff1b; 还…...

Mingw快捷安装教程 并完美解决出现的下载错误:The file has been downloaded incorrectly

安装c语言编译器的时候&#xff0c;老是出现The file has been downloaded incorrectly&#xff0c;真的让人 直接去官网拿压缩包&#xff1a;https://sourceforge.net/projects/mingw-w64/files/ &#xff08;往下拉找到那个x86_64-win32-seh的链接&#xff0c;点击后会自动…...

OpenGL —— 2.6、绘制一个正方体并贴图(附源码,glfw+glad)

源码效果 C源码 纹理图片 需下载stb_image.h这个解码图片的库&#xff0c;该库只有一个头文件。 具体代码&#xff1a; vertexShader.glsl #version 330 corelayout(location 0) in vec3 aPos; layout(location 1) in vec2 aUV;out vec2 outUV;uniform mat4 _viewMatrix; u…...

JavaWeb从入门到起飞笔记——导学课程

学完这一节&#xff0c;我不知道学Web开发究竟能干什么&#xff1f;你知道吗&#xff1f; 以下是黑马程序员Java从入门到起飞的笔记 一、学完Javaweb能干什么&#xff1f; 学完Java后我们可以独立开发一些后台管理系统&#xff0c;例如CRMER器&#xff0c;京东和淘宝&#x…...

【LeetCode:1402. 做菜顺序 | 动态规划 + 贪心】

&#x1f680; 算法题 &#x1f680; &#x1f332; 算法刷题专栏 | 面试必备算法 | 面试高频算法 &#x1f340; &#x1f332; 越难的东西,越要努力坚持&#xff0c;因为它具有很高的价值&#xff0c;算法就是这样✨ &#x1f332; 作者简介&#xff1a;硕风和炜&#xff0c;…...

基于FPGA的图像拉普拉斯变换实现,包括tb测试文件和MATLAB辅助验证

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a vivado2019.2 3.部分核心程序 timescale 1ns / 1ps // // Company: // Engineer: // // Create Date: 202…...

高校教务系统登录页面JS分析——巢湖学院

高校教务系统密码加密逻辑及JS逆向 本文将介绍高校教务系统的密码加密逻辑以及使用JavaScript进行逆向分析的过程。通过本文&#xff0c;你将了解到密码加密的基本概念、常用加密算法以及如何通过逆向分析来破解密码。 本文仅供交流学习&#xff0c;勿用于非法用途。 一、密码加…...

人工智能、机器学习、深度学习的区别

人工智能涵盖范围最广&#xff0c;它包含了机器学习&#xff1b;而机器学习是人工智能的重要研究内容&#xff0c;它又包含了深度学习。 人工智能&#xff08;AI&#xff09; 人工智能是一门以计算机科学为基础&#xff0c;融合了数学、神经学、心理学、控制学等多个科目的交…...

Element Plus el-select选择框失去焦点blur

正常情况下&#xff0c;可以使用 el-select 自带的方法 blur 事件来使select失去焦点 示例&#xff1a; <el-select v-model"value" ref"selectRef"><el-optionv-for"item in options":key"item.value":label"item.la…...

Java File与IO流学习笔记

内存中存放的都是临时数据&#xff0c;但是在断电或者程序终止时都会丢失 而硬盘则可以长久存储数据&#xff0c;即使断电&#xff0c;程序终止&#xff0c;也不会丢失 File File是java.io.包下的类&#xff0c;File类的对象&#xff0c;用于代表当前操作系统的文件(可以是文…...

LabVIEW中PID控制的的高级功能

LabVIEW中PID控制的的高级功能 比例-积分-微分&#xff08;PID&#xff09;控制占当今控制和自动化应用的90%以上&#xff0c;主要是因为它是一种有效且简单的解决方案。虽然PID算法最初用于线性、时不变系统&#xff0c;但现在已经发展到控制具有复杂动力学的系统。在现实世界…...

STM32基于HAL库RT-Thread Demo测试

STM32基于HAL库RT-Thread Demo测试 &#x1f388;源码地址&#xff1a;https://github.com/RT-Thread/rt-thread/tree/master&#x1f4cc;基于STM32CUBEMX中间件安装《基于 CubeMX 移植 RT-Thread Nano》&#x1f4cd;环境搭建《使用 Env 创建 RT-Thread 项目工程》&#x1f5…...

萌新小白必做题(2)找素数

一.思路分析 先来看看素数的性质&#xff1a; 素数又称质数&#xff0c;是指除了1和本身外没有其它因数的自然数。素数有许多有趣的性质和应用&#xff0c;例如可以用于加密算法和数学证明等。比如2、3、5、7等都是素数&#xff0c;而4、6、8、9等则不是素数。素数的研究是数…...

超短脉冲激光自聚焦效应

前言与目录 强激光引起自聚焦效应机理 超短脉冲激光在脆性材料内部加工时引起的自聚焦效应&#xff0c;这是一种非线性光学现象&#xff0c;主要涉及光学克尔效应和材料的非线性光学特性。 自聚焦效应可以产生局部的强光场&#xff0c;对材料产生非线性响应&#xff0c;可能…...

如何在看板中体现优先级变化

在看板中有效体现优先级变化的关键措施包括&#xff1a;采用颜色或标签标识优先级、设置任务排序规则、使用独立的优先级列或泳道、结合自动化规则同步优先级变化、建立定期的优先级审查流程。其中&#xff0c;设置任务排序规则尤其重要&#xff0c;因为它让看板视觉上直观地体…...

Python爬虫实战:研究feedparser库相关技术

1. 引言 1.1 研究背景与意义 在当今信息爆炸的时代,互联网上存在着海量的信息资源。RSS(Really Simple Syndication)作为一种标准化的信息聚合技术,被广泛用于网站内容的发布和订阅。通过 RSS,用户可以方便地获取网站更新的内容,而无需频繁访问各个网站。 然而,互联网…...

django filter 统计数量 按属性去重

在Django中&#xff0c;如果你想要根据某个属性对查询集进行去重并统计数量&#xff0c;你可以使用values()方法配合annotate()方法来实现。这里有两种常见的方法来完成这个需求&#xff1a; 方法1&#xff1a;使用annotate()和Count 假设你有一个模型Item&#xff0c;并且你想…...

VTK如何让部分单位不可见

最近遇到一个需求&#xff0c;需要让一个vtkDataSet中的部分单元不可见&#xff0c;查阅了一些资料大概有以下几种方式 1.通过颜色映射表来进行&#xff0c;是最正规的做法 vtkNew<vtkLookupTable> lut; //值为0不显示&#xff0c;主要是最后一个参数&#xff0c;透明度…...

【开发技术】.Net使用FFmpeg视频特定帧上绘制内容

目录 一、目的 二、解决方案 2.1 什么是FFmpeg 2.2 FFmpeg主要功能 2.3 使用Xabe.FFmpeg调用FFmpeg功能 2.4 使用 FFmpeg 的 drawbox 滤镜来绘制 ROI 三、总结 一、目的 当前市场上有很多目标检测智能识别的相关算法&#xff0c;当前调用一个医疗行业的AI识别算法后返回…...

Java多线程实现之Thread类深度解析

Java多线程实现之Thread类深度解析 一、多线程基础概念1.1 什么是线程1.2 多线程的优势1.3 Java多线程模型 二、Thread类的基本结构与构造函数2.1 Thread类的继承关系2.2 构造函数 三、创建和启动线程3.1 继承Thread类创建线程3.2 实现Runnable接口创建线程 四、Thread类的核心…...

SAP学习笔记 - 开发26 - 前端Fiori开发 OData V2 和 V4 的差异 (Deepseek整理)

上一章用到了V2 的概念&#xff0c;其实 Fiori当中还有 V4&#xff0c;咱们这一章来总结一下 V2 和 V4。 SAP学习笔记 - 开发25 - 前端Fiori开发 Remote OData Service(使用远端Odata服务)&#xff0c;代理中间件&#xff08;ui5-middleware-simpleproxy&#xff09;-CSDN博客…...

管理学院权限管理系统开发总结

文章目录 &#x1f393; 管理学院权限管理系统开发总结 - 现代化Web应用实践之路&#x1f4dd; 项目概述&#x1f3d7;️ 技术架构设计后端技术栈前端技术栈 &#x1f4a1; 核心功能特性1. 用户管理模块2. 权限管理系统3. 统计报表功能4. 用户体验优化 &#x1f5c4;️ 数据库设…...

SQL慢可能是触发了ring buffer

简介 最近在进行 postgresql 性能排查的时候,发现 PG 在某一个时间并行执行的 SQL 变得特别慢。最后通过监控监观察到并行发起得时间 buffers_alloc 就急速上升,且低水位伴随在整个慢 SQL,一直是 buferIO 的等待事件,此时也没有其他会话的争抢。SQL 虽然不是高效 SQL ,但…...