mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
etcdserver: check IsMemberExist before IsLearner
If member does not exist in cluster, IsLearner will panic.
This commit is contained in:
parent
d0c1b3fa38
commit
c438f6db27
@ -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
|
||||
}
|
||||
|
||||
|
@ -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)
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user