1 Star 0 Fork 1

sagmain / distill-infra

forked from distill / distill-infra 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
starer.go 4.01 KB
一键复制 编辑 原始数据 按行查看 历史
Lyndon Hu 提交于 2020-05-03 09:53 . infra toml
package infra
import (
conf "gitee.com/banyanhouse/distill-infra/config"
log "github.com/sirupsen/logrus"
"reflect"
"sort"
)
const (
KeyProps = "_conf"
)
// 资源启动器上下文,
// 用来在服务资源初始化、安装、启动和停止的生命周期中变量和对象的传递
type StarterContext map[string]interface{}
func (s StarterContext) Props() *conf.TomlConfig {
p := s[KeyProps]
if p == nil {
panic("配置还没有被初始化")
}
return p.(*conf.TomlConfig)
}
func (s StarterContext) SetProps(conf *conf.TomlConfig) {
s[KeyProps] = conf
}
//资源启动器,每个应用少不了依赖其他资源,比如数据库,缓存,消息中间件等等服务
//启动器实现类,不需要实现所有方法,只需要实现对应的阶段方法即可,可以嵌入@BaseStarter
//通过实现资源启动器接口和资源启动注册器,友好的管理这些资源的初始化、安装、启动和停止。
//Starter对象注册器,所有需要在系统启动时需要实例化和运行的逻辑,都可以实现此接口
//注意只有Start方法才能被阻塞,如果是阻塞Start(),同时StartBlocking()要返回true
type Starter interface {
//资源初始化和,通常把一些准备资源放在这里运行
Init(StarterContext)
//资源的安装,所有启动需要的具备条件,使得资源达到可以启动的就备状态
Setup(StarterContext)
//启动资源,达到可以使用的状态
Start(StarterContext)
//说明该资源启动器开始启动服务时,是否会阻塞
//如果存在多个阻塞启动器时,只有最后一个阻塞,之前的会通过goroutine来异步启动
//所以,需要规划好启动器注册顺序
StartBlocking() bool
//资源停止:
// 通常在启动时遇到异常时或者启用远程管理时,用于释放资源和终止资源的使用,
// 通常要优雅的释放,等待正在进行的任务继续,但不再接受新的任务
Stop(StarterContext)
PriorityGroup() PriorityGroup
Priority() int
}
//服务启动注册器
//不用需外部构造,全局只有一个
type starterRegister struct {
nonBlockingStarters []Starter
blockingStarters []Starter
}
//返回所有的启动器
func (r *starterRegister) AllStarters() []Starter {
starters := make([]Starter, 0)
starters = append(starters, r.nonBlockingStarters...)
starters = append(starters, r.blockingStarters...)
return starters
}
//注册启动器
func (r *starterRegister) Register(starter Starter) {
if starter.StartBlocking() {
r.blockingStarters = append(r.blockingStarters, starter)
} else {
r.nonBlockingStarters = append(r.nonBlockingStarters, starter)
}
typ := reflect.TypeOf(starter)
log.Infof("Register starter: %s", typ.String())
}
var StarterRegister *starterRegister = &starterRegister{}
type Starters []Starter
func (s Starters) Len() int { return len(s) }
func (s Starters) Swap(i, j int) { s[i], s[j] = s[j], s[i] }
func (s Starters) Less(i, j int) bool {
return s[i].PriorityGroup() > s[j].PriorityGroup() && s[i].Priority() > s[j].Priority()
}
//注册starter
func Register(starter Starter) {
StarterRegister.Register(starter)
}
func SortStarters() {
sort.Sort(Starters(StarterRegister.AllStarters()))
}
//获取所有注册的starter
func GetStarters() []Starter {
return StarterRegister.AllStarters()
}
type PriorityGroup int
const (
SystemGroup PriorityGroup = 30
BasicResourcesGroup PriorityGroup = 20
AppGroup PriorityGroup = 10
INT_MAX = int(^uint(0) >> 1)
DEFAULT_PRIORITY = 10000
)
//默认的空实现,方便资源启动器的实现
type BaseStarter struct {
}
func (s *BaseStarter) Init(ctx StarterContext) {}
func (s *BaseStarter) Setup(ctx StarterContext) {}
func (s *BaseStarter) Start(ctx StarterContext) {}
func (s *BaseStarter) Stop(ctx StarterContext) {}
func (s *BaseStarter) StartBlocking() bool { return false }
func (s *BaseStarter) PriorityGroup() PriorityGroup { return BasicResourcesGroup }
func (s *BaseStarter) Priority() int { return DEFAULT_PRIORITY }
Go
1
https://gitee.com/sagmain/distill-infra.git
git@gitee.com:sagmain/distill-infra.git
sagmain
distill-infra
distill-infra
master

搜索帮助