package cmd import ( "github.com/gin-gonic/gin" "github.com/spf13/cobra" "github.com/zh-five/xdaemon" "goflylivechat/middleware" "goflylivechat/router" "goflylivechat/tools" "goflylivechat/ws" "log" "os" ) var ( port string daemon bool ) var serverCmd = &cobra.Command{ Use: "server", Short: "启动http服务", Example: "gofly server -p 8082", Run: func(cmd *cobra.Command, args []string) { run() }, } func init() { serverCmd.PersistentFlags().StringVarP(&port, "port", "p", "8081", "监听端口号") serverCmd.PersistentFlags().BoolVarP(&daemon, "daemon", "d", false, "是否为守护进程模式") } func run() { if daemon == true { logFilePath := "" if dir, err := os.Getwd(); err == nil { logFilePath = dir + "/logs/" } _, err := os.Stat(logFilePath) if os.IsNotExist(err) { if err := os.MkdirAll(logFilePath, 0777); err != nil { log.Println(err.Error()) } } d := xdaemon.NewDaemon(logFilePath + "go-fly.log") d.MaxCount = 10 d.Run() } baseServer := "0.0.0.0:" + port log.Println("start server...\r\ngo:http://" + baseServer) tools.Logger().Println("start server...\r\ngo:http://" + baseServer) engine := gin.Default() engine.LoadHTMLGlob("static/templates/*") engine.Static("/assets", "./static") engine.Static("/static", "./static") engine.Use(tools.Session("gofly")) engine.Use(middleware.CrossSite) //性能监控 //pprof.Register(engine) //记录日志 engine.Use(middleware.NewMidLogger()) router.InitViewRouter(engine) router.InitApiRouter(engine) //记录pid //os.WriteFile("gofly.sock", []byte(fmt.Sprintf("%d,%d", os.Getppid(), os.Getpid())), 0666) //限流类 tools.NewLimitQueue() //清理 ws.CleanVisitorExpire() //后端websocket go ws.WsServerBackend() engine.Run(baseServer) }