how to handle signals go by example
Jul 25, 2025 am 04:36 AMUse signal.Notify() in the os/signal package to register the specified signal (such as SIGINT, SIGTERM) to the buffer channel, so that the program can capture rather than terminate by default; 2. Wait for the signal to arrive through
Handling signals in Go is essential when you want your program to respond gracefully to OS-level events like SIGTERM
, SIGINT
, or SIGHUP
. For example, you might want to clean up resources, close files, or shut down a server properly when a user presses Ctrl C
.

Let's go through a practical example to show how signal handling works in Go.
?? Basic Signal Handling in Go
Here's a simple Go program that listens for interrupt signals and shuts down gracefully:

package main import ( "fmt" "os" "os/signal" "syscall" "time" ) func main() { // Create a channel to receive OS signals sigChan := make(chan os.Signal, 1) // Notify the channel of specific signals signal.Notify(sigChan, os.Interrupt, syscall.SIGTERM) fmt.Println("Server started... (press Ctrl C to stop)") // Simulate work in the background go func() { for { fmt.Println("Working...") time.Sleep(2 * time.Second) } }() // Block until a signal is received sig := <-sigChan fmt.Printf("\nReceived signal: %v\n", sig) // Perform cleanup fmt.Println("Cleaning up resources...") time.Sleep(1 * time.Second) // Simulate cleanup fmt.Println("Shutdown complete.") }
? What's Happening?
-
signal.Notify(sigChan, ...)
tells Go to send the specified signals tosigChan
instead of letting them terminate the program immediately. -
os.Interrupt
corresponds toCtrl C
(SIGINT
). -
syscall.SIGTERM
is the standard termination signal (used by tools likekill
). - The program runs a background goroutine simulating work.
-
<-sigChan
blocks execution until a signal arrives. - Once a signal is received, we handle cleanup before exiting.
? Graceful Shutdown with HTTP Server
A common real-world use case is gracefully shutting down an HTTP server:
package main import ( "context" "log" "net/http" "os" "os/signal" "syscall" "time" ) func main() { mux := http.NewServeMux() mux.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) { time.Sleep(5 * time.Second) // Simulate long-running request w.Write([]byte("Hello, world!")) }) server := &http.Server{ Addr: ":8080", Handler: mux, } // Start server in a goroutine go func() { fmt.Println("Starting server on :8080") if err := server.ListenAndServe(); err != http.ErrServerClosed { log.Fatalf("Server failed: %v", err) } }() // Set up signal handling sigChan := make(chan os.Signal, 1) signal.Notify(sigChan, os.Interrupt, syscall.SIGTERM) // Wait for interrupt signal <-sigChan fmt.Println("\nShutting down server...") // Create a deadline to wait for graceful shutdown ctx, cancel := context.WithTimeout(context.Background(), 10*time.Second) defer cancel() // Attempt graceful shutdown if err := server.Shutdown(ctx); err != nil { log.Printf("Server forced to shutdown: %v", err) } else { fmt.Println("Server stopped gracefully.") } }
? Key Points
- Always use
signal.Notify()
with a buffered channel (size 1 is enough). - Use
context.WithTimeout()
to avoid hanging during shutdown. - Call
server.Shutdown()
to stop the HTTP server gracefully—this stops new connections and give active requests time to finish. - Handle both
os.Interrupt
(Ctrl C) andsyscall.SIGTERM
(used in production environments like Docker/Kubernetes).
? Supported Signals (Common Ones)
Signal | Meaning |
---|---|
SIGINT | Interrupt (Ctrl C) |
SIGTERM | Termination request (graceful) |
SIGQUIT | Quit with core dump |
SIGHUP | Hang-up (config reload in daemons) |
Note:
SIGKILL
andSIGSTOP
cannot be caught or ignored.
? Pro Tip: Reload Config with SIGHUP
You can use SIGHUP
to trigger config reloads (common in daemons):
signal.Notify(sigChan, syscall.SIGHUP) go func() { for { sig := <-sigChan if sig == syscall.SIGHUP { fmt.Println("Reloading config...") // Reload your config file here } } }()
Handling signals in Go is straightforward with the os/signal
package. Whether you're building a CLI tool, a daemon, or a web server, proper signal handling ensures your app behaves predictably and cleans up properly.
Basically, just set up a channel, notify it of the signals you care about, and react when they arrive.
The above is the detailed content of how to handle signals go by example. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Go's switch statement will not be executed throughout the process by default and will automatically exit after matching the first condition. 1. Switch starts with a keyword and can carry one or no value; 2. Case matches from top to bottom in order, only the first match is run; 3. Multiple conditions can be listed by commas to match the same case; 4. There is no need to manually add break, but can be forced through; 5.default is used for unmatched cases, usually placed at the end.

Usereflect.ValueOfandreflect.TypeOftogetruntimevaluesandtypes;2.Inspecttypedetailswithreflect.TypemethodslikeName()andKind();3.Modifyvaluesviareflect.Value.Elem()andCanSet()afterpassingapointer;4.CallmethodsdynamicallyusingMethodByName()andCall();5.R

In Go language, HTTP middleware is implemented through functions, and its core answer is: the middleware is a function that receives and returns http.Handler, used to execute general logic before and after request processing. 1. The middleware function signature is like func (Middleware(nexthttp.Handler)http.Handler), which achieves functional expansion by wrapping the original processor; 2. The log middleware in the example records the request method, path, client address and processing time-consuming, which is convenient for monitoring and debugging; 3. The authentication middleware checks the Authorization header, and returns 401 or 403 errors when verification fails to ensure secure access; 4. Multiple middleware can be nested to adjust

In Go, to break out of nested loops, you should use labeled break statements or return through functions; 1. Use labeled break: Place the tag before the outer loop, such as OuterLoop:for{...}, use breakOuterLoop in the inner loop to directly exit the outer loop; 2. Put the nested loop into the function, and return in advance when the conditions are met, thereby terminating all loops; 3. Avoid using flag variables or goto, the former is lengthy and easy to make mistakes, and the latter is not recommended; the correct way is that the tag must be before the loop rather than after it, which is the idiomatic way to break out of multi-layer loops in Go.

Usecontext.WithTimeouttocreateacancellablecontextwithadeadlineandalwayscallcancel()toreleaseresources.2.ForHTTPrequests,settimeoutsusinghttp.Client.Timeoutorusecontextviahttp.NewRequestWithContextforper-requestcontrol.3.Ingoroutineswithchannels,usese

UsestructswithPERJSontagsFeRpredictabledatoensurefast, safeparsingwithcompile-timetypesafety.2.avoidmap [string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] interface {string] }duetoreflectionoverheadandruntimetypeassertionsunlessdealingwithtrulydynamicJSON.3.Usejson.RawMessagefordeferredorselectivep

Usecontexttopropagatecancellationanddeadlinesacrossgoroutines,enablingcooperativecancellationinHTTPservers,backgroundtasks,andchainedcalls.2.Withcontext.WithCancel(),createacancellablecontextandcallcancel()tosignaltermination,alwaysdeferringcancel()t

InitializeaGomodulewithgomodinit,2.InstallgqlgenCLI,3.Defineaschemainschema.graphqls,4.Rungqlgeninittogeneratemodelsandresolvers,5.Implementresolverfunctionsforqueriesandmutations,6.SetupanHTTPserverusingthegeneratedschema,and7.RuntheservertoaccessGr
