From 3feb4fec4b7b631793168e55ef40013e854bcce9 Mon Sep 17 00:00:00 2001 From: Soulan Saeng Date: Mon, 29 Apr 2024 13:22:24 -0400 Subject: [PATCH 1/3] adding sleep --- main.go | 2 ++ 1 file changed, 2 insertions(+) diff --git a/main.go b/main.go index fc3cb3d..0541175 100644 --- a/main.go +++ b/main.go @@ -6,6 +6,7 @@ import ( "os" "strconv" "strings" + "time" "github.com/gofrs/uuid" ) @@ -125,6 +126,7 @@ func main() { fmt.Println(line) } fmt.Println() + time.Sleep(time.Minute * 3) fmt.Printf("==> Server listening at %s 🚀\n", bindAddr) err := http.ListenAndServe(fmt.Sprintf(":%s", port), nil) From b172fc482c33226143bb01b0b62509cfb53c8529 Mon Sep 17 00:00:00 2001 From: Soulan Saeng Date: Thu, 1 May 2025 11:39:57 -0400 Subject: [PATCH 2/3] update go version & run go mod tidy remove sleep. --- go.mod | 4 ++-- go.sum | 5 ++--- main.go | 2 -- 3 files changed, 4 insertions(+), 7 deletions(-) diff --git a/go.mod b/go.mod index 0a5ec84..ff20217 100644 --- a/go.mod +++ b/go.mod @@ -1,5 +1,5 @@ module github.com/digitalocean/sample-golang -go 1.13 +go 1.22 -require github.com/gofrs/uuid v3.3.0+incompatible // indirect +require github.com/gofrs/uuid v4.4.0+incompatible diff --git a/go.sum b/go.sum index 4b1328f..c0ad687 100644 --- a/go.sum +++ b/go.sum @@ -1,3 +1,2 @@ -github.com/gofrs/uuid v1.2.0 h1:coDhrjgyJaglxSjxuJdqQSSdUpG3w6p1OwN2od6frBU= -github.com/gofrs/uuid v3.3.0+incompatible h1:8K4tyRfvU1CYPgJsveYFQMhpFd/wXNM7iK6rR7UHz84= -github.com/gofrs/uuid v3.3.0+incompatible/go.mod h1:b2aQJv3Z4Fp6yNu3cdSllBxTCLRxnplIgP/c0N/04lM= +github.com/gofrs/uuid v4.4.0+incompatible h1:3qXRTX8/NbyulANqlc0lchS1gqAVxRgsuW1YrTJupqA= +github.com/gofrs/uuid v4.4.0+incompatible/go.mod h1:b2aQJv3Z4Fp6yNu3cdSllBxTCLRxnplIgP/c0N/04lM= diff --git a/main.go b/main.go index 0541175..fc3cb3d 100644 --- a/main.go +++ b/main.go @@ -6,7 +6,6 @@ import ( "os" "strconv" "strings" - "time" "github.com/gofrs/uuid" ) @@ -126,7 +125,6 @@ func main() { fmt.Println(line) } fmt.Println() - time.Sleep(time.Minute * 3) fmt.Printf("==> Server listening at %s 🚀\n", bindAddr) err := http.ListenAndServe(fmt.Sprintf(":%s", port), nil) From 040a55a7499a01dc1cd4bcaa267bd11ddc0e26a4 Mon Sep 17 00:00:00 2001 From: Soulan Saeng Date: Tue, 29 Jul 2025 11:32:42 -0400 Subject: [PATCH 3/3] log out sigterm --- main.go | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/main.go b/main.go index 43d1ce5..1fb184f 100644 --- a/main.go +++ b/main.go @@ -4,8 +4,10 @@ import ( "fmt" "net/http" "os" + "os/signal" "strconv" "strings" + "syscall" "github.com/gofrs/uuid" ) @@ -127,6 +129,16 @@ func main() { fmt.Println() fmt.Printf("==> Server listening at %s 🚀\n", bindAddr) + sigCh := make(chan os.Signal, 1) + signal.Notify(sigCh, os.Interrupt, syscall.SIGTERM, syscall.SIGINT, syscall.SIGQUIT, syscall.SIGKILL) + go func() { + fmt.Println("Waiting for shutdown signal...") + sig := <-sigCh + fmt.Printf("Shutdown signal received: %s\n", sig) + // Perform cleanup or shutdown here + os.Exit(0) + }() + if err := http.ListenAndServe(bindAddr, nil); err != nil { panic(err) }