added check span!=nil && conn close
This commit is contained in:
1
kgo.go
1
kgo.go
@@ -287,6 +287,7 @@ func (k *Broker) publish(ctx context.Context, msgs []*broker.Message, opts ...br
|
|||||||
k.Unlock()
|
k.Unlock()
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
k.c.Close()
|
||||||
k.c = c
|
k.c = c
|
||||||
k.connected.Store(1)
|
k.connected.Store(1)
|
||||||
}
|
}
|
||||||
|
@@ -274,11 +274,17 @@ func (pc *consumer) consume() {
|
|||||||
} else if pc.opts.BodyOnly {
|
} else if pc.opts.BodyOnly {
|
||||||
p.msg.Body = record.Value
|
p.msg.Body = record.Value
|
||||||
} else {
|
} else {
|
||||||
sp.AddEvent("codec unmarshal start")
|
if sp != nil {
|
||||||
|
sp.AddEvent("codec unmarshal start")
|
||||||
|
}
|
||||||
err := pc.kopts.Codec.Unmarshal(record.Value, p.msg)
|
err := pc.kopts.Codec.Unmarshal(record.Value, p.msg)
|
||||||
sp.AddEvent("codec unmarshal stop")
|
if sp != nil {
|
||||||
|
sp.AddEvent("codec unmarshal stop")
|
||||||
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
sp.SetStatus(tracer.SpanStatusError, err.Error())
|
if sp != nil {
|
||||||
|
sp.SetStatus(tracer.SpanStatusError, err.Error())
|
||||||
|
}
|
||||||
pc.kopts.Meter.Counter(semconv.SubscribeMessageTotal, "endpoint", record.Topic, "topic", record.Topic, "status", "failure").Inc()
|
pc.kopts.Meter.Counter(semconv.SubscribeMessageTotal, "endpoint", record.Topic, "topic", record.Topic, "status", "failure").Inc()
|
||||||
p.err = err
|
p.err = err
|
||||||
p.msg.Body = record.Value
|
p.msg.Body = record.Value
|
||||||
@@ -308,17 +314,25 @@ func (pc *consumer) consume() {
|
|||||||
eventPool.Put(p)
|
eventPool.Put(p)
|
||||||
// pc.connected.Store(0)
|
// pc.connected.Store(0)
|
||||||
pc.kopts.Logger.Fatal(pc.kopts.Context, "[kgo] Unmarshal err not handled wtf?")
|
pc.kopts.Logger.Fatal(pc.kopts.Context, "[kgo] Unmarshal err not handled wtf?")
|
||||||
sp.Finish()
|
if sp != nil {
|
||||||
|
sp.Finish()
|
||||||
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
sp.AddEvent("handler start")
|
if sp != nil {
|
||||||
|
sp.AddEvent("handler start")
|
||||||
|
}
|
||||||
err := pc.handler(p)
|
err := pc.handler(p)
|
||||||
sp.AddEvent("handler stop")
|
if sp != nil {
|
||||||
|
sp.AddEvent("handler stop")
|
||||||
|
}
|
||||||
if err == nil {
|
if err == nil {
|
||||||
pc.kopts.Meter.Counter(semconv.SubscribeMessageTotal, "endpoint", record.Topic, "topic", record.Topic, "status", "success").Inc()
|
pc.kopts.Meter.Counter(semconv.SubscribeMessageTotal, "endpoint", record.Topic, "topic", record.Topic, "status", "success").Inc()
|
||||||
} else {
|
} else {
|
||||||
sp.SetStatus(tracer.SpanStatusError, err.Error())
|
if sp != nil {
|
||||||
|
sp.SetStatus(tracer.SpanStatusError, err.Error())
|
||||||
|
}
|
||||||
pc.kopts.Meter.Counter(semconv.SubscribeMessageTotal, "endpoint", record.Topic, "topic", record.Topic, "status", "failure").Inc()
|
pc.kopts.Meter.Counter(semconv.SubscribeMessageTotal, "endpoint", record.Topic, "topic", record.Topic, "status", "failure").Inc()
|
||||||
}
|
}
|
||||||
pc.kopts.Meter.Counter(semconv.SubscribeMessageInflight, "endpoint", record.Topic, "topic", record.Topic).Dec()
|
pc.kopts.Meter.Counter(semconv.SubscribeMessageInflight, "endpoint", record.Topic, "topic", record.Topic).Dec()
|
||||||
@@ -327,9 +341,13 @@ func (pc *consumer) consume() {
|
|||||||
} else if err != nil {
|
} else if err != nil {
|
||||||
p.err = err
|
p.err = err
|
||||||
if eh != nil {
|
if eh != nil {
|
||||||
sp.AddEvent("error handler start")
|
if sp != nil {
|
||||||
|
sp.AddEvent("error handler start")
|
||||||
|
}
|
||||||
_ = eh(p)
|
_ = eh(p)
|
||||||
sp.AddEvent("error handler stop")
|
if sp != nil {
|
||||||
|
sp.AddEvent("error handler stop")
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if pc.kopts.Logger.V(logger.ErrorLevel) {
|
if pc.kopts.Logger.V(logger.ErrorLevel) {
|
||||||
pc.kopts.Logger.Error(pc.kopts.Context, "[kgo]: subscriber error", err)
|
pc.kopts.Logger.Error(pc.kopts.Context, "[kgo]: subscriber error", err)
|
||||||
@@ -346,11 +364,15 @@ func (pc *consumer) consume() {
|
|||||||
eventPool.Put(p)
|
eventPool.Put(p)
|
||||||
// pc.connected.Store(0)
|
// pc.connected.Store(0)
|
||||||
pc.kopts.Logger.Fatal(pc.kopts.Context, "[kgo] ErrLostMessage wtf?")
|
pc.kopts.Logger.Fatal(pc.kopts.Context, "[kgo] ErrLostMessage wtf?")
|
||||||
sp.SetStatus(tracer.SpanStatusError, "ErrLostMessage")
|
if sp != nil {
|
||||||
sp.Finish()
|
sp.SetStatus(tracer.SpanStatusError, "ErrLostMessage")
|
||||||
|
sp.Finish()
|
||||||
|
}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
sp.Finish()
|
if sp != nil {
|
||||||
|
sp.Finish()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user