在ACK集群中自动化执行Ray Job

news2025/1/13 6:14:00

企业在管理集群资源时面临的主要挑战是任务量庞大而资源有限。为解决这一问题,需要优先将资源分配给关键部门或个人,并保持高度的灵活性以随时调整资源分配。本文将介绍如何提高企业集群资源的利用率,并通过统一的任务管理平台自动化处理来自不同部门的大量Ray Job,支持任务插队和动态优先级调整,确保高优先级任务能够优先获得资源。

为什么要在ACK集群中自动化执行Ray Job

  • 资源管理与优化。

    通过ACK集群配合Ray来自动调度任务,可以更灵活地管理和分配计算资源。例如,在给定的场景中,文本生成小组和视频生成小组被分配了不同的CPU核心数量。使用Ray可以在这些限定的资源范围内高效地安排作业,确保每个小组都能充分利用其分配到的资源,同时避免资源浪费或过度竞争。

  • 优先级控制。

    算法工程师的任务享有更高的执行优先级。通过在ACK上配置适当的策略,并结合Ray的调度机制,可以实现这种基于用户角色的任务优先级设置。这样既保证了关键研究工作的顺利进行,也使得实习生能够在不影响主要项目进度的前提下参与学习和实验。

  • 弹性伸缩。

    随着研究进展或项目需求的变化,可能需要调整各组可用的计算能力。利用ACK提供的弹性伸缩功能,可以根据实际负载动态增加或减少节点数目,而Ray则能够无缝适应这种变化,自动重新平衡工作负载,从而保持最优性能。

CPU的分配情况如下图所示。

 

为了解决配额管理和任务排序的问题,需在集群中建立资源配额机制任务调度系统

资源配额可以根据部门或个人设定,明确每个单位可使用的最大资源量或机器数量。在任务启动前,系统会自动检查该任务所属的资源配额是否足以满足其需求。只有当确认资源配额能够支持所需资源时,任务才会被分配到相应的计算资源上并开始执行。这样既保证了资源的有效利用,也确保了任务按照优先级合理安排。

环境准备

  • 创建ACK集群Pro版。

    • 关于如何创建集群,请参见创建ACK托管集群。

    • 如需升级集群版本,请参见手动升级集群。

  • 安装集群组件。

    • Kuberay Operator组件版本:v1.2.1.2.gfebe140及以上。具体操作,请参见安装Kuberay Operator组件。

    • Kube Queue版本:v1.21.4及以上。具体操作,请参见使用任务队列ack-kube-queue。

    • 已通过kubectl连接Kubernetes集群,且已在本地安装kubectl。具体操作,请参见获取集群KubeConfig并通过kubectl工具连接集群。

设置队列与资源

任务排队及编排系统应具备将来自不同部门和员工的任务分配至相应队列的能力,以便根据各部门设定的优先级进行管理。此外,系统需支持基于优先级的任务调度机制,而非简单的先进先出(FIFO)模式,从而确保紧急任务可以优先处理。

通过结合使用ACK Scheduler、Kube Queue和ElasticQuotaTree,ACK集群能够支持包括最大配额限制、弹性配额管理、多样化的排队策略以及队列资源回收机制在内的多种功能。这种综合方案全面满足了企业在任务队列系统方面的需求。

管理员、研究员、任务、Kube Queue、ACK Scheduler以及Controller的关联关系如下图所示。

ElasticQuotaTree设置建立完成,不同部门研究员便能够提交任务至集群。管理员需在集群中创建ElasticQuotaTree,以定义资源配额及队列结构。这些提交的任务将依据预设的资源配额被分配到不同的组别,并根据各队列特有的排队策略进行排序等待执行。当任务从队列中出队时,其状态管理由Controller负责,而具体的Pod调度则交由ACK Scheduler处理。若某出队任务长时间未能启动运行,Kube Queue会自动回收该任务并将其重新加入到待处理队列中。

