Kubernetes(k8s)容器编排控制器使用

news2025/1/4 16:00:12

目录

  • 1 Pod控制器
    • 1.1 Pod控制器是什么
    • 1.2 Pod和Pod控制器
    • 1.3 控制器的必要性
    • 1.4 常见的控制器
      • 1.4.1 ReplicaSet
      • 1.4.2 Deployment
      • 1.4.3 DaemonSet
  • 2 ReplicaSet控制器
    • 2.1 ReplicaSet概述
    • 2.2 ReplicaSet功能
      • 2.2.1 精确反应期望值
      • 2.2.2 保证高可用
      • 2.2.3 弹性伸缩
    • 2.3 创建ReplicaSet
      • 2.3.1 核心属性
      • 2.3.2 ReplicaSet示例
    • 2.4 更新控制器
      • 2.4.1 应用更新
    • 2.5 RS扩缩容
      • 2.5.1 scale命令扩容
      • 2.5.2 配置文件缩容
    • 2.6 删除rs控制器
      • 2.6.1 查看集群情况
      • 2.6.2 删除rs
      • 2.6.3 查看集群情况
      • 2.6.4 删除Pod
  • 3 Deployment控制器
    • 3.1 Deployment概述
      • 3.1.1 其他特性
    • 3.2 Deployment配置
      • 3.2.1 编辑资源清单
      • 3.2.2 配置项说明
      • 3.2.3 创建控制器
      • 3.2.4 查看replicaset
    • 3.3 更新策略
      • 3.3.1 重建更新
      • 3.3.2 滚动更新
    • 配置参数
    • 3.4 更新控制器
      • 3.4.1 命令更新
      • 3.4.2 配置更新
      • 3.4.3 回滚更新
      • 3.4.4 再次回滚
      • 3.4.5 回滚指定版本
    • 3.5 Deployment扩缩容
      • 3.5.1 scale命令扩容
      • 3.5.2 配置文件缩容
    • 3.6 删除Deployment
      • 3.6.1 查看集群情况


1 Pod控制器

在这里插入图片描述

1.1 Pod控制器是什么

Pod控制器就是帮助我们自动的调度管理Pod,并满足期望的Pod数量。

	Pod控制器是用于实现管理pod的中间层,确保pod资源符合预期的状态,pod的资源出现故障时,会尝试进行重启,当根据重启策略无效,则会重新新建pod的资源。

	创建为具体的控制器对象之后,每个控制器均通过`API Server`提供的接口持续监控相关资源对象的当前状态,并在因故障、更新或其他原因导致系统状态发生变化时,尝试让资源的当前状态想期望状态迁移和逼近。

1.2 Pod和Pod控制器

Pod控制器资源通过持续性地监控集群中运行着的Pod资源对象来确保受其管控的资源严格符合用户期望的状态,例如资源副本的数量要精确符合期望等。

通常,一个Pod控制器资源至少应该包含三个基本的组成部分:

  • 标签选择器:匹配并关联Pod资源对象,并据此完成受其管控的Pod资源计数。
  • 期望的副本数:期望在集群中精确运行着的Pod资源的对象数量。
  • Pod模板:用于新建Pod资源对象的Pod模板资源。

1.3 控制器的必要性

	自主式`Pod`对象由调度器调度到目标工作节点后即由相应节点上的`kubelet`负责监控其容器的存活状态,容器主进程崩溃后,`kubelet`能够自动重启相应的容器,但对出现非主进程崩溃类的容器错误却无从感知,这便依赖于`pod`资源对象定义的存活探测,以便`kubelet`能够探知到此类故障。

	但若`pod`被删除或者工作节点自身发生故障(工作节点上都有`kubelet`,`kubelet`不可用,因此其健康状态便无法保证),则便需要控制器来处理相应的容器重启和配置。

1.4 常见的控制器

Pod控制器由masterkube-controller-manager组件提供,常见的此类控制器有以下几种

1.4.1 ReplicaSet

	代用户创建指定数量的`pod`副本数量,确保`pod`副本数量符合预期状态,并且支持滚动式自动扩容和缩容功能

1.4.2 Deployment

	工作在`ReplicaSet`之上,用于管理无状态应用,目前来说最好的控制器。支持滚动更新和回滚功能,还提供声明式配置。

1.4.3 DaemonSet

	用于确保集群中的每一个节点只运行特定的`pod`副本,常用于实现系统级后台任务,比如`ELK`服务

