package api import ( "context" "ferry/database" "ferry/global/orm" "ferry/pkg/logger" "ferry/pkg/task" "ferry/router" "ferry/tools" config2 "ferry/tools/config" "fmt" "io/ioutil" "log" "net/http" "os" "os/signal" "time" "github.com/gin-gonic/gin" "github.com/spf13/cobra" "github.com/spf13/viper" ) var ( config string port string mode string StartCmd = &cobra.Command{ Use: "server", Short: "Start API server", Example: "ferry server config/settings.yml", PreRun: func(cmd *cobra.Command, args []string) { usage() setup() }, RunE: func(cmd *cobra.Command, args []string) error { return run() }, } ) func init() { StartCmd.PersistentFlags().StringVarP(&config, "config", "c", "config/settings.yml", "Start server with provided configuration file") StartCmd.PersistentFlags().StringVarP(&port, "port", "p", "8002", "Tcp port server listening on") StartCmd.PersistentFlags().StringVarP(&mode, "mode", "m", "dev", "server mode ; eg:dev,test,prod") } func usage() { usageStr := `starting api server` log.Printf("%s\n", usageStr) } func setup() { // 1. 读取配置 config2.ConfigSetup(config) // 2. 初始化数据库链接 database.Setup() // 3. 启动异步任务队列 go task.Start() } func run() error { if mode != "" { config2.SetConfig(config, "settings.application.mode", mode) } if viper.GetString("settings.application.mode") == string(tools.ModeProd) { gin.SetMode(gin.ReleaseMode) } r := router.InitRouter() defer func() { err := orm.Eloquent.Close() if err != nil { logger.Error(err) } }() if port != "" { config2.SetConfig(config, "settings.application.port", port) } srv := &http.Server{ Addr: config2.ApplicationConfig.Host + ":" + config2.ApplicationConfig.Port, Handler: r, } go func() { // 服务连接 if config2.ApplicationConfig.IsHttps { if err := srv.ListenAndServeTLS(config2.SslConfig.Pem, config2.SslConfig.KeyStr); err != nil && err != http.ErrServerClosed { logger.Fatalf("listen: %s\n", err) } } else { if err := srv.ListenAndServe(); err != nil && err != http.ErrServerClosed { logger.Fatalf("listen: %s\n", err) } } }() content, _ := ioutil.ReadFile("./static/ferry.txt") fmt.Println(string(content)) fmt.Printf("%s Server Run http://127.0.0.1:%s/ \r\n", tools.GetCurrntTimeStr(), config2.ApplicationConfig.Port) fmt.Printf("%s Swagger URL http://127.0.0.1:%s/swagger/index.html \r\n", tools.GetCurrntTimeStr(), config2.ApplicationConfig.Port) fmt.Printf("%s Enter Control + C Shutdown Server \r\n", tools.GetCurrntTimeStr()) // 等待中断信号以优雅地关闭服务器(设置 5 秒的超时时间) quit := make(chan os.Signal) signal.Notify(quit, os.Interrupt) <-quit fmt.Printf("%s Shutdown Server ... \r\n", tools.GetCurrntTimeStr()) ctx, cancel := context.WithTimeout(context.Background(), 5*time.Second) defer cancel() if err := srv.Shutdown(ctx); err != nil { logger.Fatal("Server Shutdown:", err) } logger.Info("Server exiting") return nil }