Files
mayfly-go/server/pkg/starter/web-server.go

61 lines
1.4 KiB
Go
Raw Normal View History

2021-04-16 15:10:07 +08:00
package starter
import (
2023-12-27 22:59:20 +08:00
"context"
"errors"
"mayfly-go/initialize"
"mayfly-go/pkg/config"
"mayfly-go/pkg/logx"
2023-01-14 16:29:52 +08:00
"mayfly-go/pkg/req"
2023-12-27 22:59:20 +08:00
"net/http"
"time"
2024-01-09 17:31:21 +08:00
"github.com/gin-gonic/gin"
2021-04-16 15:10:07 +08:00
)
2023-12-27 22:59:20 +08:00
func runWebServer(ctx context.Context) {
// 设置gin日志输出器
logOut := logx.GetConfig().GetLogOut()
gin.DefaultErrorWriter = logOut
gin.DefaultWriter = logOut
2022-01-13 17:06:04 +08:00
// 权限处理器
2023-01-14 16:29:52 +08:00
req.UseBeforeHandlerInterceptor(req.PermissionHandler)
2022-01-13 17:06:04 +08:00
// 日志处理器
2023-01-14 16:29:52 +08:00
req.UseAfterHandlerInterceptor(req.LogHandler)
// 设置日志保存函数
2023-01-14 16:29:52 +08:00
req.SetSaveLogFunc(initialize.InitSaveLogFunc())
2023-12-27 22:59:20 +08:00
srv := http.Server{
Addr: config.Conf.Server.GetPort(),
// 注册路由
Handler: initialize.InitRouter(),
}
2022-01-13 17:06:04 +08:00
2023-12-27 22:59:20 +08:00
go func() {
<-ctx.Done()
logx.Info("Shutdown HTTP Server ...")
timeout, cancel := context.WithTimeout(context.Background(), 5*time.Second)
defer cancel()
err := srv.Shutdown(timeout)
if err != nil {
logx.Errorf("Failed to Shutdown HTTP Server: %v", err)
}
2024-01-09 17:31:21 +08:00
initialize.Terminate()
2023-12-27 22:59:20 +08:00
}()
2023-12-27 22:59:20 +08:00
confSrv := config.Conf.Server
logx.Infof("Listening and serving HTTP on %s", srv.Addr+confSrv.ContextPath)
2022-01-13 17:06:04 +08:00
var err error
2023-12-27 22:59:20 +08:00
if confSrv.Tls != nil && confSrv.Tls.Enable {
err = srv.ListenAndServeTLS(confSrv.Tls.CertFile, confSrv.Tls.KeyFile)
} else {
2023-12-27 22:59:20 +08:00
err = srv.ListenAndServe()
}
if errors.Is(err, http.ErrServerClosed) {
logx.Info("HTTP Server Shutdown")
} else if err != nil {
logx.Errorf("Failed to Start HTTP Server: %v", err)
}
2021-04-16 15:10:07 +08:00
}