1 Star 2 Fork 3

kristas/booting-go

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
web_container_starter.go 2.06 KB
一键复制 编辑 原始数据 按行查看 历史
kristas 提交于 2021-12-20 14:52 +08:00 . feat: rebuild bean lifecycle
package starter
import (
"gitee.com/kristas/booting-go/framework"
"gitee.com/kristas/booting-go/framework/core/bean"
"gitee.com/kristas/booting-go/framework/core/log"
"gitee.com/kristas/booting-go/framework/core/statement/types"
"gitee.com/kristas/booting-go/framework/web"
"gitee.com/kristas/booting-go/framework/web/web_filter"
"reflect"
"strings"
"sync"
)
func init() {
framework.Component(new(serverRunner))
}
type serverRunner struct {
types.ApplicationRunner `order:"999"`
Container web.Server `wire:""`
Log log.Logger `wire:""`
Port int `value:"server.port"`
}
func (s *serverRunner) Run() error {
var once sync.Once
web_filter.InitFilters(func(order int, filter web.Filter) {
once.Do(func() {
s.Log.Debug("using filters:")
})
s.Log.Debug("└%s %s [%s] [%3d]", strings.Repeat("-", order), reflect.TypeOf(filter).Elem().String(), strings.Join(filter.UrlPatterns(), ", "), filter.Order())
})
s.Log.Info("container detected: %s", bean.GetBeanName(s.Container))
go func() {
s.Log.Info("server listen at %d", s.Port)
err := s.Container.ListenAndServe(s.Port)
if err != nil {
s.Log.Fatal(err.Error())
}
}()
return nil
}
type ServerProcessor struct {
Log log.Logger `wire:""`
Port int `value:"server.port"`
}
func (s *ServerProcessor) Order() int {
return 257
}
func (s *ServerProcessor) Async() bool {
return true
}
func (s *ServerProcessor) Filter(bean bean.Bean) bool {
_, ok := bean.(web.Server)
return ok
}
func (s *ServerProcessor) Do(b bean.Bean) error {
container := b.(web.Server)
var once sync.Once
web_filter.InitFilters(func(order int, filter web.Filter) {
once.Do(func() {
s.Log.Debug("using filters:")
})
s.Log.Debug("└%s %s [%s] [%3d]", strings.Repeat("-", order), reflect.TypeOf(filter).Elem().String(), strings.Join(filter.UrlPatterns(), ", "), filter.Order())
})
s.Log.Info("container detected: %s", bean.GetBeanName(container))
go func() {
err := container.ListenAndServe(s.Port)
if err != nil {
s.Log.Fatal(err.Error())
}
}()
return nil
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Go
1
https://gitee.com/kristas/booting-go.git
git@gitee.com:kristas/booting-go.git
kristas
booting-go
booting-go
v1.4.4

搜索帮助