2 ReplicaSet控制器

2.1 ReplicaSet概述

ReplicaSet是取代早期版本中的ReplicationController控制器,其功能基本上与ReplicationController相同

	`ReplicaSet`(简称RS)是`Pod`控制器类型的一种实现,用于确保由其管控的`Pod`对象副本数在任意时刻都能精确满足期望的数量,`ReplicaSet`控制器资源启动后会查找集群中匹配器标签选择器的`Pod`资源对象,当前活动对象的数量与期望的数量不吻合时,多则删除,少则通过`Pod`模板创建以补足。

2.2 ReplicaSet功能

ReplicaSet能够实现以下功能:

2.2.1 精确反应期望值

	**确保Pod资源对象的数量精确反映期望值:**`ReplicaSet`需要确保由其控制运行的Pod副本数量精确吻合配置中定义的期望值,否则就会自动补足所缺或终止所余。

2.2.2 保证高可用

	**确保Pod健康运行:**探测到由其管控的`Pod`对象因其所在的工作节点故障而不可用时,自动请求由调度器于其他工作节点创建缺失的`Pod`副本。

2.2.3 弹性伸缩

	**弹性伸缩:**可通过`ReplicaSet`控制器动态扩容或者缩容`Pod`资源对象的数量,必要时还可以通过`HPA`控制器实现`Pod`资源规模的自动伸缩。

2.3 创建ReplicaSet

2.3.1 核心属性

spec字段一般嵌套使用以下几个属性字段:

字段值类型描述
replicasInteger指定期望的Pod对象副本数量
selectorObject当前控制器匹配Pod对象副本的标签选择器,支持matchLabels和matchExpressions两种匹配机制
templateObject用于定义Pod时的Pod资源信息
minReadySecondsInteger用于定义Pod启动后多长时间为可用状态,默认为0秒

2.3.2 ReplicaSet示例

创建资源清单

vi nginx-rs.yml
apiVersion: apps/v1  #api版本定义
kind: ReplicaSet  #定义资源类型为ReplicaSet
metadata:  #元数据定义
  name: nginx-rs
  namespace: default
spec:  #ReplicaSet的规格定义
  replicas: 2  #定义副本数量为2个
  selector:  #标签选择器,定义匹配Pod的标签
    matchLabels:
      app: nginx
  template:  #Pod的模板定义
    metadata:  #Pod的元数据定义
      name: nginx-pod  #自定义Pod的名称
      labels:  #定义Pod的标签,需要和上面的标签选择器内匹配规则中定义的标签一致,可以多出其他标签
        app: nginx
    spec:  #Pod的规格定义
      containers:  #容器定义
      - name: nginx  #容器名称
        image: nginx:1.12  #容器镜像
        imagePullPolicy: IfNotPresent  #拉取镜像的规则
        ports:  #暴露端口
        - name: http  #端口名称
          containerPort: 80

创建rs控制器

kubectl apply -f nginx-rs.yaml

在这里插入图片描述

查看rs控制器

kubectl get rs

在这里插入图片描述

查看pod容器

通过查看pod可以看出pod命令是规则是前面是replicaset控制器的名称加随机生成的字符串

kubectl get pods -o wide -w

在这里插入图片描述

2.4 更新控制器

修改上面创建的replicaset示例文件,将镜像nginx:1.12改为1.20版本

vi nginx-rs.yml
apiVersion: apps/v1  #api版本定义
kind: ReplicaSet  #定义资源类型为ReplicaSet
metadata:  #元数据定义
  name: nginx-rs
  namespace: default
spec:  #ReplicaSet的规格定义
  replicas: 2  #定义副本数量为2个
  selector:  #标签选择器,定义匹配Pod的标签
    matchLabels:
      app: nginx
  template:  #Pod的模板定义
    metadata:  #Pod的元数据定义
      name: nginx-pod  #自定义Pod的名称
      labels:  #定义Pod的标签,需要和上面的标签选择器内匹配规则中定义的标签一致,可以多出其他标签
        app: nginx
    spec:  #Pod的规格定义
      containers:  #容器定义
      - name: nginx  #容器名称
        image: nginx:1.20  #容器镜像
        imagePullPolicy: IfNotPresent  #拉取镜像的规则
        ports:  #暴露端口
        - name: http  #端口名称
          containerPort: 80

2.4.1 应用更新

kubectl apply -f nginx-rs.yaml

