mirror of
https://github.com/lightningnetwork/lnd.git
synced 2025-11-10 22:27:22 +01:00
sweep: make sweeper block-driven instead of time-driven
This commit changes the source that drives the state changes in the sweeper. Previously we used a ticker with default interval of 30s to trigger sweepings periodically. The assumption is, within this 30s we'd batch multiple inputs into one transaction to maximize profits. However, the efficacy of this batch is questionable. At a high level, we can put our inputs into two categories - one that's forced, and one that's not. For forced inputs, we should sweep them immediately as the force flag indicates they are very urgent, eg, CPFPing the force closing tx. For non-forced inputs, such as anchors or HTLCs with CLTV that's far away, we can wait to sweep them till a new block comes in and triggers the sweeping process. Eventually, all inputs will be deadline-aware, and the sweeper will consult our fee bumper about the most economical fee rate to be used for a given deadline. Since the deadlines here are blockstamp, it's also easier to manage them if the sweeper is also using blockstamp instead of timestamp.
This commit is contained in:
@@ -40,6 +40,27 @@ func NewMockNotifier(t *testing.T) *MockNotifier {
|
||||
}
|
||||
}
|
||||
|
||||
// NotifyEpochNonBlocking simulates a new epoch arriving without blocking when
|
||||
// the epochChan is not read.
|
||||
func (m *MockNotifier) NotifyEpochNonBlocking(height int32) {
|
||||
m.t.Helper()
|
||||
|
||||
for epochChan, chanHeight := range m.epochChan {
|
||||
// Only send notifications if the height is greater than the
|
||||
// height the caller passed into the register call.
|
||||
if chanHeight >= height {
|
||||
continue
|
||||
}
|
||||
|
||||
log.Debugf("Notifying height %v to listener", height)
|
||||
|
||||
select {
|
||||
case epochChan <- &chainntnfs.BlockEpoch{Height: height}:
|
||||
default:
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// NotifyEpoch simulates a new epoch arriving.
|
||||
func (m *MockNotifier) NotifyEpoch(height int32) {
|
||||
m.t.Helper()
|
||||
|
||||
Reference in New Issue
Block a user