package cmd import ( "github.com/gin-contrib/pprof" "github.com/gin-gonic/gin" "github.com/spf13/cobra" "github.com/taoshihan1991/imaptool/controller" "github.com/taoshihan1991/imaptool/middleware" "github.com/taoshihan1991/imaptool/router" "github.com/taoshihan1991/imaptool/tools" "github.com/zh-five/xdaemon" "log" "os" ) var ( Port string daemon bool ) var serverCmd = &cobra.Command{ Use: "server", Short: "example:go-fly server -p 8081", Example: "go-fly server -c config/", 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 = 5 d.Run() //if os.Getppid() != 1 { // // 将命令行参数中执行文件路径转换成可用路径 // filePath, _ := filepath.Abs(os.Args[0]) // cmd := exec.Command(filePath, os.Args[1:]...) // // 将其他命令传入生成出的进程 // cmd.Stdin = os.Stdin // 给新进程设置文件描述符,可以重定向到文件中 // cmd.Stdout = os.Stdout // cmd.Stderr = os.Stderr // cmd.Start() // 开始执行新进程,不等待新进程退出 // os.Exit(0) //} } baseServer := "0.0.0.0:" + Port controller.Port = Port log.Println("start server...\r\ngo:http://" + baseServer) tools.Logger().Println("start server...\r\ngo:http://" + baseServer) engine := gin.Default() engine.LoadHTMLGlob("static/html/*") engine.Static("/static", "./static") engine.Use(tools.Session("gofly")) //性能监控 pprof.Register(engine) //记录日志 engine.Use(middleware.NewMidLogger()) router.InitViewRouter(engine) router.InitApiRouter(engine) //logFile, _ := os.OpenFile("./fatal.log", os.O_CREATE|os.O_APPEND|os.O_RDWR, 0660) //tools.RedirectStderr(logFile) //tcp服务 //go controller.NewTcpServer(tcpBaseServer) engine.Run(baseServer) }