Skip to content

Commit

Permalink
Clean Systemd files on exit
Browse files Browse the repository at this point in the history
If implemented all systemD related files will be cleaned up on exit.
  • Loading branch information
souleb committed Oct 14, 2024
1 parent a85ab70 commit 9700ce2
Show file tree
Hide file tree
Showing 2 changed files with 50 additions and 19 deletions.
60 changes: 42 additions & 18 deletions cmd/sriov-network-config-daemon/start.go
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,9 @@ import (
"net"
"net/url"
"os"
"os/signal"
"strings"
"syscall"
"time"

"github.com/spf13/cobra"
Expand Down Expand Up @@ -134,7 +136,6 @@ func runStartCmd(cmd *cobra.Command, args []string) error {

// This channel is used to ensure all spawned goroutines exit when we exit.
stopCh := make(chan struct{})
defer close(stopCh)

// This channel is used to signal Run() something failed and to jump ship.
// It's purely a chan<- in the Daemon struct for goroutines to write to, and
Expand Down Expand Up @@ -286,6 +287,7 @@ func runStartCmd(cmd *cobra.Command, args []string) error {
err = kClient.Get(context.Background(), types.NamespacedName{Namespace: vars.Namespace, Name: consts.DefaultConfigName}, defaultConfig)
if err != nil {
log.Log.Error(err, "Failed to get default SriovOperatorConfig object")
close(stopCh)
return err
}
featureGates := featuregate.New()
Expand All @@ -294,25 +296,47 @@ func runStartCmd(cmd *cobra.Command, args []string) error {
log.Log.Info("Enabled featureGates", "featureGates", featureGates.String())

setupLog.V(0).Info("Starting SriovNetworkConfigDaemon")
err = daemon.New(
kClient,
snclient,
kubeclient,
hostHelpers,
platformHelper,
exitCh,
stopCh,
syncCh,
refreshCh,
eventRecorder,
featureGates,
startOpts.disabledPlugins,
).Run(stopCh, exitCh)
if err != nil {
setupLog.Error(err, "failed to run daemon")

// create a signal channel to catch interrupts
sigc := make(chan os.Signal, 1)
signal.Notify(sigc, os.Interrupt)
signal.Notify(sigc, syscall.SIGTERM)

errChan := make(chan error)
defer close(errChan)
go func() {
if err := daemon.New(
kClient,
snclient,
kubeclient,
hostHelpers,
platformHelper,
exitCh,
stopCh,
syncCh,
refreshCh,
eventRecorder,
featureGates,
startOpts.disabledPlugins,
).Run(stopCh, exitCh); err != nil {
errChan <- err
}
}()

select {
case err := <-errChan:
// daemon has exited, close the stop channel and return the error
close(stopCh)
return err
case <-sigc:
// signal received, close the stop channel and wait for the daemon to exit
close(stopCh)
if err := <-errChan; err != nil {
return err
}
}
setupLog.V(0).Info("Shutting down SriovNetworkConfigDaemon")
return err
return nil
}

// updateDialer instruments a restconfig with a dial. the returned function allows forcefully closing all active connections.
Expand Down
9 changes: 8 additions & 1 deletion pkg/daemon/daemon.go
Original file line number Diff line number Diff line change
Expand Up @@ -207,8 +207,15 @@ func (dn *Daemon) Run(stopCh <-chan struct{}, exitCh <-chan error) error {
for {
select {
case <-stopCh:
// clean files from host if we are running in systemd mode
if vars.UsingSystemdMode {
err := systemd.CleanSriovFilesFromHost(vars.ClusterType == consts.ClusterTypeOpenshift)
if err != nil {
log.Log.Error(err, "failed to remove all the systemd sriov files")
return err
}
}
log.Log.V(0).Info("Run(): stop daemon")
return nil
case err, more := <-exitCh:
log.Log.Error(err, "got an error")
if more {
Expand Down

0 comments on commit 9700ce2

Please sign in to comment.