mempool: Modify default orphan tx policy.
The current max orphan transaction size causes problems with dependent transaction relay due to its artificially small size in relation to the max standard transaction size. Consequently, this modifies the orphan transaction policy by increasing the max size of each orphan to the same value allowed for standard non-orphan transactions and reducing the default max allowed number of orphans to 100. From a memory usage standpoint, the worst case max mem usage prior to this change was 5MB plus structure and tracking overhead (1000 max orphans * 5KB max each). With this, that is raised to 10MB (100 max orphans * 100KB max each) in the worst case. It is important to note that the values were originally implemented as a naive means to control the size of the orphan pool before several of the recent enhancements which more aggressively remove orphans from the orphan pool were added, so they needed to be evaluated again. For a very long time prior to recent changes, the orphan pool would quickly reach the max allowed worst-case usage and effectively stay there forever whereas with more recent changes, the actual run-time orphan pool usage is usually much smaller. Finally, as another point in favor of this change, as the network has evolved, nodes have generally become better about orphan management and as such missing ancestors will typically either be broadcast or mined fairly quickly resulting in fewer overall orphans.
This commit is contained in:
parent
6d5714e1b7
commit
760c5299c7
5 changed files with 12 additions and 12 deletions
|
@ -50,8 +50,8 @@ const (
|
||||||
blockMaxSizeMin = 1000
|
blockMaxSizeMin = 1000
|
||||||
blockMaxSizeMax = wire.MaxBlockPayload - 1000
|
blockMaxSizeMax = wire.MaxBlockPayload - 1000
|
||||||
defaultGenerate = false
|
defaultGenerate = false
|
||||||
defaultMaxOrphanTransactions = 1000
|
defaultMaxOrphanTransactions = 100
|
||||||
defaultMaxOrphanTxSize = 5000
|
defaultMaxOrphanTxSize = mempool.MaxStandardTxSize
|
||||||
defaultSigCacheMaxSize = 100000
|
defaultSigCacheMaxSize = 100000
|
||||||
sampleConfigFilename = "sample-btcd.conf"
|
sampleConfigFilename = "sample-btcd.conf"
|
||||||
defaultTxIndex = false
|
defaultTxIndex = false
|
||||||
|
|
2
doc.go
2
doc.go
|
@ -94,7 +94,7 @@ Application Options:
|
||||||
--norelaypriority Do not require free or low-fee transactions to have
|
--norelaypriority Do not require free or low-fee transactions to have
|
||||||
high priority for relaying
|
high priority for relaying
|
||||||
--maxorphantx= Max number of orphan transactions to keep in memory
|
--maxorphantx= Max number of orphan transactions to keep in memory
|
||||||
(1000)
|
(100)
|
||||||
--generate Generate (mine) bitcoins using the CPU
|
--generate Generate (mine) bitcoins using the CPU
|
||||||
--miningaddr= Add the specified payment address to the list of
|
--miningaddr= Add the specified payment address to the list of
|
||||||
addresses to use for generated blocks -- At least
|
addresses to use for generated blocks -- At least
|
||||||
|
|
|
@ -19,10 +19,10 @@ const (
|
||||||
// that are considered standard in a pay-to-script-hash script.
|
// that are considered standard in a pay-to-script-hash script.
|
||||||
maxStandardP2SHSigOps = 15
|
maxStandardP2SHSigOps = 15
|
||||||
|
|
||||||
// maxStandardTxSize is the maximum size allowed for transactions that
|
// MaxStandardTxSize is the maximum size allowed for transactions that
|
||||||
// are considered standard and will therefore be relayed and considered
|
// are considered standard and will therefore be relayed and considered
|
||||||
// for mining.
|
// for mining.
|
||||||
maxStandardTxSize = 100000
|
MaxStandardTxSize = 100000
|
||||||
|
|
||||||
// maxStandardSigScriptSize is the maximum size allowed for a
|
// maxStandardSigScriptSize is the maximum size allowed for a
|
||||||
// transaction input signature script to be considered standard. This
|
// transaction input signature script to be considered standard. This
|
||||||
|
@ -276,9 +276,9 @@ func checkTransactionStandard(tx *btcutil.Tx, height int32,
|
||||||
// size of a transaction. This also helps mitigate CPU exhaustion
|
// size of a transaction. This also helps mitigate CPU exhaustion
|
||||||
// attacks.
|
// attacks.
|
||||||
serializedLen := msgTx.SerializeSize()
|
serializedLen := msgTx.SerializeSize()
|
||||||
if serializedLen > maxStandardTxSize {
|
if serializedLen > MaxStandardTxSize {
|
||||||
str := fmt.Sprintf("transaction size of %v is larger than max "+
|
str := fmt.Sprintf("transaction size of %v is larger than max "+
|
||||||
"allowed size of %v", serializedLen, maxStandardTxSize)
|
"allowed size of %v", serializedLen, MaxStandardTxSize)
|
||||||
return txRuleError(wire.RejectNonstandard, str)
|
return txRuleError(wire.RejectNonstandard, str)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -41,13 +41,13 @@ func TestCalcMinRequiredTxRelayFee(t *testing.T) {
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"max standard tx size with default minimum relay fee",
|
"max standard tx size with default minimum relay fee",
|
||||||
maxStandardTxSize,
|
MaxStandardTxSize,
|
||||||
DefaultMinRelayTxFee,
|
DefaultMinRelayTxFee,
|
||||||
100000,
|
100000,
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"max standard tx size with max satoshi relay fee",
|
"max standard tx size with max satoshi relay fee",
|
||||||
maxStandardTxSize,
|
MaxStandardTxSize,
|
||||||
btcutil.MaxSatoshi,
|
btcutil.MaxSatoshi,
|
||||||
btcutil.MaxSatoshi,
|
btcutil.MaxSatoshi,
|
||||||
},
|
},
|
||||||
|
@ -360,7 +360,7 @@ func TestCheckTransactionStandard(t *testing.T) {
|
||||||
TxOut: []*wire.TxOut{{
|
TxOut: []*wire.TxOut{{
|
||||||
Value: 0,
|
Value: 0,
|
||||||
PkScript: bytes.Repeat([]byte{0x00},
|
PkScript: bytes.Repeat([]byte{0x00},
|
||||||
maxStandardTxSize+1),
|
MaxStandardTxSize+1),
|
||||||
}},
|
}},
|
||||||
LockTime: 0,
|
LockTime: 0,
|
||||||
},
|
},
|
||||||
|
|
|
@ -236,8 +236,8 @@
|
||||||
; Require high priority for relaying free or low-fee transactions.
|
; Require high priority for relaying free or low-fee transactions.
|
||||||
; norelaypriority=0
|
; norelaypriority=0
|
||||||
|
|
||||||
; Limit orphan transaction pool to 1000 transactions.
|
; Limit orphan transaction pool to 100 transactions.
|
||||||
; maxorphantx=1000
|
; maxorphantx=100
|
||||||
|
|
||||||
; Do not accept transactions from remote peers.
|
; Do not accept transactions from remote peers.
|
||||||
; blocksonly=1
|
; blocksonly=1
|
||||||
|
|
Loading…
Add table
Reference in a new issue