-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.go
83 lines (74 loc) · 1.96 KB
/
main.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
package main
import (
"context"
"flag"
"fmt"
"kidshelloworld.com/bindb/bdata"
"kidshelloworld.com/bindb/middleware"
"kidshelloworld.com/bindb/route"
"github.com/gin-gonic/gin"
logger "github.com/sirupsen/logrus"
"net/http"
"os"
"os/signal"
"syscall"
"time"
)
func setGinMode(mode string) {
switch mode {
case bdata.RunModeDev:
gin.SetMode(gin.DebugMode)
case bdata.RunModeTest:
gin.SetMode(gin.TestMode)
case bdata.RunModeRelease:
gin.SetMode(gin.ReleaseMode)
}
}
func main() {
logger.SetFormatter(&logger.TextFormatter{FullTimestamp: true})
logger.SetOutput(os.Stdout)
logger.SetLevel(logger.InfoLevel)
port := flag.Int("p", 8080, "-p 8080")
mode := flag.String("m", "dev", "-m [dev|test|release]")
dataDir := flag.String("d", ".", "-d /home/testuser/bindata")
flag.Parse()
if *dataDir != "" {
go func() { bdata.WatchBinDataDir(*dataDir) }()
}
bdata.Config.DataDir = *dataDir
bdata.SetBinDatabaseMode(bdata.BinDatabaseModeMemory)
//启动http服务
logger.Info("启动http服务...")
setGinMode(*mode)
r := gin.New()
r.Use(middleware.Log())
r.Use(middleware.Recovery())
route.Register(r)
// Listen and serve on 0.0.0.0:8080
srv := &http.Server{
Addr: fmt.Sprintf(":%d", *port),
Handler: r,
ReadTimeout: 10 * time.Second,
WriteTimeout: 10 * time.Second,
MaxHeaderBytes: 1 << 20,
}
go func() {
// service connections
if err := srv.ListenAndServe(); err != nil {
logger.Infof("listen: %s", err.Error())
}
logger.Infof("启动http服务成功, port: %d", port)
}()
// Wait for interrupt signal to gracefully shutdown the server with
// a timeout of 5 seconds.
quit := make(chan os.Signal)
signal.Notify(quit, os.Interrupt, syscall.SIGTERM)
<-quit
logger.Info("Shutting down Server...")
ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second)
defer cancel()
if err := srv.Shutdown(ctx); err != nil {
logger.Fatal("Server Shutdown failure.", err)
}
logger.Info("Server exit.")
}