Updated on 2025-08-12 GMT+08:00

Scheduling Workloads to CCI 2.0

This section describes how you can schedule workloads to CCI 2.0 when needed.

You can use either of the following methods to schedule the workloads from a CCE cluster to CCI 2.0:

Constraints

  • You can only use ScheduleProfile to manage a workload and schedule it to CCI 2.0 when native labels of the workload are matched by ScheduleProfile. For example, the labels added to a workload through ExtensionProfile cannot be matched by ScheduleProfile. For this reason, the workload cannot be scheduled by ScheduleProfile.
  • You can use labels to control pod scheduling to CCI 2.0. You need to add a label before a workload is created. If you add a label to an existing workload, the pods for the workload will not be updated. In this case, you can select the workload and choose More > Redeploy for update.

Prerequisites

  • Add-on version: The CCE Cloud Bursting Engine for CCI add-on has been installed. If you use profiles to control pod scheduling to CCI, the add-on version must be 1.3.19 or later.
  • Cluster type: If profiles are used to control pod scheduling to CCI, only CCE standard clusters and CCE Turbo clusters that use VPC networks are supported.

Scheduling Policies

There are four policies for elastically scheduling workloads from a CCE cluster to CCI 2.0.

Scheduling Policy

Policy Diagram

Application Scenario

Forcible scheduling (enforce)

Workloads are forcibly scheduled to CCI 2.0.

Automatic scheduling (auto)

Workloads are scheduled to CCI 2.0 based on the scoring results provided by the cluster scheduler.

Local priority scheduling (localPrefer)

Workloads are preferentially scheduled to a CCE cluster. If cluster resources are insufficient, Workloads are elastically scheduled to CCI 2.0.

Disable scheduling (off)

Workloads will not be scheduled to CCI 2.0.

Method 1: Using a Label

You can configure a label to control pod scheduling to CCI using either the console or YAML files.

Using the Console

  1. Log in to the CCE console and click the cluster name to go to the cluster console.
  2. In the navigation pane, choose Workloads. On the displayed page, click Create Workload.
  3. In the Basic Info area, select any policy other than Disable scheduling.

    • Priority scheduling: Pods will be preferentially scheduled to nodes in your CCE cluster. When the node resources are insufficient, pods will then be burst to CCI.
    • Force scheduling: All pods will be scheduled to CCI.

  4. Select the required CCI resource pool.

    • CCI 2.0 (bursting-node): next-generation serverless resource pool
    • CCI 1.0 (virtual-kubelet): existing serverless resource pool, which will be unavailable soon.

      When creating a workload on the CCE console, you can select either CCI 2.0 (bursting-node) or CCI 1.0 (virtual-kubelet). If you use CCI 1.0, select CCI 1.0 (virtual-kubelet). If you use CCI 2.0, select CCI 2.0 (bursting-node).

  5. Create a workload on the CCE console by following the instructions in Creating a Workload. After the workload is created, click OK.

Using YAML

  1. Log in to the CCE console and click the cluster name to go to the cluster console.
  2. In the navigation pane, choose Workloads. On the displayed page, click Create from YAML.
  3. Add the virtual-kubelet.io/burst-to-cci label to the YAML file of the workload.

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: test
      namespace: default
      labels:
        bursting.cci.io/burst-to-cci: 'auto'    # Schedules the workload to CCI.
    spec:
      replicas: 2
      selector:
        matchLabels:
          app: test
      template:
        metadata:
          labels:
            app: test
        spec:
          containers:
            - image: 'nginx:perl'
              name: container-0
              resources:
                requests:
                  cpu: 250m
                  memory: 512Mi
                limits:
                  cpu: 250m
                  memory: 512Mi
              volumeMounts: []
          imagePullSecrets:
            - name: default-secret
    Table 1 Key parameters

    Parameter

    Type

    Description

    bursting.cci.io/burst-to-cci

    String

    Policy for automatically scheduling the workload from the CCE cluster to CCI. The options are as follows:
    • enforce: The workload is forcibly scheduled to CCI 2.0.
    • auto: The workload is scheduled to CCI 2.0 based on the scoring results provided by the cluster scheduler.
    • localPrefer: The workload is preferentially scheduled to a CCE cluster. If cluster resources are insufficient, Workloads are elastically scheduled to CCI 2.0.
    • off: The workload will not be scheduled to CCI 2.0.

  1. Click OK.

Method 2: Using a Profile

You can configure profiles to control pod scheduling to CCI using either the console or YAML files.

