Merge pull request #5299 from C-Otto/insufficient-bandwidth-log
add detailed log message for "insufficient bandwidth" error
This commit is contained in:
commit
a4d4d5f8dc
@ -640,7 +640,7 @@ func (l *channelLink) createFailureWithUpdate(
|
|||||||
// flow. We'll compare out commitment chains with the remote party, and re-send
|
// flow. We'll compare out commitment chains with the remote party, and re-send
|
||||||
// either a danging commit signature, a revocation, or both.
|
// either a danging commit signature, a revocation, or both.
|
||||||
func (l *channelLink) syncChanStates() error {
|
func (l *channelLink) syncChanStates() error {
|
||||||
l.log.Info("attempting to re-resynchronize")
|
l.log.Info("attempting to re-synchronize")
|
||||||
|
|
||||||
// First, we'll generate our ChanSync message to send to the other
|
// First, we'll generate our ChanSync message to send to the other
|
||||||
// side. Based on this message, the remote party will decide if they
|
// side. Based on this message, the remote party will decide if they
|
||||||
@ -1558,7 +1558,7 @@ func (l *channelLink) cleanupSpuriousResponse(pkt *htlcPacket) {
|
|||||||
// If the htlc packet doesn't have a source reference, it is unsafe to
|
// If the htlc packet doesn't have a source reference, it is unsafe to
|
||||||
// proceed, as skipping this ack may cause the htlc to be reforwarded.
|
// proceed, as skipping this ack may cause the htlc to be reforwarded.
|
||||||
if pkt.sourceRef == nil {
|
if pkt.sourceRef == nil {
|
||||||
l.log.Errorf("uanble to cleanup response for incoming "+
|
l.log.Errorf("unable to cleanup response for incoming "+
|
||||||
"circuit-key=%v, does not contain source reference",
|
"circuit-key=%v, does not contain source reference",
|
||||||
inKey)
|
inKey)
|
||||||
return
|
return
|
||||||
@ -2217,7 +2217,7 @@ func (l *channelLink) CheckHtlcForward(payHash [32]byte,
|
|||||||
// any case, we'll cancel this HTLC.
|
// any case, we'll cancel this HTLC.
|
||||||
actualFee := incomingHtlcAmt - amtToForward
|
actualFee := incomingHtlcAmt - amtToForward
|
||||||
if incomingHtlcAmt < amtToForward || actualFee < expectedFee {
|
if incomingHtlcAmt < amtToForward || actualFee < expectedFee {
|
||||||
l.log.Errorf("outgoing htlc(%x) has insufficient fee: "+
|
l.log.Warnf("outgoing htlc(%x) has insufficient fee: "+
|
||||||
"expected %v, got %v",
|
"expected %v, got %v",
|
||||||
payHash[:], int64(expectedFee), int64(actualFee))
|
payHash[:], int64(expectedFee), int64(actualFee))
|
||||||
|
|
||||||
@ -2239,7 +2239,7 @@ func (l *channelLink) CheckHtlcForward(payHash [32]byte,
|
|||||||
// sender messed up, or an intermediate node tampered with the HTLC.
|
// sender messed up, or an intermediate node tampered with the HTLC.
|
||||||
timeDelta := policy.TimeLockDelta
|
timeDelta := policy.TimeLockDelta
|
||||||
if incomingTimeout < outgoingTimeout+timeDelta {
|
if incomingTimeout < outgoingTimeout+timeDelta {
|
||||||
l.log.Errorf("incoming htlc(%x) has incorrect time-lock value: "+
|
l.log.Warnf("incoming htlc(%x) has incorrect time-lock value: "+
|
||||||
"expected at least %v block delta, got %v block delta",
|
"expected at least %v block delta, got %v block delta",
|
||||||
payHash[:], timeDelta, incomingTimeout-outgoingTimeout)
|
payHash[:], timeDelta, incomingTimeout-outgoingTimeout)
|
||||||
|
|
||||||
@ -2276,7 +2276,7 @@ func (l *channelLink) CheckHtlcTransit(payHash [32]byte,
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
// htlcSatifiesPolicyOutgoing checks whether the given htlc parameters satisfy
|
// canSendHtlc checks whether the given htlc parameters satisfy
|
||||||
// the channel's amount and time lock constraints.
|
// the channel's amount and time lock constraints.
|
||||||
func (l *channelLink) canSendHtlc(policy ForwardingPolicy,
|
func (l *channelLink) canSendHtlc(policy ForwardingPolicy,
|
||||||
payHash [32]byte, amt lnwire.MilliSatoshi, timeout uint32,
|
payHash [32]byte, amt lnwire.MilliSatoshi, timeout uint32,
|
||||||
@ -2286,7 +2286,7 @@ func (l *channelLink) canSendHtlc(policy ForwardingPolicy,
|
|||||||
// too small for the next hop. If so, then we'll cancel the HTLC
|
// too small for the next hop. If so, then we'll cancel the HTLC
|
||||||
// directly.
|
// directly.
|
||||||
if amt < policy.MinHTLCOut {
|
if amt < policy.MinHTLCOut {
|
||||||
l.log.Errorf("outgoing htlc(%x) is too small: min_htlc=%v, "+
|
l.log.Warnf("outgoing htlc(%x) is too small: min_htlc=%v, "+
|
||||||
"htlc_value=%v", payHash[:], policy.MinHTLCOut,
|
"htlc_value=%v", payHash[:], policy.MinHTLCOut,
|
||||||
amt)
|
amt)
|
||||||
|
|
||||||
@ -2305,7 +2305,7 @@ func (l *channelLink) canSendHtlc(policy ForwardingPolicy,
|
|||||||
// Next, ensure that the passed HTLC isn't too large. If so, we'll
|
// Next, ensure that the passed HTLC isn't too large. If so, we'll
|
||||||
// cancel the HTLC directly.
|
// cancel the HTLC directly.
|
||||||
if policy.MaxHTLC != 0 && amt > policy.MaxHTLC {
|
if policy.MaxHTLC != 0 && amt > policy.MaxHTLC {
|
||||||
l.log.Errorf("outgoing htlc(%x) is too large: max_htlc=%v, "+
|
l.log.Warnf("outgoing htlc(%x) is too large: max_htlc=%v, "+
|
||||||
"htlc_value=%v", payHash[:], policy.MaxHTLC, amt)
|
"htlc_value=%v", payHash[:], policy.MaxHTLC, amt)
|
||||||
|
|
||||||
// As part of the returned error, we'll send our latest routing
|
// As part of the returned error, we'll send our latest routing
|
||||||
@ -2322,7 +2322,7 @@ func (l *channelLink) canSendHtlc(policy ForwardingPolicy,
|
|||||||
// future, so we'll reject an HTLC if the outgoing expiration time is
|
// future, so we'll reject an HTLC if the outgoing expiration time is
|
||||||
// too close to the current height.
|
// too close to the current height.
|
||||||
if timeout <= heightNow+l.cfg.OutgoingCltvRejectDelta {
|
if timeout <= heightNow+l.cfg.OutgoingCltvRejectDelta {
|
||||||
l.log.Errorf("htlc(%x) has an expiry that's too soon: "+
|
l.log.Warnf("htlc(%x) has an expiry that's too soon: "+
|
||||||
"outgoing_expiry=%v, best_height=%v", payHash[:],
|
"outgoing_expiry=%v, best_height=%v", payHash[:],
|
||||||
timeout, heightNow)
|
timeout, heightNow)
|
||||||
failure := l.createFailureWithUpdate(
|
failure := l.createFailureWithUpdate(
|
||||||
@ -2335,7 +2335,7 @@ func (l *channelLink) canSendHtlc(policy ForwardingPolicy,
|
|||||||
|
|
||||||
// Check absolute max delta.
|
// Check absolute max delta.
|
||||||
if timeout > l.cfg.MaxOutgoingCltvExpiry+heightNow {
|
if timeout > l.cfg.MaxOutgoingCltvExpiry+heightNow {
|
||||||
l.log.Errorf("outgoing htlc(%x) has a time lock too far in "+
|
l.log.Warnf("outgoing htlc(%x) has a time lock too far in "+
|
||||||
"the future: got %v, but maximum is %v", payHash[:],
|
"the future: got %v, but maximum is %v", payHash[:],
|
||||||
timeout-heightNow, l.cfg.MaxOutgoingCltvExpiry)
|
timeout-heightNow, l.cfg.MaxOutgoingCltvExpiry)
|
||||||
|
|
||||||
@ -2344,6 +2344,8 @@ func (l *channelLink) canSendHtlc(policy ForwardingPolicy,
|
|||||||
|
|
||||||
// Check to see if there is enough balance in this channel.
|
// Check to see if there is enough balance in this channel.
|
||||||
if amt > l.Bandwidth() {
|
if amt > l.Bandwidth() {
|
||||||
|
l.log.Warnf("insufficient bandwidth to route htlc: %v is "+
|
||||||
|
"larger than %v", amt, l.Bandwidth())
|
||||||
failure := l.createFailureWithUpdate(
|
failure := l.createFailureWithUpdate(
|
||||||
func(upd *lnwire.ChannelUpdate) lnwire.FailureMessage {
|
func(upd *lnwire.ChannelUpdate) lnwire.FailureMessage {
|
||||||
return lnwire.NewTemporaryChannelFailure(upd)
|
return lnwire.NewTemporaryChannelFailure(upd)
|
||||||
|
@ -109,8 +109,6 @@
|
|||||||
<time> [ERR] HSWC: ChannelLink(<chan>): failing link: unable to synchronize channel states: unable to send chan sync message for ChannelPoint(<chan_point>): write tcp <ip>-><ip>: write: connection reset by peer with error: unable to resume channel, recovery required
|
<time> [ERR] HSWC: ChannelLink(<chan>): failing link: unable to synchronize channel states: unable to send chan sync message for ChannelPoint(<chan_point>): write tcp <ip>-><ip>: write: connection reset by peer with error: unable to resume channel, recovery required
|
||||||
<time> [ERR] HSWC: ChannelLink(<chan>): failing link: unable to update commitment: link shutting down with error: internal error
|
<time> [ERR] HSWC: ChannelLink(<chan>): failing link: unable to update commitment: link shutting down with error: internal error
|
||||||
<time> [ERR] HSWC: ChannelLink(<chan>): link failed, exiting htlcManager
|
<time> [ERR] HSWC: ChannelLink(<chan>): link failed, exiting htlcManager
|
||||||
<time> [ERR] HSWC: ChannelLink(<chan>): outgoing htlc(<hex>) has insufficient fee: expected 575000, got 1075
|
|
||||||
<time> [ERR] HSWC: ChannelLink(<chan>): outgoing htlc(<hex>) is too small: min_htlc=<amt>, htlc_value=<amt>
|
|
||||||
<time> [ERR] HSWC: ChannelLink(<chan>): unable to cancel incoming HTLC for circuit-key=(Chan ID=<chan>, HTLC ID=0): HTLC with ID 0 has already been failed
|
<time> [ERR] HSWC: ChannelLink(<chan>): unable to cancel incoming HTLC for circuit-key=(Chan ID=<chan>, HTLC ID=0): HTLC with ID 0 has already been failed
|
||||||
<time> [ERR] HSWC: ChannelLink(<chan>): unable to decode onion hop iterator: TemporaryChannelFailure
|
<time> [ERR] HSWC: ChannelLink(<chan>): unable to decode onion hop iterator: TemporaryChannelFailure
|
||||||
<time> [ERR] HSWC: ChannelLink(<chan>): unable to update signals
|
<time> [ERR] HSWC: ChannelLink(<chan>): unable to update signals
|
||||||
|
Loading…
Reference in New Issue
Block a user