Empêcher Ctrl C de perturber exec.Command dans Golang
Des interruptions de Ctrl C peuvent être rencontrées lors de l'utilisation de exec.Command pour lancer des processus, même lorsque les appels d'interruption sont interceptés via signal.Notify. Ce problème se produit car le shell transmet des signaux à l'ensemble du groupe de processus dès réception de Ctrl C. Par conséquent, les processus enfants lancés avec exec.Command sont également affectés.
Pour atténuer ce problème et empêcher Ctrl C d'interrompre les processus enfants, il est nécessaire d'établir la commande avec son propre groupe de processus avant de commencer l'exécution. Ceci peut être réalisé en utilisant les champs SysProcAttr, Setpgid et Pgid de la structure syscall.SysProcAttr.
Voici un exemple modifié qui intègre cette approche :
package main import ( "log" "os" "os/exec" "os/signal" "syscall" ) func sleep() { log.Println("Sleep start") cmd := exec.Command("sleep", "60") cmd.SysProcAttr = &syscall.SysProcAttr{ Setpgid: true, } cmd.Run() log.Println("Sleep stop") } func main() { var doneChannel = make(chan bool) go sleep() c := make(chan os.Signal, 1) signal.Notify(c, os.Interrupt) signal.Notify(c, syscall.SIGTERM) go func() { <-c log.Println("Received Ctrl + C") }() <-doneChannel }
Avec cette modification, lorsque Ctrl C est enfoncé pendant que le programme est en exécution, la sortie suivante est produit :
2015/10/16 10:05:50 Sleep start ^C2015/10/16 10:05:52 Received Ctrl + C
La commande sleep continue de s'exécuter avec succès, démontrant la prévention des interruptions via Ctrl C.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!