设置资源配额体系

ElasticQuotaTree定义了集群内的配额信息,涵盖了配额的层级结构、与配额关联的资源量,以及配额所绑定的命名空间。当在这些命名空间下提交任务时,任务将自动归入相应命名空间的资源配额中。

为了构建符合企业需求的资源配额体系,可以向集群提交如下的ElasticQuotaTree配置

展开查看完整代码示例

ElasticQuotaTree是一种树形结构,其中每个节点通过max字段定义了资源配额的最大使用量,而min字段则指定了该节点的最低保障资源量。当某一资源配额的最低保障无法得到满足时,调度系统将尝试从那些实际占用超过其最低保障资源量的其他配额中回收资源来运行任务。特别是对于标记为intern-textintern-video的任务,由于它们的保障资源量设定为0,这意味着如果算法团队成员提交了需要立即处理的任务,并且此时有实习生的任务正在执行,那么可以通过抢占这些实习生任务所使用的资源来优先保证算法团队任务的执行,从而确保高优先级任务能够顺利进行。

设置管理队列优先级

在ElasticQuotaTree提交后,Kube Queue会在集群中创建相应的队列用于任务排队。每个叶子节点的配额对应于集群中的一个独立队列。当任务被提交到集群时,系统会依据任务所属的命名空间及资源配额配置中的命名空间信息,自动将任务分配至正确的队列内。如果需要指定特定的Quota,则可以在Ray Job和Ray Cluster资源上通过"quota.scheduling.alibabacloud.com/name"标签来声明所需使用的Quota名称。默认情况下,所有新建队列的优先级均为0;但用户可以通过调整kube-queue命名空间下queue资源对象的属性来自定义各个队列的优先级。Kube Queue采用轮询方式遍历各队列,并尝试从当前访问的队列头部取出一项任务执行调度操作。在此过程中,具有较高优先级的队列会被更早地检查,从而有机会优先利用可用资源。

此外,还可以通过修改Queue资源规格(Spec)来进一步管理队列的优先级设置。

apiVersion: scheduling.x-k8s.io/v1alpha1
kind: Queue
metadata:
  annotations:
    kube-queue/quota-fullname: root/group-video/algorithm-video
  creationTimestamp: "2024-10-08T06:43:07Z"
  generation: 1
  labels:
    create-by-kubequeue: "true"
  name: root-group-video-algorithm-video-algorithm-video
  namespace: kube-queue
  resourceVersion: "5766258"
  uid: 01342987-3dad-401b-8509-ef7250683377
spec:
  queuePolicy: Round
  # 通过在Queue的Spec中增加Priority=2的字段申明Queue具有2的优先级
  priority: 2

资源配额与队列的对应关系如下图所示。默认情况下创建的队列排队方式是轮转调度,更多支持的队列排队方式可以参考相关文档开启阻塞队列。

 

在完成资源配额设置后,用户只需在提交任务时添加Suspend标记,即可使任务进入队列等待。对于Ray Job来说,只需将任务的.spec.suspend字段设为True。对于其他支持排队功能的任务类型,也应遵循类似的方法来启用排队,具体操作,请参见相关文档支持排队功能的任务类型。针对Ray Job,系统会在任务提交后,把Head Pod的资源需求与每个WorkerGroup的资源量(即副本数乘以单个Pod请求的资源量)相加,以此总和作为该任务所需的资源总量。

Kube Queue管理任务队列示例

以下将通过提交几个Ray Job来展示Kube Queue的功能。当Ray Job达到Succeeded状态时,即表示任务已完成,此时Kube Queue会允许后续任务开始执行。需要注意的是,新的RayCluster的Pod调度必须等待与已完成的Ray Job关联的Ray Cluster被销毁并释放其占用的资源后才能进行,代码示例如下所示。

展开查看完整代码示例