在这里插入图片描述

查看更新流程

kubectl get pods -o wide -w

我们发现pod没有任何更新变化

在这里插入图片描述

查看Pod版本号

kubectl get pods -o custom-columns=Name:metadata.name,Image:spec.containers[0].image

这里并没有更新pod的nginx版本号

在这里插入图片描述

删除pod应用

这里虽然重载了,但是已有的pod所使用的镜像仍然是1.12版本的,只是新建pod时才会使用1.20版本,这里测试先手动删除已有的pod。

kubectl delete pods -l app=nginx

在这里插入图片描述

查看版本

kubectl get pods -o custom-columns=Name:metadata.name,Image:spec.containers[0].image

现在我们发现pod的版本已经更新正确了

在这里插入图片描述

2.5 RS扩缩容

可以直接通过vim 编辑清单文件修改replicas字段,也可以通过kubect edit 命令去编辑

	`kubectl`还提供了一个专用的子命令`scale`用于实现应用规模的伸缩,支持从资源清单文件中获取新的目标副本数量,也可以直接在命令行通过`“--replicas”`选项进行读取。

2.5.1 scale命令扩容

命令扩容一般用于短期的临时性扩容,应付完成后要记得缩容到原来水平

查看容量

可看到当前是两个节点

kubectl get pods -o wide

在这里插入图片描述

执行扩容

使用scale命令可以对集群进行扩缩容

kubectl scale replicasets nginx-rs --replicas=4

在这里插入图片描述

查看扩容过程

在更新前打开新窗口,监控pod的更新变化

kubectl get pods -o wide -w

在这里插入图片描述

在更新前打开新窗口,监控RS的更新变化

kubectl get rs -o wide -w

我们发现扩容后只是在原来的RS集群上面增加了两个节点

在这里插入图片描述

2.5.2 配置文件缩容

配置文件扩容一般用于初始容量变更,长期进行扩容

查看容量

可看到当前是四个节点

kubectl get pods -o wide

在这里插入图片描述

应用配置

因为没有变更配置文件可以直接应用配置文件

kubectl apply -f nginx-rs.yml

在这里插入图片描述

查看缩容容过程

在更新前打开新窗口,监控pod的更新变化

kubectl get pods -o wide -w

在这里插入图片描述

在更新前打开新窗口,监控RS的更新变化

kubectl get rs -o wide -w

我们发现扩容后只是在原来的RS集群上面减少了两个节点

在这里插入图片描述

2.6 删除rs控制器

使用Kubectl delete命令删除ReplicaSet对象时默认会一并删除其管控的各Pod对象,有时,考虑到这些Pod资源未必由其创建,或者即便由其创建也并非自身的组成部分,这时候可以添加“--cascade=false”选项,取消级联关系。

2.6.1 查看集群情况

查看RS集群

kubectl get rs -o wide

在这里插入图片描述

查看POD

kubectl get pods -o wide

在这里插入图片描述

2.6.2 删除rs

删除rs可以通过参数cascade=false设置不删除pod

kubectl delete replicasets nginx-rs --cascade=false

在这里插入图片描述

2.6.3 查看集群情况

查看RS集群

kubectl get rs -o wide

在这里插入图片描述

查看POD

kubectl get pods -o wide

在这里插入图片描述

2.6.4 删除Pod

kubectl delete pods nginx-rs-7rzz6
kubectl delete pods nginx-rs-c5zrs

在这里插入图片描述

3 Deployment控制器

3.1 Deployment概述

Deployment为Pod和Replica Set(下一代Replication Controller)提供声明式更新

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

在这里插入图片描述

3.1.1 其他特性

Deployment控制器资源的主要职责是为了保证Pod资源的健康运行,其大部分功能均可通过调用ReplicaSet实现,同时还增添部分特性。

  • 事件和状态查看:必要时可以查看Deployment对象升级的详细进度和状态。
  • 回滚:升级操作完成后发现问题时,支持使用回滚机制将应用返回到前一个或由用户指定的历史记录中的版本上。
  • 版本记录:对Deployment对象的每一个操作都予以保存,以供后续可能执行的回滚操作使用。
  • 暂停和启动:对于每一次升级,都能够随时暂停和启动。
  • 多种自动更新方案:一是Recreate,即重建更新机制,全面停止、删除旧有的Pod后用新版本替代;另一个是RollingUpdate,即滚动升级机制,逐步替换旧有的Pod至新的版本。

