mirror of
https://github.com/duanhf2012/origin.git
synced 2026-02-10 20:44:41 +08:00
优化异步接口
This commit is contained in:
@@ -14,6 +14,12 @@ import (
|
||||
_ "github.com/go-sql-driver/mysql"
|
||||
)
|
||||
|
||||
type SyncFun func()
|
||||
|
||||
const (
|
||||
MAX_EXECUTE_FUN = 10000
|
||||
)
|
||||
|
||||
// DBModule ...
|
||||
type DBModule struct {
|
||||
service.BaseModule
|
||||
@@ -22,6 +28,9 @@ type DBModule struct {
|
||||
UserName string
|
||||
Password string
|
||||
DBName string
|
||||
|
||||
syncExecuteFun chan SyncFun
|
||||
syncCoroutineNum int
|
||||
}
|
||||
|
||||
// DBResult ...
|
||||
@@ -37,7 +46,8 @@ type DBResult struct {
|
||||
|
||||
//OnInit ...
|
||||
func (slf *DBModule) OnInit() error {
|
||||
return slf.Connect(100)
|
||||
slf.syncExecuteFun = make(chan SyncFun, MAX_EXECUTE_FUN)
|
||||
return slf.Connect(10)
|
||||
}
|
||||
|
||||
// Next ...
|
||||
@@ -238,6 +248,10 @@ func (slf *DBModule) Connect(maxConn int) error {
|
||||
db.SetMaxIdleConns(maxConn)
|
||||
db.SetConnMaxLifetime(time.Second * 90)
|
||||
|
||||
slf.syncCoroutineNum = maxConn
|
||||
for i := 0; i < slf.syncCoroutineNum; i++ {
|
||||
go slf.RunExecuteDBCoroutine()
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
@@ -274,10 +288,20 @@ func (slf *DBModule) SyncQuery(query string, args ...interface{}) SyncDBResult {
|
||||
ret := SyncDBResult{
|
||||
sres: make(chan DBResult, 1),
|
||||
}
|
||||
go func() {
|
||||
|
||||
if len(slf.syncExecuteFun) >= MAX_EXECUTE_FUN {
|
||||
dbret := DBResult{}
|
||||
dbret.Err = fmt.Errorf("chan is full,sql:%s", query)
|
||||
ret.sres <- dbret
|
||||
|
||||
return ret
|
||||
}
|
||||
|
||||
slf.syncExecuteFun <- func() {
|
||||
rsp := slf.Query(query, args...)
|
||||
ret.sres <- rsp
|
||||
}()
|
||||
}
|
||||
|
||||
return ret
|
||||
}
|
||||
|
||||
@@ -301,9 +325,36 @@ func (slf *DBModule) SyncExec(query string, args ...interface{}) SyncDBResult {
|
||||
ret := SyncDBResult{
|
||||
sres: make(chan DBResult, 1),
|
||||
}
|
||||
go func() {
|
||||
|
||||
if len(slf.syncExecuteFun) >= MAX_EXECUTE_FUN {
|
||||
dbret := DBResult{}
|
||||
dbret.Err = fmt.Errorf("chan is full,sql:%s", query)
|
||||
ret.sres <- dbret
|
||||
|
||||
return ret
|
||||
}
|
||||
|
||||
slf.syncExecuteFun <- func() {
|
||||
rsp := slf.Exec(query, args...)
|
||||
ret.sres <- rsp
|
||||
}()
|
||||
}
|
||||
|
||||
return ret
|
||||
}
|
||||
|
||||
func (slf *DBModule) RunExecuteDBCoroutine() {
|
||||
slf.WaitGroup.Add(1)
|
||||
defer slf.WaitGroup.Done()
|
||||
for {
|
||||
select {
|
||||
case <-slf.ExitChan:
|
||||
service.GetLogger().Printf(LEVER_WARN, "stopping module %s...", fmt.Sprintf("%T", slf))
|
||||
fmt.Println("stopping module %s...", fmt.Sprintf("%T", slf))
|
||||
return
|
||||
case fun := <-slf.syncExecuteFun:
|
||||
fun()
|
||||
default:
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user