以下将提交了两个任务,每个任务都需要31核CPU的资源。在这种情况下,只有一个任务能够立即获得所需资源并开始运行,而另一个任务则会持续处于挂起状态。您可以通过以下命令检查队列中的Status字段来了解详细的排队情况。

# 从返回值中可以看到提交的两个任务中只有第一个任务处于初始化状态,第二个任务处于挂起等待状态
➜  kubequeue-doc kubectl get rayjob -n algorithm-text
NAME                  JOB STATUS   DEPLOYMENT STATUS   START TIME             END TIME   AGE
rayjob-sample-j87d8                                                                      4s
rayjob-sample-rhm9s                Initializing        2024-10-08T07:56:31Z              7s


# 用于查看当前集群中的队列,与上述的图片所对应
➜  kubequeue-doc kubectl -n kube-queue get queue
NAME                                               AGE
root-group-text-algorithm-text-algorithm-text      73m
root-group-text-intern-text-intern-text            73m
root-group-video-algorithm-video-algorithm-video   73m
root-group-video-intern-video-intern-video         73m


# 查看刚刚提交任务的队列,从status中可以看到,rayjob-sample-j87d8在backoff队列中,排队位置为1,意味着当前任务执行完后该任务即可开始执行
➜  kubequeue-doc kubectl -n kube-queue get queue  root-group-text-algorithm-text-algorithm-text -oyaml
apiVersion: scheduling.x-k8s.io/v1alpha1
kind: Queue
metadata:
  annotations:
    kube-queue/quota-fullname: root/group-text/algorithm-text
  creationTimestamp: "2024-10-08T06:43:07Z"
  generation: 1
  labels:
    create-by-kubequeue: "true"
  name: root-group-text-algorithm-text-algorithm-text
  namespace: kube-queue
  resourceVersion: "5802083"
  uid: 83a3bf55-cd96-4405-9629-7e37512ac4b6
spec:
  queuePolicy: Round
status:
  queueItemDetails:
    active: []
    backoff:
    - name: rayjob-sample-j87d8-ray-qu     # 下个命令中的name与其保持一致
      namespace: algorithm-text
      position: 1
      
 
# 查看 qu 资源的状态,可以看到失败原因是root/group-text/algorithm-text的资源配额超出了配置的最大资源配额。
➜  kubequeue-doc kubectl get queue -n algorithm-text rayjob-sample-j87d8-ray-qu -oyaml
...
status:
  lastUpdateTime: "2024-10-08T08:01:46Z"
  message: 'Insufficient quota(cpu) in quota root/group-text/algorithm-text: request
    31, max 40, used 31, oversellreate 1. Wait for running jobs to complete'
  phase: Enqueued

同样的如果此时实习生提交了一个作业,可以看到该作业也处于排队状态,并且提示信息会显示由于root/group-text的配额超过了最大限制,因此无法从队列中取出执行。您可以通过以下命令来了解详细的排队情况。

➜  kubequeue-doc kubectl get queue -n intern-text
NAME                         AGE
rayjob-sample-n5gzf-ray-qu   9s              # 下个命令中的name与其保持一致


➜  kubequeue-doc kubectl get queue -n intern-text rayjob-sample-n5gzf-ray-qu -oyaml
apiVersion: scheduling.x-k8s.io/v1alpha1
kind: QueueUnit
metadata:
  creationTimestamp: "2024-10-08T08:07:48Z"
  generation: 1
  name: rayjob-sample-n5gzf-ray-qu
  namespace: intern-text
  ownerReferences:
  - apiVersion: ray.io/v1
    kind: RayJob
    name: rayjob-sample-n5gzf
    uid: d44af490-b595-4876-9463-bd22ff826848
  resourceVersion: "5807774"
  uid: b9f7e900-ccf9-47cb-817b-8d4e61575369