3.2 Deployment配置

3.2.1 编辑资源清单

vi nginx-deployment.yml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
spec:
  replicas: 2
  minReadySeconds: 2  # 这里需要估一个比较合理的值,从容器启动到应用正常提供服务
  strategy:  # k8s 默认的 strategy 就是 RollingUpdate, 这里写明出来可以调节细节参数
    #type: Recreate
    type: RollingUpdate
    rollingUpdate:
      maxSurge: 1  # 更新时允许最大激增的容器数,默认 replicas 的 1/4 向上取整
      maxUnavailable: 0  # 更新时允许最大 unavailable 容器数,默认 replicas 的 1/4 向下取整
  selector:
    matchLabels:
        app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:1.7.9
        ports:
        - containerPort: 80

3.2.2 配置项说明

配置解释

  • 我们定义了一个Deployment,名字叫nginx-deployment;
  • 通过spec.replicas字段定义了Pod的副本数是2;
  • 通过minReadySeconds设置等待多长的时间后才进行升级
  • 通过spec.selector字段定义了被打上app: nginx的标签的Pod才会被管理;
  • tmplate字段定义了这个Deployment管理的Pod应该是怎样的,具有怎样的属性;

控制器描述

总的来说一个Deploymet控制器可以由两部分组成:

在这里插入图片描述

3.2.3 创建控制器

kubectl apply -f nginx-deployment.yml
kubectl get pods -o wide

在这里插入图片描述

3.2.4 查看replicaset

ReplicaSet是一个副本控制器,ReplicaSet可以用selector来控制Pod的数量,而Deployments是一个更高层次的概念,它管理ReplicaSets,并提供对pod的声明性更新以及许多其他的功能。

kubectl get replicaset -o wide

通过查看资源对象可以看出,Deployment会自动创建相关的ReplicaSet控制器资源,并以"[DEPLOYMENT-name]-[POD-TEMPLATE-HASH-VALUE]"格式为其命名,其中的hash值由Deployment自动生成。而Pod名则是以ReplicaSet控制器的名称为前缀,后跟5位随机字符。

在这里插入图片描述

3.3 更新策略

ReplicaSet控制器的应用更新需要手动分成多步并以特定的次序进行,过程繁杂且容易出错,而Deployment却只需要由用户指定在Pod模板中要改动的内容,(如镜像文件的版本),余下的步骤便会由其自动完成。Pod副本数量也是一样。

Deployment控制器支持两种更新策略:滚动更新(rolling updata)和 重建更新(recreate),默认情况下为滚动更新

3.3.1 重建更新

	重建更新为:先删除所有的Pod再根据新的模板创建新的Pod,中间会导致服务的不可用,用户要么使用的是新版本,要么就是旧版本

3.3.2 滚动更新

滚动更新是默认的更新策略,它在删除一些旧版本的Pod的同时补充创建一些新的Pod,更新期间服务不会中断。

	滚动更新期间,应用升级期间还要确保可用的Pod对象数量不低于某些阈值,确保可以持续处理客户端请求,变动的方式和Pod对象的数量范围将通过`maxSurge`和`maxunavailable`两个属性协同进行定义

配置参数

两个参数用法如下:

  • maxSurge:指定升级期间存在的总Pod对象数量最多以超出期望值的个数,其值可以为0或者正整数,也可以是一个期望值的百分比:例如如果期望值是3,当前的属性值为1,则表示Pod对象的总数不能超过4个。
  • maxUnavailable:升级期间正常可用的Pod副本数(包括新旧版本)最多不能低于期望的个数、其值可以是0或者正整数,也可以是一个期望值的百分比,默认值为1;该值意味着如果期望值是3,那么在升级期间至少要有两个Pod对象处于正常提供服务的状态

maxSurge和maxUnavailable的数量不能同时为0,否则Pod对象的复本数量在符合用户期望的数量后无法做出合理变动以进行滚动更新操作。

3.4 更新控制器

命令扩容一般用于短期的临时性扩容,应付完成后要记得缩容到原来水平

3.4.1 命令更新

查看版本

通过命令查看pod的版本号

kubectl get pods -o custom-columns=Name:metadata.name,Image:spec.containers[0].image

在这里插入图片描述

执行更新命令

kubectl set image deployment/nginx-deployment nginx=nginx:1.15

在这里插入图片描述

查看更新过程

在更新前打开新窗口,监控pod的更新变化

kubectl get pods -o wide -w

