Иногда нам хотелось бы, чтобы наши программы на Go
интеллектуально обрабатывали сигналы Unix.
Например, мы можем захотеть, чтобы сервер корректно
завершил работу при получении |
|
package main
|
|
import (
"fmt"
"os"
"os/signal"
"syscall"
)
|
|
func main() {
|
|
Уведомление о выходе сигнала работает путем
отправки значений |
sigs := make(chan os.Signal, 1)
done := make(chan bool, 1)
|
|
signal.Notify(sigs, syscall.SIGINT, syscall.SIGTERM)
|
Эта горутина выполняет блокировку приема сигналов. Когда она получит его, то распечатает его, а затем уведомит программу, что она может быть завершена. |
go func() {
sig := <-sigs
fmt.Println()
fmt.Println(sig)
done <- true
}()
|
Программа будет ждать здесь, пока не получит
ожидаемый сигнал (как указано в приведенной
выше процедуре, отправляющей значение в |
fmt.Println("awaiting signal")
<-done
fmt.Println("exiting")
}
|
Когда мы запустим эту программу, она заблокирует
ожидание сигнала. Набрав |
$ go run signals.go
awaiting signal
^C
interrupt
exiting
|
Следующий пример: Выход (Exit).