spec:
  consumerRef:
    apiVersion: ray.io/v1
    kind: RayJob
    name: rayjob-sample-n5gzf
    namespace: intern-text
  podSet:
  - count: 1
    name: head
    template:
      metadata: {}
      spec:
        containers:
        - image: rayproject/ray:2.9.0
          name: ray-head
          ports:
          - containerPort: 6379
            name: gcs-server
            protocol: TCP
          - containerPort: 8265
            name: dashboard
            protocol: TCP
          - containerPort: 10001
            name: client
            protocol: TCP
          resources:
            limits:
              cpu: "1"
            requests:
              cpu: "1"
          volumeMounts:
          - mountPath: /home/ray/samples
            name: code-sample
        volumes:
        - configMap:
            items:
            - key: sample_code.py
              path: sample_code.py
            name: ray-job-code-sample
          name: code-sample
  - count: 30
    name: small-group
    template:
      metadata: {}
      spec:
        containers:
        - image: rayproject/ray:2.9.0
          lifecycle:
            preStop:
              exec:
                command:
                - /bin/sh
                - -c
                - ray stop
          name: ray-worker
          resources:
            limits:
              cpu: "1"
            requests:
              cpu: "1"
  resource:
    cpu: "31"
status:
  lastUpdateTime: "2024-10-08T08:08:03Z"
  message: 'Insufficient quota(cpu) in parent quota root/group-text: request 31, max
    40, used 31, oversellreate 1. Wait for running jobs to complete'
  phase: Enqueued

当任务 rayjob-sample-rhm9s 完成后,由于算法队列具有更高的优先级,其中的任务将优先获取资源并更早开始执行。

# 通过删除任务模拟任务执行完成
➜  kubequeue-doc kubectl delete rayjob -n algorithm-text rayjob-sample-rhm9s
rayjob.ray.io "rayjob-sample-rhm9s" deleted


# 算法队列中的任务开始执行
➜  kubequeue-doc kubectl get rayjob -n algorithm-text
NAME                  JOB STATUS   DEPLOYMENT STATUS   START TIME             END TIME   AGE
rayjob-sample-j87d8                Initializing        2024-10-08T08:24:09Z              27m


# 实习生队列中的任务继续挂起
➜  kubequeue-doc kubectl get rayjob -n intern-text
NAME                  JOB STATUS   DEPLOYMENT STATUS   START TIME   END TIME   AGE
rayjob-sample-n5gzf                                                            16m

指定节点池调度

在Ray中可以通过指定节点池来控制任务或Actor的调度位置,能够优化资源使用、提高性能或者满足特定的安全性和隔离性。以下是一些指定节点池调度的场景。

  • 资源需求匹配。

    如果您的应用中有一些任务对硬件有特殊需求(比如GPU计算),您可以将这些具有相应硬件配置的机器划分为一个单独的节点池,并且只在这个池内调度那些需要这种硬件的任务。

  • 安全隔离。

    对于处理敏感数据的任务,您可能希望它们运行在一个更加安全可控的环境中。通过创建一个专门用于此类工作的节点池,并确保只有经过严格审查的服务可以访问该池中的节点,就可以实现一定程度上的安全隔离。

  • 性能优化。

    某些类型的工作负载可能更适合部署到特定类型的基础设施上以获得最佳性能。例如,I/O密集型作业可能更适合拥有高速网络连接和SSD存储设备的服务器。在这种情况下,可以为这类作业分配专用的高性能节点池。

  • 成本控制。

    根据云服务厂商的不同定价策略,合理规划由不同价格等级实例组成的节点池可以帮助用户更好地管理成本。例如,将非关键任务安排到低成本但可能性能稍差的实例上执行。

  • 多租户环境。

    在一个共享集群里支持多个项目团队时,每个团队都希望能够独立地管理和优化自己的工作负载。这时,可以根据不同的团队创建对应的节点池,使得各团队能够更方便地进行资源规划与调整。

