Merge pull request #1400 from nspcc-dev/height-dependent-policy

core|config: make max(free)txperblock height-dependent
This commit is contained in:
Roman Khimov 2020-09-15 12:36:58 +03:00 committed by GitHub
commit 13f29805bb
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 38 additions and 21 deletions

View file

@ -32,9 +32,9 @@ ProtocolConfiguration:
RegisterTransaction: 10000 RegisterTransaction: 10000
VerifyBlocks: true VerifyBlocks: true
VerifyTransactions: false VerifyTransactions: false
FreeGasLimit: {0: 10.0, 6216000: 50.0} FreeGasLimit: {0: 10.0, 6200000: 50.0}
MaxTransactionsPerBlock: 500 MaxTransactionsPerBlock: {0: 500, 6200000: 200}
MaxFreeTransactionsPerBlock: 20 MaxFreeTransactionsPerBlock: {0: 20, 6200000: 199}
MaxFreeTransactionSize: 1024 MaxFreeTransactionSize: 1024
MinimumNetworkFee: 0 MinimumNetworkFee: 0
FeePerExtraByte: 0.00001 FeePerExtraByte: 0.00001

View file

@ -33,8 +33,8 @@ ProtocolConfiguration:
VerifyBlocks: true VerifyBlocks: true
VerifyTransactions: false VerifyTransactions: false
FreeGasLimit: {0: 10.0, 5220000: 50.0} FreeGasLimit: {0: 10.0, 5220000: 50.0}
MaxTransactionsPerBlock: 500 MaxTransactionsPerBlock: {0: 500, 5220000: 200}
MaxFreeTransactionsPerBlock: 20 MaxFreeTransactionsPerBlock: {0: 20, 5220000: 199}
MaxFreeTransactionSize: 1024 MaxFreeTransactionSize: 1024
MinimumNetworkFee: 0 MinimumNetworkFee: 0
FeePerExtraByte: 0.00001 FeePerExtraByte: 0.00001

View file

