etcdserver: check IsMemberExist before IsLearner

If member does not exist in cluster, IsLearner will panic.
This commit is contained in:
Jingyi Hu 2019-04-25 16:31:22 -07:00
parent d0c1b3fa38
commit c438f6db27
2 changed files with 7 additions and 2 deletions

View File

@ -48,7 +48,7 @@ func newUnaryInterceptor(s *etcdserver.EtcdServer) grpc.UnaryServerInterceptor {
return nil, rpctypes.ErrGRPCNotCapable
}
if s.IsLearner() && !isRPCSupportedForLearner(req) {
if s.IsMemberExist(s.ID()) && s.IsLearner() && !isRPCSupportedForLearner(req) {
return nil, rpctypes.ErrGPRCNotSupportedForLearner
}
@ -194,7 +194,7 @@ func newStreamInterceptor(s *etcdserver.EtcdServer) grpc.StreamServerInterceptor
return rpctypes.ErrGRPCNotCapable
}
if s.IsLearner() { // learner does not support Watch and LeaseKeepAlive RPC
if s.IsMemberExist(s.ID()) && s.IsLearner() { // learner does not support stream RPC
return rpctypes.ErrGPRCNotSupportedForLearner
}

View File

@ -2518,3 +2518,8 @@ func (s *EtcdServer) Logger() *zap.Logger {
func (s *EtcdServer) IsLearner() bool {
return s.cluster.IsLocalMemberLearner()
}
// IsMemberExist returns if the member with the given id exists in cluster.
func (s *EtcdServer) IsMemberExist(id types.ID) bool {
return s.cluster.IsMemberExist(id)
}