Skip to content

Latest commit

 

History

History
196 lines (106 loc) · 5.63 KB

CHANGELOG.md

File metadata and controls

196 lines (106 loc) · 5.63 KB

CHANGELOG

v1.0.1

Add MIG support:"mixed strategy"

Add support for kubernetes v1.22+

v1.0.1.1

Bugs fixed

a pod can be scheduled to a node where its core usage is 100 - Fixed

cudevshr.cache can't be modified with non-root users - Fixed

v1.0.1.2

Add custom resource name

A task with cores=100 will allocate all device memory(virtual device memory excluded)

v1.0.1.3

nvidia.com/gpucores will limit the GPU utilization inside container Prior than v1.0.1.3, nvidia.com/gpucores will not limit utilization inside container, we have fixed it in v1.0.1.3

v1.0.1.4

Add nvidia.com/gpumem-percentage resoure name This resource indicates the device memory percentage of GPU, can not be used with "nvidia.com/gpumem". If you want an exclusive GPU, specify both the "nvidia.com/gpucores" and "nvidia.com/gpumem-percentage" to 100

Add GPU type specification You can set "nvidia.com/use-gputype" annotation to specify which type of GPU to use. "nvidia.com/nouse-gputype" annotation to specify which type of GPU to avoid.

v1.0.1.5

Fix an monitor "desc not found" error

Add "devicePlugin.sockPath" parameter to set the location of vgpu.sock

v1.1.0.0

Major Update: Device Memory will be counted more accurately serveral device memory usage, including cuda context, modules, parameters, reserved addresses will be counted in v1.1.0.0

Update to be compatable with CUDA 11.6 and Driver 500+

Rework monitor strategy Monitor will mmap control file into address space instead of reading it in each query.

v1.1.1.0

Fix segmentation fault when invoking cuMallocAsync

Core Utilization Oversubscribe and priority-base scheduling Currently we have two priority, 0 for high and 1 for low. The core utilization of high priority task won't be limited to resourceCores unless sharing GPU node with other high priority tasks. The core utilization of low priority task won't be limited to resourceCores if no other tasks sharing its GPU. See exmaple.yaml for more details

Add Container Core Utilization policy See details in docs/config.md(docs/config_cn.md)

v2.2

Update device memory counting mechanism to compat with CUDA 11.3+ task sometimes vgpu-scheduler won't able to collect device memory usage when running cuda11.3+ compiled tasks in v1.x version of vgpu-scheduler. We solve this problem by reworking device memory counting mechanism.

Use node annotation instead of grpc to communicate between scheduler and device-plugin In v1.x version of vgpu-scheduler, we use grpc to communicate between scheduler and device-plugin, but we reimplement this communication in v2.x by using node annotation, to make it more stable and readable.

modified nvidia-container-runtime is no longer needed We remove self-modified nvidia-container-runtime in v1.x, because we now use node lock to track pod and container information. so this nvidia-container-runtime is no longer needed.

v2.2.7

BUG fix

fix tasks with "gpumem-percentage" not working properly

fix dead lock when a process die with its lock not released

Adjust certain logs

update go modules to more recent version in order to support k8s v1.25

v2.2.8

BUG fix

fix vGPUmonitor not working properly with containerd

fix installation error on k8s v1.25+

v2.2.9

BUG fix

fix non-root user in container can't access /tmp/vgpulock, result in "unified lock error"

Rework device registration

device registration used to be done in gRpc between device-plugin and scheduler. However, in some cluster, this communication may be blocked by firewall or selinux configuration. So, we reimplement device registration mechanism by using node annotations: A-device-plugin will put its usable device and its status in "Node-A-device-register" annotation scheduler will read from this annotation and acknowledge this registration. So, gRpc will no longer be used.

Optimization in code

Put nvidia-device-plugin related code in a seperate directory "nvidiadevice"

Libvgpu log adjusting

Downgrade the following API from LOG:WARN to LOG:INFO cuFuncSetCacheConfig, cuFuncSetCacheConfig ,cuModuleGetTexRef, cuModuleGetSurfRef

v2.2.10

BUG fix

fix process can't initialize properly in driver 440

fix cuCtxCreate failed in some tensorRT task

fix env CUDA_VISIBLE_DEVICES not working properly sometimes.

v2.2.11

BUG fix

fix initialization failed with non-root uers

fix core limitation not working properly on A30

v2.2.12

Downgrade core control output from LOG:WARN to LOG:DEBUG

v2.2.13

Adjust default memory to 0, which means use 100% device memory

Move cache file directory from /tmp/vgpu/containers to /usr/local/vgpu/containers

v2.2.14

Fix device memory calculation error after container crashloop

Fix env cuda_oversubscribe not set properly when MemoryScaling < 1

Fix MemoryScaling not working when set < 1

v2.2.15

Move shared-memory from from /tmp/xxx.cache to /usr/local/vgpu/xxx.cache inside container

Add Deviceidx to scheduler monitor apis(31993)

v2.2.16

Fix crash during initlization in vGPUmonitor

v2.3

v2.3.0

Fix oom can't be triggered when loading module

Update device-plugin version to v0.14.0

v2.3.1

Fix a bug where a cuda process can't be launched properly

v2.3.2

Remove node selector for scheduler

Fix an issue where mlu device-plugin can't be launched properly

Major rework on devices-related code

Add support for hygon DCU device

v2.3.3

Fix an issue where pod pending on nodes with multi-architect devices.

v2.3.4

Fix an issue where 31993 port can't list all GPU nodes

Add a switch on cuda_control by set env "CUDA_DISABLE_ENV=true" in container

v2.3.6

Fix initialization error when using ray