mirror of
				https://github.com/coredns/coredns.git
				synced 2025-10-29 01:04:15 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			80 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // +build !windows
 | |
| 
 | |
| package core
 | |
| 
 | |
| import (
 | |
| 	"io/ioutil"
 | |
| 	"log"
 | |
| 	"os"
 | |
| 	"os/signal"
 | |
| 	"syscall"
 | |
| )
 | |
| 
 | |
| // trapSignalsPosix captures POSIX-only signals.
 | |
| func trapSignalsPosix() {
 | |
| 	go func() {
 | |
| 		sigchan := make(chan os.Signal, 1)
 | |
| 		signal.Notify(sigchan, syscall.SIGTERM, syscall.SIGHUP, syscall.SIGQUIT, syscall.SIGUSR1)
 | |
| 
 | |
| 		for sig := range sigchan {
 | |
| 			switch sig {
 | |
| 			case syscall.SIGTERM:
 | |
| 				log.Println("[INFO] SIGTERM: Terminating process")
 | |
| 				if PidFile != "" {
 | |
| 					os.Remove(PidFile)
 | |
| 				}
 | |
| 				os.Exit(0)
 | |
| 
 | |
| 			case syscall.SIGQUIT:
 | |
| 				log.Println("[INFO] SIGQUIT: Shutting down")
 | |
| 				exitCode := executeShutdownCallbacks("SIGQUIT")
 | |
| 				err := Stop()
 | |
| 				if err != nil {
 | |
| 					log.Printf("[ERROR] SIGQUIT stop: %v", err)
 | |
| 					exitCode = 1
 | |
| 				}
 | |
| 				if PidFile != "" {
 | |
| 					os.Remove(PidFile)
 | |
| 				}
 | |
| 				os.Exit(exitCode)
 | |
| 
 | |
| 			case syscall.SIGHUP:
 | |
| 				log.Println("[INFO] SIGHUP: Hanging up")
 | |
| 				err := Stop()
 | |
| 				if err != nil {
 | |
| 					log.Printf("[ERROR] SIGHUP stop: %v", err)
 | |
| 				}
 | |
| 
 | |
| 			case syscall.SIGUSR1:
 | |
| 				log.Println("[INFO] SIGUSR1: Reloading")
 | |
| 
 | |
| 				var updatedCaddyfile Input
 | |
| 
 | |
| 				caddyfileMu.Lock()
 | |
| 				if caddyfile == nil {
 | |
| 					// Hmm, did spawing process forget to close stdin? Anyhow, this is unusual.
 | |
| 					log.Println("[ERROR] SIGUSR1: no Caddyfile to reload (was stdin left open?)")
 | |
| 					caddyfileMu.Unlock()
 | |
| 					continue
 | |
| 				}
 | |
| 				if caddyfile.IsFile() {
 | |
| 					body, err := ioutil.ReadFile(caddyfile.Path())
 | |
| 					if err == nil {
 | |
| 						updatedCaddyfile = CaddyfileInput{
 | |
| 							Filepath: caddyfile.Path(),
 | |
| 							Contents: body,
 | |
| 							RealFile: true,
 | |
| 						}
 | |
| 					}
 | |
| 				}
 | |
| 				caddyfileMu.Unlock()
 | |
| 
 | |
| 				err := Restart(updatedCaddyfile)
 | |
| 				if err != nil {
 | |
| 					log.Printf("[ERROR] SIGUSR1: %v", err)
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 	}()
 | |
| }
 |