@ -28,14 +28,15 @@ type (
// FreeGasLimit is an amount of GAS which can be spent for free. // FreeGasLimit is an amount of GAS which can be spent for free.
// It can change over time, thus it's a map of block height to the // It can change over time, thus it's a map of block height to the
// respective GAS limit. // respective GAS limit.
FreeGasLimit map[uint32]util.Fixed8 `yaml:"FreeGasLimit"` FreeGasLimit map[uint32]util.Fixed8 `yaml:"FreeGasLimit"`
LowPriorityThreshold float64 `yaml:"LowPriorityThreshold"` LowPriorityThreshold float64 `yaml:"LowPriorityThreshold"`
Magic NetMode `yaml:"Magic"` Magic NetMode `yaml:"Magic"`
MaxTransactionsPerBlock int `yaml:"MaxTransactionsPerBlock"` // Maximum number of transactions allowed to be packed into block.
MaxTransactionsPerBlock map[uint32]int `yaml:"MaxTransactionsPerBlock"`
// Maximum size of low priority transaction in bytes. // Maximum size of low priority transaction in bytes.
MaxFreeTransactionSize int `yaml:"MaxFreeTransactionSize"` MaxFreeTransactionSize int `yaml:"MaxFreeTransactionSize"`
// Maximum number of low priority transactions accepted into block. // Maximum number of low priority transactions accepted into block.
MaxFreeTransactionsPerBlock int `yaml:"MaxFreeTransactionsPerBlock"` MaxFreeTransactionsPerBlock map[uint32]int `yaml:"MaxFreeTransactionsPerBlock"`
// MinimumNetworkFee sets the minimum required network fee for transaction to pass validation. // MinimumNetworkFee sets the minimum required network fee for transaction to pass validation.
MinimumNetworkFee util.Fixed8 `yaml:"MinimumNetworkFee"` MinimumNetworkFee util.Fixed8 `yaml:"MinimumNetworkFee"`
MemPoolSize int `yaml:"MemPoolSize"` MemPoolSize int `yaml:"MemPoolSize"`
@ -79,6 +80,29 @@ func (p *ProtocolConfiguration) GetFreeGas(block uint32) util.Fixed8 {
return gas return gas
} }
func getIntFromMap(m map[uint32]int, block uint32) int {
var res int
var height uint32
for h, i := range m {
if h > block || h < height || i < 0 {
continue
}
res = i
height = h
}
return res
}
// GetMaxTxPerBlock returns MaxTransactionsPerBlock value for given block height.
func (p *ProtocolConfiguration) GetMaxTxPerBlock(block uint32) int {
return getIntFromMap(p.MaxTransactionsPerBlock, block)
}
// GetMaxFreeTxPerBlock returns MaxFreeTransactionsPerBlock value for given block height.
func (p *ProtocolConfiguration) GetMaxFreeTxPerBlock(block uint32) int {
return getIntFromMap(p.MaxFreeTransactionsPerBlock, block)
}
// String implements the stringer interface. // String implements the stringer interface.
func (n NetMode) String() string { func (n NetMode) String() string {
switch n { switch n {

View file

@ -156,14 +156,6 @@ func NewBlockchain(s storage.Store, cfg config.ProtocolConfiguration, log *zap.L
cfg.MemPoolSize = defaultMemPoolSize cfg.MemPoolSize = defaultMemPoolSize
log.Info("mempool size is not set or wrong, setting default value", zap.Int("MemPoolSize", cfg.MemPoolSize)) log.Info("mempool size is not set or wrong, setting default value", zap.Int("MemPoolSize", cfg.MemPoolSize))
} }
if cfg.MaxTransactionsPerBlock <= 0 {
cfg.MaxTransactionsPerBlock = 0
log.Info("MaxTransactionsPerBlock is not set or wrong, setting default value (unlimited)", zap.Int("MaxTransactionsPerBlock", cfg.MaxTransactionsPerBlock))
}
if cfg.MaxFreeTransactionsPerBlock <= 0 {
cfg.MaxFreeTransactionsPerBlock = 0
log.Info("MaxFreeTransactionsPerBlock is not set or wrong, setting default value (unlimited)", zap.Int("MaxFreeTransactionsPerBlock", cfg.MaxFreeTransactionsPerBlock))
}
if cfg.MaxFreeTransactionSize <= 0 { if cfg.MaxFreeTransactionSize <= 0 {
cfg.MaxFreeTransactionSize = 0 cfg.MaxFreeTransactionSize = 0
log.Info("MaxFreeTransactionSize is not set or wrong, setting default value (unlimited)", zap.Int("MaxFreeTransactionSize", cfg.MaxFreeTransactionSize)) log.Info("MaxFreeTransactionSize is not set or wrong, setting default value (unlimited)", zap.Int("MaxFreeTransactionSize", cfg.MaxFreeTransactionSize))
@ -1646,10 +1638,11 @@ func (bc *Blockchain) GetMemPool() *mempool.Pool {
// ApplyPolicyToTxSet applies configured policies to given transaction set. It // ApplyPolicyToTxSet applies configured policies to given transaction set. It
// expects slice to be ordered by fee and returns a subslice of it. // expects slice to be ordered by fee and returns a subslice of it.
func (bc *Blockchain) ApplyPolicyToTxSet(txes []mempool.TxWithFee) []mempool.TxWithFee { func (bc *Blockchain) ApplyPolicyToTxSet(txes []mempool.TxWithFee) []mempool.TxWithFee {
if bc.config.MaxTransactionsPerBlock != 0 && len(txes) > bc.config.MaxTransactionsPerBlock { maxTx := bc.config.GetMaxTxPerBlock(bc.BlockHeight())
txes = txes[:bc.config.MaxTransactionsPerBlock] if maxTx != 0 && len(txes) > maxTx {
txes = txes[:maxTx]
} }
maxFree := bc.config.MaxFreeTransactionsPerBlock maxFree := bc.config.GetMaxFreeTxPerBlock(bc.BlockHeight())
if maxFree != 0 && len(txes) > maxFree { if maxFree != 0 && len(txes) > maxFree {
// Transactions are sorted by fee, so we just find the first free one. // Transactions are sorted by fee, so we just find the first free one.
freeStart := sort.Search(len(txes), func(i int) bool { freeStart := sort.Search(len(txes), func(i int) bool {