Using the Console

  1. Log in to the CCE console and click the cluster name to go to the cluster console.
  2. In the navigation pane, choose Policies > CCI Scaling Policies.
  3. Click Create CCI Scaling Policy and configure the parameters.

    Table 2 Parameters for creating a CCI scaling policy

    Parameter

    Description

    Policy Name

    Enter a policy name.

    Namespace

    Select the namespace where the scheduling policy applies. You can select an existing namespace or create a namespace. For details, see Creating a Namespace.

    Workload

    Enter a key and value or reference a workload label.

    Scheduling Policy

    Select a scheduling policy.

    • Priority scheduling: Pods will be preferentially scheduled to nodes in the current CCE cluster. When the node resources are insufficient, pods will be scheduled to CCI.
    • Force scheduling: All pods will be scheduled to CCI.

    Scale to

    • Local: Set the current CCE cluster.
    • CCI: Set the maximum number of pods that can run on CCI.

    Maximum Pods

    Enter the maximum number of pods that can run in the CCE cluster or on CCI.

    CCE Scale-in Priority

    Value range: –100 to 100. A larger value indicates a higher priority.

    CCI Scale-in Priority

    Value range: –100 to 100. A larger value indicates a higher priority.

    CCI Resource Pool

    • CCI 2.0 (bursting-node): next-generation serverless resource pool
    • CCI 1.0 (virtual-kubelet): existing serverless resource pool, which will be unavailable soon.

  4. Click OK.
  1. In the navigation pane, choose Workloads. Then click Create Workload. In Advanced Settings > Labels and Annotations, add a pod label. The key and value must be the same as those for the workload in 3. For other parameters, see Creating a Workload.
  2. Click Create Workload.

Using YAML

  1. Log in to the CCE console and click the cluster name to go to the cluster console.
  2. In the navigation pane, choose Policies > CCI Scaling Policies.
  3. Click Create from YAML to create a profile.

    Example 1: Configure local maxNum and scaleDownPriority to limit the maximum number of pods for the workloads that can be scheduled to the CCE cluster.
    apiVersion: scheduling.cci.io/v2
    kind: ScheduleProfile
    metadata:
      name: test-local-profile
      namespace: default
    spec:
      objectLabels:
        matchLabels:
          app: nginx
      strategy: localPrefer
      virtualNodes:
        - type: bursting-node
      location:
        local: 
          maxNum: 20 # maxNum can be configured either for local or cci.
          scaleDownPriority: 2
        cci: 
          scaleDownPriority: 10
    Example 2: Configure maxNum and scaleDownPriority for cci to limit the maximum number of pods that are allowed for the workloads scheduled to CCI.
    apiVersion: scheduling.cci.io/v2
    kind: ScheduleProfile
    metadata:
      name: test-cci-profile
      namespace: default
    spec:
      objectLabels:
        matchLabels:
          app: nginx
      strategy: localPrefer
      virtualNodes:
        - type: bursting-node
      location:
        local: {}
        cci:
          maxNum: 20 # maxNum can be configured either for local or cci.
          scaleDownPriority: 10
    Table 3 Key parameters

    Parameter

    Type

    Description

    strategy

    String

    Policy for automatically scheduling a workload from a CCE cluster to CCI 2.0. The options are as follows:
    • enforce: The workload is forcibly scheduled to CCI 2.0.
    • auto: The workload is scheduled to CCI 2.0 based on the scoring results provided by the cluster scheduler.
    • localPrefer: The workload is preferentially scheduled to a CCE cluster. If cluster resources are insufficient, Workloads are elastically scheduled to CCI 2.0.

    maxNum

    int

    Maximum number of pods.

    The value ranges from 0 to int32.

    scaleDownPriority

    int

    Scale-in priority. The larger the value, the earlier the associated pods are removed.

    The value ranges from -100 to 100.

    • In the location field, configure the local field for CCE and cci for CCI to control the number of pods and scale-in priority.
    • maxNum can be configured either for local or cci.
    • Scale-in priority is optional. If it is not specified, the default value is set to nil.

  1. Click OK.
  2. Create a Deployment, use the selector to select the pods labeled with app:nginx, and associate the pods with the profile.

    kind: Deployment
    apiVersion: apps/v1
    metadata:
      name: nginx
    spec:
      replicas: 10
      selector:
        matchLabels:
          app: nginx
      template:
        metadata:
          labels:
            app: nginx
        spec:
          containers:
            - name: container-1
              image: nginx:latest
              imagePullPolicy: IfNotPresent
              resources:
                requests:
                  cpu: 250m
                  memory: 512Mi
                limits:
                  cpu: 250m
                  memory: 512Mi
          imagePullSecrets:
            - name: default-secret
    Table 4 Special scenarios

    Scenario

    How to Schedule

    Both a label and a profile are used to schedule the workloads to CCI 2.0.

    The scheduling priority of the label is higher than that of the profile.

    For example, if the scheduling policy of the label is off and the scheduling policy of the profile is set to enforce, the workloads will not be scheduled to CCI 2.0.

    There are multiple profiles specified for a pod.

    A pod can only have one profile. If a pod has multiple profiles, the profile that can associate the maximum of labels is used. If there are multiple profiles that can associate an equal number of labels, the profile whose name has the smallest alphabetical order is used.

    In this figure, the pod is finally associated with profileA.

  3. Click OK.