如果您希望将Pod部署到特定的节点池,可以通过在Head Pod和Work Group的Pod配置中设置NodeAffinity来实现。此外,您还可以通过定义Resource Policy为一组Pod指定调度优先级,例如优先调度至ECS实例,然后才是ECI或ACS节点。相关代码如下所示。

展开查看完整代码

另外,也可以配置Resource Policy,在节点池资源不足时自动将任务调度至Serverless资源上。

重要

当前ACS资源尚不支持与Gang调度机制同时使用。

apiVersion: scheduling.alibabacloud.com/v1alpha1
kind: ResourcePolicy
metadata:
  name: rayjob-sample-tnj27-raycluster-s6t8b-small-group
  namespace: algorithm-text
spec:
  selector:
    # 指定某个raycluster的某个workergroup需要优先级调度,ray.io/group对应groupName
    # ray.io/cluster对应特定rayCluster
    ray.io/group: small-group
    ray.io/cluster: rayjob-sample-tnj27-raycluster-s6t8b
    ray.io/node-type: worker
  strategy: prefer
  units:
  - nodeSelector:
      alibabacloud.com/nodepool-id: np9c9b663eb55d44d0943009d5c3d32781
    resource: ecs
  - resource: acs

设置Gang调度

当您面临需要利用多台计算机共同解决问题时,且希望简化这些复杂性带来的编程挑战时,在以下几种场景中,您可考虑使用Ray来设置节点协同调度。

  • 大规模机器学习训练。

    当需要处理非常大的数据集或复杂的模型时,单一机器可能无法提供足够的计算资源,这时需要一组容器协同工作。Gang调度策略能够确保这些容器同时调度,避免资源争抢和死锁,从而提高训练效率。

  • ‌MPI计算框架‌。

    MPI框架下的多线程并行计算需要主从进程协同工作。Gang调度策略能够确保这些进程同时调度,减少通信延迟,提升计算效率。

  • 数据处理与分析。

    对于那些需要处理海量数据的应用来说,比如日志分析、实时流处理等,多个任务可能需要同时运行以完成复杂的分析工作。Gang调度策略可以确保这些任务同时调度,提高整体处理速度。

  • 自定义分布式应用开发。

    在游戏服务器架构中实现玩家匹配服务;或者在物联网(IoT)项目里协调来自成千上万个设备的数据收集与处理工作。

如果您需要提交带有Gang调度需求的Ray Job,在ACK Pro以及ACK灵骏的环境中只需要在Ray Job的Metadata中申明ray.io/scheduler-name=kube-scheduler即可,提交任务之后rayoperator会在创建出Pod时注入Gang相关标记。

如果您需要在Ray Job中提交Gang调度需求,在ACK Pro及ACK灵骏环境中,您只需在Ray Job的Metadata中声明ray.io/scheduler-name=kube-scheduler。提交任务后,Ray Operator会在创建Pod时自动注入与Gang调度相关的标记。相关代码如下所示。

展开查看完整代码

创建Pod时为其设置标签,以便于后续的识别、分组、筛选及管理操作。相关代码如下所示。

展开查看完整代码

当资源不足时,您可以通过事件(events)获取调度失败的详细信息。使用--field-selector='type=Warning,reason=GangFailedScheduling'可以过滤出与Gang相关的调度失败记录。此外,“cycle xx”表示不同轮次下的调度失败详情,具体说明了在该轮中Pod未能成功调度的原因。具体示例如下所示。

