Merge pull request #1583 from obscuren/miner-price-order
miner, core: sort txs by price, nonce
This commit is contained in:
		@@ -289,3 +289,22 @@ type TxByNonce struct{ Transactions }
 | 
				
			|||||||
func (s TxByNonce) Less(i, j int) bool {
 | 
					func (s TxByNonce) Less(i, j int) bool {
 | 
				
			||||||
	return s.Transactions[i].data.AccountNonce < s.Transactions[j].data.AccountNonce
 | 
						return s.Transactions[i].data.AccountNonce < s.Transactions[j].data.AccountNonce
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type TxByPrice struct{ Transactions }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (s TxByPrice) Less(i, j int) bool {
 | 
				
			||||||
 | 
						return s.Transactions[i].data.Price.Cmp(s.Transactions[j].data.Price) > 0
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					type TxByPriceAndNonce struct{ Transactions }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					func (s TxByPriceAndNonce) Less(i, j int) bool {
 | 
				
			||||||
 | 
						// we can ignore the error here. Sorting shouldn't care about validness
 | 
				
			||||||
 | 
						ifrom, _ := s.Transactions[i].From()
 | 
				
			||||||
 | 
						jfrom, _ := s.Transactions[j].From()
 | 
				
			||||||
 | 
						// favour nonce if they are from the same recipient
 | 
				
			||||||
 | 
						if ifrom == jfrom {
 | 
				
			||||||
 | 
							return s.Transactions[i].data.AccountNonce < s.Transactions[j].data.AccountNonce
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						return s.Transactions[i].data.Price.Cmp(s.Transactions[j].data.Price) > 0
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -457,9 +457,42 @@ func (self *worker) commitNewWork() {
 | 
				
			|||||||
	self.makeCurrent(parent, header)
 | 
						self.makeCurrent(parent, header)
 | 
				
			||||||
	work := self.current
 | 
						work := self.current
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	// commit transactions for this run.
 | 
						/* //approach 1
 | 
				
			||||||
	transactions := self.eth.TxPool().GetTransactions()
 | 
						transactions := self.eth.TxPool().GetTransactions()
 | 
				
			||||||
	sort.Sort(types.TxByNonce{transactions})
 | 
						sort.Sort(types.TxByNonce{transactions})
 | 
				
			||||||
 | 
						*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						//approach 2
 | 
				
			||||||
 | 
						transactions := self.eth.TxPool().GetTransactions()
 | 
				
			||||||
 | 
						sort.Sort(types.TxByPriceAndNonce{transactions})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* // approach 3
 | 
				
			||||||
 | 
						// commit transactions for this run.
 | 
				
			||||||
 | 
						txPerOwner := make(map[common.Address]types.Transactions)
 | 
				
			||||||
 | 
						// Sort transactions by owner
 | 
				
			||||||
 | 
						for _, tx := range self.eth.TxPool().GetTransactions() {
 | 
				
			||||||
 | 
							from, _ := tx.From() // we can ignore the sender error
 | 
				
			||||||
 | 
							txPerOwner[from] = append(txPerOwner[from], tx)
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						var (
 | 
				
			||||||
 | 
							singleTxOwner types.Transactions
 | 
				
			||||||
 | 
							multiTxOwner  types.Transactions
 | 
				
			||||||
 | 
						)
 | 
				
			||||||
 | 
						// Categorise transactions by
 | 
				
			||||||
 | 
						// 1. 1 owner tx per block
 | 
				
			||||||
 | 
						// 2. multi txs owner per block
 | 
				
			||||||
 | 
						for _, txs := range txPerOwner {
 | 
				
			||||||
 | 
							if len(txs) == 1 {
 | 
				
			||||||
 | 
								singleTxOwner = append(singleTxOwner, txs[0])
 | 
				
			||||||
 | 
							} else {
 | 
				
			||||||
 | 
								multiTxOwner = append(multiTxOwner, txs...)
 | 
				
			||||||
 | 
							}
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
						sort.Sort(types.TxByPrice{singleTxOwner})
 | 
				
			||||||
 | 
						sort.Sort(types.TxByNonce{multiTxOwner})
 | 
				
			||||||
 | 
						transactions := append(singleTxOwner, multiTxOwner...)
 | 
				
			||||||
 | 
						*/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	work.coinbase.SetGasLimit(header.GasLimit)
 | 
						work.coinbase.SetGasLimit(header.GasLimit)
 | 
				
			||||||
	work.commitTransactions(transactions, self.gasPrice, self.proc)
 | 
						work.commitTransactions(transactions, self.gasPrice, self.proc)
 | 
				
			||||||
	self.eth.TxPool().RemoveTransactions(work.lowGasTxs)
 | 
						self.eth.TxPool().RemoveTransactions(work.lowGasTxs)
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user