Parfois, on voudrait que les programmes en Go gèrent intelligemment les signaux Unix.
Par exemple, on peut vouloir qu’un serveur s’éteigne gracieusement lorsqu’il reçoit le signal |
|
package main
|
|
import "fmt"
import "os"
import "os/signal"
import "syscall"
|
|
func main() {
|
|
Go signale les travaux de notification en envoyer des valeurs |
sigs := make(chan os.Signal, 1)
done := make(chan bool, 1)
|
|
signal.Notify(sigs, syscall.SIGINT, syscall.SIGTERM)
|
Cette goroutine exécute une réception bloquante des signaux. Quand elle se termine, elle l’affichera et notifiera le programme qu’il peut terminer. |
go func() {
sig := <-sigs
fmt.Println()
fmt.Println(sig)
done <- true
}()
|
Le programme va attendre ici jusqu’à ce qu’il reçoive le signal attendu (comme indiqué par la goroutine au dessus, qui envoit une valeur sur |
fmt.Println("awaiting signal")
<-done
fmt.Println("exiting")
}
|
Quand on lance ce programme, il va bloquer, en
attendant un signal. En faisant |
$ go run signals.go
awaiting signal
^C
interrupt
exiting
|
Exemple suivant: Sortie.