➜  kubequeue-doc kubectl get events -n algorithm-text --field-selector='type=Warning,reason=GangFailedScheduling' | grep "cycle 1"
5m48s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-89mlq   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-89mlq in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.
5m48s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-8fwmr   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-8fwmr in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.
5m48s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-8g5wv   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-8g5wv in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.
5m46s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-8tn4w   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-8tn4w in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.
5m48s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-97gpk   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-97gpk in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.
5m46s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-9xsgw   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-9xsgw in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.
5m48s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-gwxhg   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-gwxhg in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.
5m48s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-jzw6k   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-jzw6k in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.
5m48s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-kb55s   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-kb55s in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.
5m48s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-lbvk7   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-lbvk7 in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.
5m46s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-ms96b   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-ms96b in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.
5m48s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-sgr9g   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-sgr9g in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.
5m46s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-svt6g   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-svt6g in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.
5m48s       Warning   GangFailedScheduling   pod/rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-wm5c6   rayjob-sample-dtmtl-raycluster-r9jc7-small-group-worker-wm5c6 in gang failed to be scheduled in cycle 1: 0/0 nodes are available: 3 Insufficient cpu.

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

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

相关文章

分布式锁的实现原理

作者:来自 vivo 互联网服务器团队- Xu Yaoming 介绍分布式锁的实现原理。 一、分布式锁概述 分布式锁,顾名思义,就是在分布式环境下使用的锁。众所周知,在并发编程中,我们经常需要借助并发控制工具,如 mu…

【北京迅为】iTOP-4412全能版使用手册-第十九章 搭建和测试TFTP服务器

iTOP-4412全能版采用四核Cortex-A9,主频为1.4GHz-1.6GHz,配备S5M8767 电源管理,集成USB HUB,选用高品质板对板连接器稳定可靠,大厂生产,做工精良。接口一应俱全,开发更简单,搭载全网通4G、支持WIFI、蓝牙、…

webrtc 3A移植以及实时处理

文章目录 前言一、交叉编译1.Pulse Audio webrtc-audio-processing2.交叉编译 二、基于alsa进行实时3A处理1.demo源码2.注意项3.效果展示 总结 前言 由于工作需要,硬件3A中的AEC效果实在太差,后面使用SpeexDSP的软3A,效果依旧不是很好&#…

Python学习第十天--处理CSV文件和JSON数据

CSV:简化的电子表格,被保存为纯文本文件 JSON:是一种数据交换格式,易于人阅读和编写,同时也易于机器解析和生成,以JavaScript源代码的形式将信息保存在纯文本文件中 一、csv模块 CSV文件中的每行代表电…

Layui表格的分页下拉框新增“全部”选项

