run.go 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. package lxrun
  2. import (
  3. "context"
  4. "fmt"
  5. "git.listensoft.net/tool/lxutils/lxlog"
  6. "git.listensoft.net/tool/lxutils/lxzap"
  7. "github.com/gin-gonic/gin"
  8. "log"
  9. "net/http"
  10. "os"
  11. "os/signal"
  12. "syscall"
  13. "time"
  14. )
  15. func Run(env string, port string, fun func(), r func(router *gin.Engine), zapConfig lxzap.LogConfig) {
  16. _ = lxlog.InitLog()
  17. err := lxzap.InitLogger(zapConfig)
  18. if err != nil {
  19. panic(err.Error())
  20. }
  21. app := gin.New()
  22. // 注册zap相关中间件
  23. if env == "dev" {
  24. app.Use(gin.Logger(), gin.Recovery())
  25. } else {
  26. app.Use(lxzap.GinLogger(), lxzap.GinRecovery(true))
  27. }
  28. fun()
  29. r(app)
  30. srv := http.Server{
  31. Addr: ":" + port,
  32. Handler: app,
  33. }
  34. // make sure idle connections returned
  35. processed := make(chan struct{})
  36. go func() {
  37. c := make(chan os.Signal, 1)
  38. signal.Notify(c, os.Interrupt, syscall.SIGTERM)
  39. <-c
  40. fmt.Println("ctrl + c")
  41. ctx, cancel := context.WithTimeout(context.Background(), 60*time.Second)
  42. defer cancel()
  43. if err := srv.Shutdown(ctx); nil != err {
  44. log.Fatalf("server shutdown failed, err: %v\n", err)
  45. }
  46. log.Println("server gracefully shutdown")
  47. processed <- struct{}{}
  48. }()
  49. // serve
  50. err = srv.ListenAndServe()
  51. if http.ErrServerClosed != err {
  52. log.Fatalf("server not gracefully shutdown, err :%v\n", err)
  53. }
  54. // waiting for goroutine above processed
  55. <-processed
  56. }