在这里插入图片描述

在更新前打开新窗口,监控RS的更新变化

kubectl get rs -o wide -w

我们发现更新后新建了一个RS,并且保留原来的RS但是节点数为0用来回滚

在这里插入图片描述

查看版本

通过命令查看pod的版本号

kubectl get pods -o custom-columns=Name:metadata.name,Image:spec.containers[0].image

在这里插入图片描述

3.4.2 配置更新

查看版本

通过命令查看pod的版本号

kubectl get pods -o custom-columns=Name:metadata.name,Image:spec.containers[0].image

在这里插入图片描述

编辑资源清单

vi nginx-deployment.yml
apiVersion: apps/v1
kind: Deployment
metadata:
  name: nginx-deployment
spec:
  replicas: 2
  selector:
    matchLabels:
        app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx:1.20 # 将nginx版本改为1.20
        ports:
        - containerPort: 80

应用更新

kubectl apply -f nginx-deployment.yml

在这里插入图片描述

查看更新过程

在更新前打开新窗口,监控pod的更新变化

kubectl get pods -o wide -w

在这里插入图片描述

在更新前打开新窗口,监控RS的更新变化

kubectl get rs -o wide -w

我们发现更新后新建了一个RS,并且保留原来的RS但是节点数为0用来回滚

在这里插入图片描述

查看版本

通过命令查看pod的版本号

kubectl get pods -o custom-columns=Name:metadata.name,Image:spec.containers[0].image

在这里插入图片描述

3.4.3 回滚更新

通过rollout命令进行回滚操作

查看版本

通过命令查看pod的版本号

kubectl get pods -o custom-columns=Name:metadata.name,Image:spec.containers[0].image

在这里插入图片描述

执行回滚命令

kubectl rollout undo deployment/nginx-deployment

在这里插入图片描述

查看更新过程

在更新前打开新窗口,监控pod的更新变化

kubectl get pods -o wide -w

在这里插入图片描述

在更新前打开新窗口,监控RS的更新变化

kubectl get rs -o wide -w

我们发现回滚没有创建新的rs而是将使用了原来的rs

在这里插入图片描述

查看版本

通过命令查看pod的版本号

kubectl get pods -o custom-columns=Name:metadata.name,Image:spec.containers[0].image

在这里插入图片描述

3.4.4 再次回滚

查看版本

通过命令查看pod的版本号

kubectl get pods -o custom-columns=Name:metadata.name,Image:spec.containers[0].image

在这里插入图片描述

执行回滚命令

kubectl rollout undo deployment/nginx-deployment

在这里插入图片描述

查看更新过程

在更新前打开新窗口,监控pod的更新变化

kubectl get pods -o wide -w

在这里插入图片描述

在更新前打开新窗口,监控RS的更新变化

kubectl get rs -o wide -w

我们发现回滚没有创建新的rs而是将使用了原来的rs

在这里插入图片描述

查看版本

通过命令查看pod的版本号

kubectl get pods -o custom-columns=Name:metadata.name,Image:spec.containers[0].image

我们发现rollout回滚只在最近的两个版本之间来回回滚,不会回滚到在上一个版本。

在这里插入图片描述

3.4.5 回滚指定版本

查看历史版本

通过rollout history查看版本历史

kubectl rollout history deployment/nginx-deployment

在这里插入图片描述

历史版本内容

通过指定版本号来查看变更内容,找到需要回滚的版本,这里我会回滚到最早版本nginx:1.7.9

kubectl rollout history deployment/nginx-deployment --revision=1

我们找到了需要回滚的版本是1

在这里插入图片描述

查看版本

通过命令查看pod的版本号

kubectl get pods -o custom-columns=Name:metadata.name,Image:spec.containers[0].image

在这里插入图片描述

执行回滚命令

写入我们需要回滚到的指定版本1

kubectl rollout undo deployment/nginx-deployment --to-revision=1

查看版本

通过命令查看pod的版本号

kubectl get pods -o custom-columns=Name:metadata.name,Image:spec.containers[0].image

到此我们已经回滚到了指定版本

在这里插入图片描述

3.5 Deployment扩缩容

3.5.1 scale命令扩容

命令扩容一般用于短期的临时性扩容,应付完成后要记得缩容到原来水平

查看当前容量

当前是两个节点

 kubectl get pods -o wide

在这里插入图片描述

执行扩容