1、首先需要从后端接口获取表格的全部数据长度,这里以100为例。 2、根据请求到的数据进行表格的渲染。示例代码: let pageSize 5 let pageNo 1 let count 100 table.render({elem: XXX,done: function(res, curr, count){pageNo curr; // 将当前选…

CBK7运营安全

1 运营部门的角色 ​ prudent man、due care(按要求执行)VS due diligence(承担管理者责任) ​ 应尽关注:执行了负责任的动作降低了风险。 ​ 应尽职责:采取了所有必要的安全步骤以了解公司或个人的实际风…

AIGC引领金融大模型革命:未来已来

文章目录 金融大模型的应用场景1. **金融风险管理**2. **量化交易**3. **个性化投资建议**4. **金融欺诈检测和预防**5. **智能客户服务** 金融大模型开发面临的挑战应对策略《金融大模型开发基础与实践》亮点内容简介作者简介获取方式 在AIGC(Artificial Intellige…

Linux操作系统2-进程控制3(进程替换,exec相关函数和系统调用)

上篇文章:Linux操作系统2-进程控制2(进程等待,waitpid系统调用,阻塞与非阻塞等待)-CSDN博客 本篇代码Gitee仓库:Linux操作系统-进程的程序替换学习 d0f7bb4 橘子真甜/linux学习 - Gitee.com 本篇重点:进程替换 目录 …

Java函数式编程+Lambda表达式

文章目录 函数式编程介绍纯函数Lambda表达式基础Lambda的引入传统方法1. 顶层类2. 内部类3. 匿名类 Lambda 函数式接口(Functional Interface)1. **函数式接口的定义**示例: 2. **函数式接口与Lambda表达式的关系**关联逻辑:示例&…

DI依赖注入详解

DI依赖注入 声明了一个成员变量(对象)之后,在该对象上面加上注解AutoWired注解,那么在程序运行时,该对象自动在IOC容器中寻找对应的bean对象,并且将其赋值给成员变量,完成依赖注入。 AutoWire…

自动化运维(k8s)之微服务信息自动抓取:namespaceName、deploymentName等全解析

前言:公司云原生k8s二开工程师发了一串通用性命令用来查询以下数值,我想着能不能将这命令写成一个自动化脚本。 起初设计的 版本一:开头加一条环境变量,执行脚本后,提示输入:需要查询的命名空间&#xff0c…

[Python/网络安全] Git漏洞之Githack工具基本安装及使用详析

前言 本文仅分享Githack工具基本安装及使用相关知识,不承担任何法律责任。 Git是一个非常流行的开源分布式版本控制系统,它被广泛用于协同开发和代码管理。许多网站和应用程序都使用Git作为其代码管理系统,并将其部署到生产环境中以维护其代…

解决水库安全监测难题 长期无外接电源 低功耗设备智能化监测系统

解决水库安全监测难题 长期无外接电源 低功耗设备智能化监测系统 国内某水库安全监测项目需要监测点分散,且无外接供电。项目年限为4年,不允许使用太阳能电板。因此,我们需要设备具备低功耗且内置电池的功能。为了满足客户的要求,…

蓝桥杯c++算法秒杀【6】之动态规划【上】(数字三角形、砝码称重(背包问题)、括号序列、组合数问题:::非常典型的必刷例题!!!)

下将以括号序列、组合数问题超级吧难的题为例子讲解动态规划 别忘了请点个赞收藏关注支持一下博主喵!!!! ! ! ! ! 关注博主,更多蓝桥杯nice题目静待更新:) 动态规划 一、数字三角形 【问题描述】 上图给出了…

AD软件如何快速切换三维视图,由2D切换至3D,以及如何恢复

在Altium Designer软件中,切换三维视图以及恢复二维视图的操作相对简单。以下是具体的步骤: 切换三维视图 在PCB设计界面中,2D切换3D,快捷键按住数字键盘中的“3”即可切换; 快捷键ctrlf(或者vb快捷键也…

学习threejs,使用CubeCamera相机创建反光效果

👨‍⚕️ 主页: gis分享者 👨‍⚕️ 感谢各位大佬 点赞👍 收藏⭐ 留言📝 加关注✅! 👨‍⚕️ 收录于专栏:threejs gis工程师 文章目录 一、🍀前言1.1 ☘️CubeCamera 立方体相机 二、…

长时间无事可做是个危险信号

小马加入的是技术开发部,专注于Java开发。团队里有一位姓隋的女同事,是唯一的web前端工程师,负责页面开发工作,比小马早两个月入职。公司的项目多以定制化OA系统为主,后端任务繁重,前端工作相对较少。在这样…

Llama模型分布式训练(微调)

1 常见大模型 1.1 参数量对照表 模型参数量发布时间训练的显存需求VGG-19143.68M2014~5 GB(单 224x224 图像,batch_size32)ResNet-15260.19M2015~7 GB(单 224x224 图像,batch_size32)GPT-2 117M117M2019~…

Linux 子进程 -- fork函数

子进程 什么是子进程? 子进程指的是由一个已经存在的进程(称为父进程或父进程)创建的进程. 如: OS (操作系统) 就可以当作是一个进程, 用来管理软硬件资源, 当我点击浏览器, 想让浏览器运行起来时, 实际上是由 OS 接收指令, 然后 OS 帮我们将浏览器运行…

DataLoade类与list ,iterator ,yield的用法

1 问题 探索DataLoader的属性,方法 Vscode中图标含意 list 与 iterator 的区别,尤其yield的用法 2 方法 知乎搜索DataLoader的属性,方法 pytorch基础的dataloader类是 from torch.utils.data.dataloader import Dataloader 其主要的参数如下&…