forked from yuxh/gearman-go
fixed a infinite loop
This commit is contained in:
parent
0d6d1e114f
commit
842edf79ba
@ -23,6 +23,7 @@ var (
|
||||
ErrNotConn = errors.New("Did not connect to job server.")
|
||||
ErrFuncNotFound = errors.New("The function was not found.")
|
||||
ErrEmptyReading = errors.New("Empty reading.")
|
||||
ErrNoActiveAgent = errors.New("No active agent.")
|
||||
)
|
||||
func DisablePanic() {recover()}
|
||||
|
||||
|
@ -19,6 +19,7 @@ func main() {
|
||||
log.Println("Starting ...")
|
||||
defer log.Println("Shutdown complete!")
|
||||
w := worker.New(worker.Unlimited)
|
||||
defer w.Close()
|
||||
w.ErrHandler = func(e error) {
|
||||
log.Println(e)
|
||||
}
|
||||
|
@ -48,7 +48,7 @@ func (a *agent) outLoop() {
|
||||
// inputing loop
|
||||
func (a *agent) inLoop() {
|
||||
defer func() {
|
||||
a.conn.Close()
|
||||
recover()
|
||||
close(a.in)
|
||||
close(a.out)
|
||||
a.worker.removeAgent(a)
|
||||
@ -85,6 +85,10 @@ func (a *agent) inLoop() {
|
||||
}
|
||||
}
|
||||
|
||||
func (a *agent) Close() {
|
||||
a.conn.Close()
|
||||
}
|
||||
|
||||
func (a *agent) Work() {
|
||||
go a.outLoop()
|
||||
go a.inLoop()
|
||||
|
@ -159,6 +159,9 @@ func (worker *Worker) removeFunc(funcname string) {
|
||||
func (worker *Worker) Work() {
|
||||
defer func() {
|
||||
worker.running = false
|
||||
for _, v := range worker.agents {
|
||||
v.Close()
|
||||
}
|
||||
}()
|
||||
for funcname, f := range worker.funcs {
|
||||
worker.addFunc(funcname, f.timeout)
|
||||
@ -168,8 +171,9 @@ func (worker *Worker) Work() {
|
||||
go v.Work()
|
||||
}
|
||||
ok := true
|
||||
var job *Job
|
||||
for ok {
|
||||
if job, ok := <-worker.in; ok {
|
||||
if job, ok = <-worker.in; ok {
|
||||
switch job.DataType {
|
||||
case common.ERROR:
|
||||
go func() {
|
||||
@ -280,6 +284,6 @@ func (worker *Worker) removeAgent(a *agent) {
|
||||
}
|
||||
}
|
||||
if len(worker.agents) == 0 {
|
||||
worker.Close()
|
||||
worker.err(common.ErrNoActiveAgent)
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user