使用scale命令可以对集群进行扩缩容,扩充到4个节点

 kubectl scale deployment nginx-deployment --replicas=4

在这里插入图片描述

查看扩容过程

在更新前打开新窗口,监控pod的更新变化

kubectl get pods -o wide -w

在这里插入图片描述

在更新前打开新窗口,监控RS的更新变化

kubectl get rs -o wide -w

我们发现扩容后只是在原来的RS集群上面增加了两个节点

3.5.2 配置文件缩容

配置文件扩缩容一般用于初始容量变更,长期进行扩缩容

查看当前容量

当前是4个节点

 kubectl get pods -o wide

在这里插入图片描述

应用配置文件

因为我们没有更改配置文件,直接应用配置文件即可

kubectl apply -f nginx-deployment.yml

在这里插入图片描述

查看扩容过程

在更新前打开新窗口,监控pod的更新变化

kubectl get pods -o wide -w

在这里插入图片描述

在更新前打开新窗口,监控RS的更新变化

kubectl get rs -o wide -w

我们发现扩容后只是在原来的RS集群上面减少了两个节点

在这里插入图片描述

3.6 删除Deployment

3.6.1 查看集群情况

查看Deployment

kubectl get deployments -o wide

在这里插入图片描述

查看POD

kubectl get pods -o wide

在这里插入图片描述

删除Deployment

执行删除命令删除Deployment

kubectl delete deployment nginx-deployment

在这里插入图片描述

查看Deployment

kubectl get deployments -o wide

在这里插入图片描述

查看POD

kubectl get pods -o wide

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/688498.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

专项练习12

目录 一、选择题 1、JavaScript中定义var a"40",var b7,则执行a%b会得到? 2、下面哪个选项中的对象与浏览列表有关( ) 3、下面哪一个语句可以实现在jQuery中找到所有元素的同辈元素? 4、如何阻止IE和各大浏览器默认行为…

CVSS4.0将于2023年底正式发布

通用漏洞评分系统(CVSS)是一种流行的、标准化的方法,用于评估数字系统安全漏洞的严重程度。由事件反应和安全小组论坛(FIRST)开发,它为安全专业人员提供了评估和优先排序风险的一致方法。 目前的CVSS v3.0已经运行了十多年,但因其复杂性和灵…

Jenkins 持续集成:Linux 系统 两台机器互相免密登录

背景知识 我们把public key放在远程系统合适的位置,然后从本地开始进行ssh连接。 此时,远程的sshd会产生一个随机数并用我们产生的public key进行加密后发给本地,本地会用private key进行解密并把这个随机数发回给远程系统。 最后&#xf…

ModaHub魔搭社区:向量数据库MIlvus服务端配置(四)

目录 常见问题 常见问题 除了配置文件外,怎样可以判断我确实在使用 GPU 做搜索? 有以下三种方式: 使用 nvidia-smi 命令查看 GPU 使用情况。用 Prometheus 配置,详见 使用 Grafana 展示监控指标 > 系统运行指标。使用 Milv…

一文教你Mysql如何性能优化

