From a01b4912e968c776ded92b52edd494e4256b5c4e Mon Sep 17 00:00:00 2001 From: Kenny Ho Date: Sat, 5 Oct 2024 17:08:12 -0400 Subject: [PATCH] Add signal handler to handle termination more gracefully Change-Id: I537f81ab494cef7fe8ecc0b38ae091b8aaf60ac1 --- internal/pkg/plugin/plugin.go | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/internal/pkg/plugin/plugin.go b/internal/pkg/plugin/plugin.go index 4ed31a11..f30efff3 100644 --- a/internal/pkg/plugin/plugin.go +++ b/internal/pkg/plugin/plugin.go @@ -21,9 +21,11 @@ import ( "bufio" "fmt" "os" + "os/signal" "path/filepath" "regexp" "strconv" + "syscall" "github.com/ROCm/k8s-device-plugin/internal/pkg/amdgpu" "github.com/ROCm/k8s-device-plugin/internal/pkg/hwloc" @@ -37,6 +39,7 @@ import ( type AMDGPUPlugin struct { AMDGPUs map[string]map[string]int Heartbeat chan bool + signal chan os.Signal } // Start is an optional interface that could be implemented by plugin. @@ -45,6 +48,9 @@ type AMDGPUPlugin struct { // method could be used to prepare resources before they are offered // to Kubernetes. func (p *AMDGPUPlugin) Start() error { + p.signal = make(chan os.Signal, 1) + signal.Notify(p.signal, syscall.SIGINT, syscall.SIGQUIT, syscall.SIGTERM) + return nil } @@ -187,6 +193,9 @@ func (p *AMDGPUPlugin) ListAndWatch(e *pluginapi.Empty, s pluginapi.DevicePlugin devs[i].Health = health } s.Send(&pluginapi.ListAndWatchResponse{Devices: devs}) + case <-p.signal: + glog.Infof("Received signal, exiting") + break } } // returning a value with this function will unregister the plugin from k8s @@ -245,6 +254,7 @@ func (p *AMDGPUPlugin) Allocate(ctx context.Context, r *pluginapi.AllocateReques type AMDGPULister struct { ResUpdateChan chan dpm.PluginNameList Heartbeat chan bool + Signal chan os.Signal } // GetResourceNamespace must return namespace (vendor ID) of implemented Lister. e.g. for