init
This commit is contained in:
56
cmd/serve/serve.go
Normal file
56
cmd/serve/serve.go
Normal file
@ -0,0 +1,56 @@
|
||||
package serve
|
||||
|
||||
import (
|
||||
"ArmedPolice/app"
|
||||
"ArmedPolice/config"
|
||||
"ArmedPolice/lib"
|
||||
"ArmedPolice/router"
|
||||
"ArmedPolice/serve/cache"
|
||||
"ArmedPolice/serve/logger"
|
||||
"ArmedPolice/serve/orm"
|
||||
"ArmedPolice/serve/web"
|
||||
"ArmedPolice/task"
|
||||
"ArmedPolice/tools"
|
||||
"strings"
|
||||
|
||||
"github.com/gin-gonic/gin"
|
||||
)
|
||||
|
||||
type Serve struct {
|
||||
*Option
|
||||
}
|
||||
|
||||
type Option struct {
|
||||
Config string `json:"config"`
|
||||
RpcConfig string `json:"rpc_config"`
|
||||
}
|
||||
|
||||
func (this *Serve) Run() {
|
||||
// 载入配置
|
||||
lib.LoadConfig(this.Option.Config, config.SettingInfo, func(i interface{}) {
|
||||
obj := i.(*config.Setting)
|
||||
obj.Upload.Exts = strings.Split(obj.Upload.Ext, ",")
|
||||
logger.NewLogger().Init(&logger.Option{File: obj.Log.File, LeastDay: obj.Log.LeastDay, Level: obj.Log.Level, IsStdout: false}).Load()
|
||||
})
|
||||
cache.Init()
|
||||
orm.Init()
|
||||
task.Init()
|
||||
app.Init()
|
||||
tools.Init()
|
||||
// 开启web
|
||||
web.NewWeb()(&web.WebConfig{
|
||||
Port: config.SettingInfo.Server.Port, ReadTimeout: config.SettingInfo.Server.ReadTimeout,
|
||||
WriteTimeout: config.SettingInfo.Server.WriteTimeout, IdleTimeout: config.SettingInfo.Server.IdleTimeout,
|
||||
}).Run(router.NewRouter(&router.Option{
|
||||
Mode: gin.DebugMode, IsCors: true,
|
||||
RateLimitConfig: &router.RateLimitConfig{
|
||||
IsRate: true, Limit: config.SettingInfo.Rate.Limit, Capacity: config.SettingInfo.Rate.Capacity,
|
||||
},
|
||||
}).Init())
|
||||
}
|
||||
|
||||
func NewServe() func(option *Option) *Serve {
|
||||
return func(option *Option) *Serve {
|
||||
return &Serve{option}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user