初始化项目
This commit is contained in:
83
trunk/framework/notify-util/mgr.go
Normal file
83
trunk/framework/notify-util/mgr.go
Normal file
@@ -0,0 +1,83 @@
|
||||
package notify_util
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
|
||||
"goutil/syncUtil"
|
||||
)
|
||||
|
||||
var (
|
||||
// key:初始化成功的标志名称 val:占位符
|
||||
registerNC = make(map[string]*notifyCenter)
|
||||
mutex = syncUtil.NewRWLocker()
|
||||
)
|
||||
|
||||
// getItemOrAdd
|
||||
// @description: 获取注册的通知对象
|
||||
// parameter:
|
||||
// @chanGroup:
|
||||
// return:
|
||||
// @*notifyCenter:
|
||||
func getItemOrAdd(chanGroup string) *notifyCenter {
|
||||
if isOk, prevStack, currStack := mutex.Lock(deathLockTime); isOk == false {
|
||||
//记日志
|
||||
errMsg := fmt.Sprintf("Lock timeout! \n上一个堆栈:\n%s \n当前堆栈:\n%s", prevStack, currStack)
|
||||
panic(errMsg)
|
||||
}
|
||||
defer mutex.Unlock()
|
||||
|
||||
nc, exists := registerNC[chanGroup]
|
||||
if exists {
|
||||
return nc
|
||||
}
|
||||
|
||||
nc = newNotifyCenter()
|
||||
registerNC[chanGroup] = nc
|
||||
|
||||
return nc
|
||||
}
|
||||
|
||||
// Register
|
||||
// @description: 注册需要被通知的对象
|
||||
// parameter:
|
||||
// @chanGroup:通知的分组标识
|
||||
// @chanName:唯一标识
|
||||
// @cf:回调方法
|
||||
// return:
|
||||
func Register(chanGroup string, chanName string, cf func()) {
|
||||
nc := getItemOrAdd(chanGroup)
|
||||
nc.register(chanName, cf)
|
||||
}
|
||||
|
||||
// Unregister
|
||||
// @description: 取消启动成功通知注册
|
||||
// parameter:
|
||||
// @chanGroup:分组标识
|
||||
// @name:唯一标识
|
||||
// return:
|
||||
func Unregister(chanGroup string, name string) {
|
||||
nc := getItemOrAdd(chanGroup)
|
||||
nc.unregister(name)
|
||||
}
|
||||
|
||||
// Notify
|
||||
// @description: 通知分组所有已注册的对象
|
||||
// parameter:
|
||||
// @chanGroup:分组标识
|
||||
// return:
|
||||
func Notify(chanGroup string) {
|
||||
nc := getItemOrAdd(chanGroup)
|
||||
nc.notify()
|
||||
}
|
||||
|
||||
// Notify2
|
||||
// @description: 通知所有已注册的对象,该方法会在捕获第一个err的时候停止后续的通知。多用于系统启动的判定
|
||||
// parameter:
|
||||
// @chanGroup:分组标识
|
||||
// return:
|
||||
// @err:
|
||||
func Notify2(chanGroup string) (err error) {
|
||||
nc := getItemOrAdd(chanGroup)
|
||||
err = nc.notify2()
|
||||
return
|
||||
}
|
||||
130
trunk/framework/notify-util/notity.go
Normal file
130
trunk/framework/notify-util/notity.go
Normal file
@@ -0,0 +1,130 @@
|
||||
package notify_util
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
|
||||
"Framework/goroutineMgr"
|
||||
"goutil/logUtil"
|
||||
"goutil/syncUtil"
|
||||
)
|
||||
|
||||
const (
|
||||
deathLockTime = 0
|
||||
)
|
||||
|
||||
// notifyCenter
|
||||
// @description: 玩家信息务逻辑类
|
||||
type notifyCenter struct {
|
||||
// key:初始化成功的标志名称 val:占位符
|
||||
registerMap map[string]func()
|
||||
mutex *syncUtil.RWLocker
|
||||
}
|
||||
|
||||
// newNotifyCenter
|
||||
// @description: 构造对象
|
||||
// parameter:
|
||||
// return:
|
||||
// @*notifyCenter:
|
||||
func newNotifyCenter() *notifyCenter {
|
||||
return ¬ifyCenter{
|
||||
registerMap: make(map[string]func()),
|
||||
mutex: syncUtil.NewRWLocker(),
|
||||
}
|
||||
}
|
||||
|
||||
// register
|
||||
// @description: 注册需要被通知的对象
|
||||
// parameter:
|
||||
// @receiver nc:
|
||||
// @chanName:唯一标识
|
||||
// @cf:回调方法
|
||||
// return:
|
||||
func (nc *notifyCenter) register(chanName string, cf func()) {
|
||||
if isOk, prevStack, currStack := nc.mutex.Lock(deathLockTime); isOk == false {
|
||||
//记日志
|
||||
errMsg := fmt.Sprintf("Lock timeout! \n上一个堆栈:\n%s \n当前堆栈:\n%s", prevStack, currStack)
|
||||
panic(errMsg)
|
||||
}
|
||||
defer nc.mutex.Unlock()
|
||||
if _, exists := nc.registerMap[chanName]; exists {
|
||||
panic(fmt.Errorf("registerMap.Register-%s已经存在,请检查", chanName))
|
||||
}
|
||||
|
||||
nc.registerMap[chanName] = cf
|
||||
}
|
||||
|
||||
// @description: 取消启动成功通知注册
|
||||
// parameter:
|
||||
// @receiver nc:
|
||||
// @name:唯一标识
|
||||
// return:
|
||||
func (nc *notifyCenter) unregister(name string) {
|
||||
if isOk, prevStack, currStack := nc.mutex.Lock(deathLockTime); isOk == false {
|
||||
//记日志
|
||||
errMsg := fmt.Sprintf("Lock timeout! \n上一个堆栈:\n%s \n当前堆栈:\n%s", prevStack, currStack)
|
||||
panic(errMsg)
|
||||
}
|
||||
defer nc.mutex.Unlock()
|
||||
|
||||
delete(nc.registerMap, name)
|
||||
}
|
||||
|
||||
// notify
|
||||
// @description: 通知所有已注册的对象
|
||||
// parameter:
|
||||
// @receiver nc:
|
||||
// return:
|
||||
func (nc *notifyCenter) notify() {
|
||||
// 处理goroutine数量
|
||||
goroutineName := "notifyCenter.Notify"
|
||||
goroutineMgr.MonitorZero(goroutineName)
|
||||
defer goroutineMgr.ReleaseMonitor(goroutineName)
|
||||
|
||||
if isOk, prevStack, currStack := nc.mutex.RLock(deathLockTime); isOk == false {
|
||||
//记日志
|
||||
errMsg := fmt.Sprintf("Lock timeout! \n上一个堆栈:\n%s \n当前堆栈:\n%s", prevStack, currStack)
|
||||
panic(errMsg)
|
||||
}
|
||||
defer nc.mutex.RUnlock()
|
||||
|
||||
for name, cf := range nc.registerMap {
|
||||
cf()
|
||||
msg := fmt.Sprintf("通知:%s初始化成功", name)
|
||||
logUtil.DebugLog(msg)
|
||||
}
|
||||
}
|
||||
|
||||
// notify2
|
||||
// @description: 通知所有已注册的对象,该方法会在捕获第一个err的时候停止后续的通知。多用于系统启动的判定
|
||||
// parameter:
|
||||
// @receiver nc:
|
||||
// return:
|
||||
// @error:
|
||||
func (nc *notifyCenter) notify2() (err error) {
|
||||
// 处理goroutine数量
|
||||
goroutineName := "notifyCenter.Notify"
|
||||
goroutineMgr.MonitorZero(goroutineName)
|
||||
defer goroutineMgr.ReleaseMonitor(goroutineName)
|
||||
|
||||
defer func() {
|
||||
if r := recover(); r != nil {
|
||||
err = fmt.Errorf("notify2 err:%s", r)
|
||||
logUtil.ErrorLog(err.Error())
|
||||
}
|
||||
}()
|
||||
|
||||
if isOk, prevStack, currStack := nc.mutex.RLock(deathLockTime); isOk == false {
|
||||
//记日志
|
||||
errMsg := fmt.Sprintf("Lock timeout! \n上一个堆栈:\n%s \n当前堆栈:\n%s", prevStack, currStack)
|
||||
panic(errMsg)
|
||||
}
|
||||
defer nc.mutex.RUnlock()
|
||||
|
||||
for name, cf := range nc.registerMap {
|
||||
cf()
|
||||
msg := fmt.Sprintf("通知:%s初始化成功", name)
|
||||
logUtil.DebugLog(msg)
|
||||
}
|
||||
|
||||
return
|
||||
}
|
||||
Reference in New Issue
Block a user