Mysql性能优化 Mysql性能优化 性能优化维度 数据库优化思路 应急调优的思路: 针对突然的业务办理卡顿,无法进行正常的业务处理!需要立马解决的场景! show processlist(查看连接session状态) explain(分…

hudi系列-timeline service

Timeline Service(时间线服务)是hudi的一个组件,用于暴露文件系统视图接口给客户端,是一个基于Javalin+Jetty实现的web服务。当客户端使用远程文件系统视图(RemoteHoodieTableFileSystemView)时,就是访问时间线服务http接口 默认情况下,如果开启了时间线服务,则它运行在…

支付中心“收银台“设计方案

01.收银台的产品架构 重点收银台架构的三个方面: 1.公司所支持的收银台种类以未来拓展倾向 2.支付方式的枚举及根据业务发展预判拓展倾向 3.收银台服务端的能力建设规划和选择 02.收银台的业务架构 收银台,是支付的起点,所以无论是何种…

接口自动化测试学习笔记分享(附上视频教程供你学习)

目录 接口自动化测试框架介绍 目录 接口测试场景 自动化测试场景 接口测试在分层测试中的位置 接口自动化测试与 Web/App 自动化测试对比 接口自动化测试与 Web/App 自动化测试对比 接口测试工具类型 为什么推荐 Requests Requests 优势 Requests 环境准备 接口请求…

Java安全——应用安全

Java安全 Java 应用安全 JCE(Java Cryptography Extension)java加密扩展包 Java Cryptography Extension(JCE)是一个可选的Java标准扩展,提供了一组用于加密、密钥生成和密钥协商等功能的类和接口。JCE包含了导入、生…

【ChatGpt】解决视频框交换中的平滑过渡的问题

【ChatGpt】解决视频框交换中的平滑过渡的问题 问题抽象chatgpt 看看直接给参考代码 解决效果 问题 在视频的播放中,我们想调换下容器的位置 ,在互调的过程中,如果需要重新进行数据的初始化,获取与加载,就会很慢&…

RocketMQ --- 原理篇

一、专业术语 Producer 消息生产者,负责产生消息,一般由业务系统负责产生消息。 Consumer 消息消费者,负责消费消息,一般是后台系统负责异步消费。 Push Consumer Consumer 的一种,应用通常向 Consumer 对象注册一个…

基于JavaScript的百度AI的人脸识别微信小程序(深度学习+机器视觉)含全部工程源码及视频演示(仅供学习)

目录 前言总体设计系统整体结构图系统流程图 运行环境模块实现1. Access token 获取2. 人脸注册3. 人脸删除4. 人脸识别 系统测试工程源代码下载其它资料下载 前言 本项目采用了百度AI的训练模型,利用图像识别接口返回结果,旨在实现人脸在库中的判断&am…

制造业质量管理如何实现数字化转型?这份指南讲透了

一、什么是制造业质量管理 制造业质量管理是现代制造业非常重要的一个方面。它包括了一系列的活动和方法,以确保制造产品或提供服务的过程中,实现高质量标准的目标。 制造业质量管理包括质量规划、控制和改进等各种方法和工具,以确保产品或…

4.25 IO多路复用简介 4.26select API介绍 4.27 select代码编写

4.25 IO多路复用简介 IO多路复用使得程序能同时监听多个文件描述符,能够提高程序的性能,Linux下实现IO多路复用的系统调用主要有select、poll和epoll。 4.26select API介绍 主旨思想: 1、首先构造一个关于文件描述符的列表&#xff…

【高危】Openfire权限绕过漏洞(POC公开)

漏洞描述 Openfire是Java开发且基于XMPP(前称Jabber,即时通讯协议)的开源实时协作(RTC)服务器。 在受影响版本中,由于路径验证机制存在缺陷,攻击者可以通过/setup/setup-s/%u002e%u002e/%u002e…

基于Python所写的学生管理系统

点击下方链接获取源码资源: https://download.csdn.net/download/qq_64505944/87950397?spm1001.2014.3001.5503 《学生信息管理系统》程序使用说明 在IDLE中运行《学生信息管理系统》即可进入如图1所示的系统主界面。在该界面中可以选择要使用功能对应的菜单进行…

【编译、链接、装载十四】堆与内存管理

【编译、链接、装载十四】堆与内存管理 一、堆与内存管理1、什么是堆 二、Linux进程堆管理三、Windows进程堆管理Q&A 一、堆与内存管理 相对于栈而言, 堆这片内存面临一个稍微复杂的行为模式: 在任意时刻, 程序可能发出请求,…

请求响应相关知识点

这里写目录标题 请求响应概述 请求postman各种参数的封装以及接收简单参数原始方式springboot方式映射解决参数不匹配小结 实体参数简单的实体参数复杂的实体参数注意点 数组集合参数数组集合总结 日期参数json参数模拟发送注意点服务端注意点 路径参数各个参数总结 响应注解统…

66、基于51单片机超声波测距LCD1602显示报警系统设计(程序+原理图+PCB源文件+Proteus仿真+参考论文+开题报告+任务书+元器件清单等)

前 言 超声波具有指向性强,能量消耗缓慢,在介质中传播的距离较远,因而超声波经常用于距离的测量,如测距仪和物位测量仪等都可以通过超声波来实现。利用超声波检测往往比较迅速、方便、计算简单、易于做到实时控制,并且…

JDK8新特性-中部

文章目录 一、方法引用1.1 为什么要有方法引用?1.1.1 Lambda表达式冗余1.1.2 解决方案 1.2 方法引用的格式1.2 .1 对象::方法名1.2.2 类名::静态方法名1.2.3 类名::引用实例方法1.2.4 类名::构造器1.2.5 数组::构造器 二、Stream API2.1 集合处理的弊端2.2 Steam流式思想概述2…