From 4a45abe3e07e79d79978660dbb3d5bcc496c4fb2 Mon Sep 17 00:00:00 2001 From: Roman Khimov Date: Fri, 7 May 2021 12:22:29 +0300 Subject: [PATCH] stateroot: make vote/root extensibles live less These are arbitrary numbers, but that's what C# node uses. maxRetries could be set lower because we have exponential backoff anyway, but this works too. --- pkg/services/stateroot/network.go | 4 +++- pkg/services/stateroot/service.go | 2 +- pkg/services/stateroot/validators.go | 7 +++++-- 3 files changed, 9 insertions(+), 4 deletions(-) diff --git a/pkg/services/stateroot/network.go b/pkg/services/stateroot/network.go index 58d065581..dba8cb216 100644 --- a/pkg/services/stateroot/network.go +++ b/pkg/services/stateroot/network.go @@ -14,6 +14,8 @@ import ( "go.uber.org/zap" ) +const rootValidEndInc = 100 + // RelayCallback represents callback for sending validated state roots. type RelayCallback = func(*payload.Extensible) @@ -91,7 +93,7 @@ func (s *service) sendValidatedRoot(r *state.MPTRoot, acc *wallet.Account) { ep := &payload.Extensible{ Category: Category, ValidBlockStart: r.Index, - ValidBlockEnd: r.Index + transaction.MaxValidUntilBlockIncrement, + ValidBlockEnd: r.Index + rootValidEndInc, Sender: priv.GetScriptHash(), Data: w.Bytes(), Witness: transaction.Witness{ diff --git a/pkg/services/stateroot/service.go b/pkg/services/stateroot/service.go index 90b4a64ab..e569f16b1 100644 --- a/pkg/services/stateroot/service.go +++ b/pkg/services/stateroot/service.go @@ -71,7 +71,7 @@ func New(cfg config.StateRoot, log *zap.Logger, bc blockchainer.Blockchainer, cb blockCh: make(chan *block.Block), done: make(chan struct{}), timePerBlock: time.Duration(bcConf.SecondsPerBlock) * time.Second, - maxRetries: bcConf.ValidatorsCount + 1, + maxRetries: voteValidEndInc, relayExtensible: cb, } diff --git a/pkg/services/stateroot/validators.go b/pkg/services/stateroot/validators.go index 8fd8fead7..821e618c3 100644 --- a/pkg/services/stateroot/validators.go +++ b/pkg/services/stateroot/validators.go @@ -12,7 +12,10 @@ import ( "go.uber.org/zap" ) -const firstVoteResendDelay = 3 * time.Second +const ( + voteValidEndInc = 10 + firstVoteResendDelay = 3 * time.Second +) // Run runs service instance in a separate goroutine. func (s *service) Run() { @@ -85,7 +88,7 @@ func (s *service) signAndSend(r *state.MPTRoot) error { e := &payload.Extensible{ Category: Category, ValidBlockStart: r.Index, - ValidBlockEnd: r.Index + transaction.MaxValidUntilBlockIncrement, + ValidBlockEnd: r.Index + voteValidEndInc, Sender: acc.PrivateKey().GetScriptHash(), Data: w.Bytes(), Witness: transaction.Witness{