blob: a55572a28c13aea8def3cc2957117396aeaf6761 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package event
import (
"fmt"
"github.com/apache/servicecomb-service-center/pkg/log"
)
const (
CheckerGroup = "__HealthChecker__"
CheckerSubject = "__NotifyServerHealthCheck__"
)
// SubscriberHealthChecker check subscriber health and remove it from bus if return Err
type SubscriberHealthChecker struct {
Subscriber
}
type UnhealthyEvent struct {
Event
ErrorSubscriber Subscriber
}
func (s *SubscriberHealthChecker) OnMessage(evt Event) {
j := evt.(*UnhealthyEvent)
err := j.ErrorSubscriber.Err()
if j.ErrorSubscriber.Type() == INNER {
log.Error(fmt.Sprintf("remove %s watcher failed, here cause a dead lock, subject: %s, group: %s",
j.ErrorSubscriber.Type(), j.ErrorSubscriber.Subject(), j.ErrorSubscriber.Group()), nil)
return
}
log.Debug(fmt.Sprintf("notification service remove %s watcher, error: %v, subject: %s, group: %s",
j.ErrorSubscriber.Type(), err, j.ErrorSubscriber.Subject(), j.ErrorSubscriber.Group()))
s.Bus().RemoveSubscriber(j.ErrorSubscriber)
}
func NewSubscriberHealthChecker() *SubscriberHealthChecker {
return &SubscriberHealthChecker{
Subscriber: NewSubscriber(INNER, CheckerSubject, CheckerGroup),
}
}
func NewUnhealthyEvent(s Subscriber) *UnhealthyEvent {
return &UnhealthyEvent{
Event: NewEvent(INNER, CheckerSubject, CheckerGroup),
ErrorSubscriber: s,
}
}