扩展资源的资源箱打包

    该功能目前处于 alpha 状态,意味着:

    • 版本名称包含 alpha(例如 v1alpha1)。
    • 可能存在问题,启用该功能可能会暴露 bug。默认情况下被禁用。
    • 对该功能的支持可能在任何时候被取消,而不另行通知。
    • API 可能会在以后的软件版本中以不兼容的方式被更改,而不另行通知。
    • 建议仅在短期测试集群中使用该功能,这是因为使用该功能会增加出现 bug 的风险,而且缺乏长期支持。

    可以将 kube-scheduler 配置为使用 RequestedToCapacityRatioResourceAllocation 优先级函数启用资源箱打包以及扩展资源。 优先级函数可用于根据自定义需求微调 kube-scheduler 。

    在 Kubernetes 1.15 之前,Kube-scheduler 用于允许根据主要资源,如 CPU 和内存对容量之比的请求对节点进行评分。 Kubernetes 1.16 在优先级函数中添加了一个新参数,该参数允许用户指定资源以及每个资源的权重,以便根据容量之比的请求为节点评分。 这允许用户通过使用适当的参数来打包扩展资源,从而提高了大型集群中稀缺资源的利用率。 RequestedToCapacityRatioResourceAllocation 优先级函数的行为可以通过名为 requestedToCapacityRatioArguments 的配置选项进行控制。 这个论证由两个参数 shaperesources 组成。 Shape 允许用户根据 utilizationscore 值将功能调整为要求最少或要求最高的功能。 资源由 nameweight 组成,name 指定评分时要考虑的资源,weight 指定每种资源的权重。

    默认情况下禁用此功能

    shape 用于指定 RequestedToCapacityRatioPriority 函数的行为。

    1. {"utilization": 0, "score": 0},
    2. {"utilization": 100, "score": 10}

    上面的参数在利用率为 0% 时给节点评分为0,在利用率为 100% 时给节点评分为10,因此启用了装箱行为。 要启用最少请求,必须按如下方式反转得分值。

    1. "resources": [
    2. {"name": "CPU", "weight": 1},
    3. {"name": "Memory", "weight": 1}
    4. ]

    它可以用来添加扩展资源,如下所示:

    weight 参数是可选的,如果未指定,则设置为1。 同样, weight 不能设置为负值。

    RequestedToCapacityRatioResourceAllocation 优先级函数如何对节点评分

    本部分适用于希望了解此功能的内部细节的人员。 以下是如何针对给定的一组值计算节点得分的示例。

    1. Requested Resources
    2. intel.com/foo : 2
    3. Memory: 256MB
    4. CPU: 2
    5. Resource Weights
    6. intel.com/foo : 5
    7. Memory: 1
    8. CPU: 3
    9. FunctionShapePoint {{0, 0}, {100, 10}}
    10. Node 1 Spec
    11. Available:
    12. intel.com/foo : 4
    13. Memory : 1 GB
    14. Used:
    15. intel.com/foo: 1
    16. Memory: 256MB
    17. CPU: 1
    18. Node Score:
    19. intel.com/foo = resourceScoringFunction((2+1),4)
    20. = (100 - ((4-3)*100/4)
    21. = (100 - 25)
    22. = 75
    23. = rawScoringFunction(75)
    24. = 7
    25. Memory = resourceScoringFunction((256+256),1024)
    26. = (100 -((1024-512)*100/1024))
    27. = 50
    28. = rawScoringFunction(50)
    29. = 5
    30. CPU = resourceScoringFunction((2+1),8)
    31. = (100 -((8-3)*100/8))
    32. = 37.5
    33. = rawScoringFunction(37.5)
    34. = 3
    35. NodeScore = (7 * 5) + (5 * 1) + (3 * 3) / (5 + 1 + 3)
    36. = 5
    37. Node 2 Spec
    38. Available:
    39. intel.com/foo: 8
    40. Memory: 1GB
    41. CPU: 8
    42. Used:
    43. intel.com/foo: 2
    44. Memory: 512MB
    45. CPU: 6
    46. Node Score:
    47. intel.com/foo = resourceScoringFunction((2+2),8)
    48. = (100 - ((8-4)*100/8)
    49. = (100 - 25)
    50. = 50
    51. = rawScoringFunction(50)
    52. = 5
    53. Memory = resourceScoringFunction((256+512),1024)
    54. = (100 -((1024-768)*100/1024))
    55. = 75
    56. = rawScoringFunction(75)
    57. = 7
    58. CPU = resourceScoringFunction((2+6),8)
    59. = (100 -((8-8)*100/8))
    60. = 100
    61. = rawScoringFunction(100)
    62. = 10
    63. = 7