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:
Dave Collins 2016-10-25 00:07:21 -05:00
parent 6d5714e1b7
commit 760c5299c7
No known key found for this signature in database
GPG key ID: B8904D9D9C93D1F2
5 changed files with 12 additions and 12 deletions

View file

@ -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
View file

@ -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

View file

@ -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)
} }

View file

@ -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,
}, },

View file

@ -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