[#872] services/container: Ignore passed routes in load router
Higher level solution for original issue with lost announcements from single node container. Signed-off-by: Alex Vanin <alexey@nspcc.ru>
This commit is contained in:
parent
f08636c518
commit
e41e74b5fc
2 changed files with 26 additions and 2 deletions
|
@ -228,6 +228,16 @@ func (*morphLoadWriter) Close() error {
|
|||
return nil
|
||||
}
|
||||
|
||||
type nopLoadWriter struct{}
|
||||
|
||||
func (nopLoadWriter) Put(containerSDK.UsedSpaceAnnouncement) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
func (nopLoadWriter) Close() error {
|
||||
return nil
|
||||
}
|
||||
|
||||
type remoteLoadAnnounceProvider struct {
|
||||
key *ecdsa.PrivateKey
|
||||
|
||||
|
@ -241,10 +251,15 @@ type remoteLoadAnnounceProvider struct {
|
|||
}
|
||||
|
||||
func (r *remoteLoadAnnounceProvider) InitRemote(srv loadroute.ServerInfo) (loadcontroller.WriterProvider, error) {
|
||||
if srv == nil || r.netmapKeys.IsLocalKey(srv.PublicKey()) {
|
||||
if srv == nil {
|
||||
return r.deadEndProvider, nil
|
||||
}
|
||||
|
||||
if r.netmapKeys.IsLocalKey(srv.PublicKey()) {
|
||||
// if local => return no-op writer
|
||||
return loadcontroller.SimpleWriterProvider(new(nopLoadWriter)), nil
|
||||
}
|
||||
|
||||
var info client.NodeInfo
|
||||
|
||||
err := client.NodeInfoFromRawNetmapElement(&info, srv)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue