Merge pull request #821 from cfromknecht/switch-early-shutdown
htlcswitch/switch: improve safety of switch shutdown
This commit is contained in:
commit
45eaa70814
@ -514,11 +514,22 @@ func (s *Switch) ForwardPackets(packets ...*htlcPacket) chan error {
|
|||||||
wg.Add(1)
|
wg.Add(1)
|
||||||
defer wg.Done()
|
defer wg.Done()
|
||||||
|
|
||||||
// Spawn a goroutine the proxy the errs back to the returned err chan.
|
// Before spawning the following goroutine to proxy our error responses,
|
||||||
// This is done to ensure the err chan returned to the caller closed
|
// check to see if we have already been issued a shutdown request. If
|
||||||
// properly, alerting the receiver of completion or shutdown.
|
// so, we exit early to avoid incrementing the switch's waitgroup while
|
||||||
|
// it is already in the process of shutting down.
|
||||||
|
select {
|
||||||
|
case <-s.quit:
|
||||||
|
close(errChan)
|
||||||
|
return errChan
|
||||||
|
default:
|
||||||
|
// Spawn a goroutine the proxy the errs back to the returned err
|
||||||
|
// chan. This is done to ensure the err chan returned to the
|
||||||
|
// caller closed properly, alerting the receiver of completion
|
||||||
|
// or shutdown.
|
||||||
s.wg.Add(1)
|
s.wg.Add(1)
|
||||||
go s.proxyFwdErrs(&numSent, &wg, fwdChan, errChan)
|
go s.proxyFwdErrs(&numSent, &wg, fwdChan, errChan)
|
||||||
|
}
|
||||||
|
|
||||||
// Make a first pass over the packets, forwarding any settles or fails.
|
// Make a first pass over the packets, forwarding any settles or fails.
|
||||||
// As adds are found, we create a circuit and append it to our set of
|
// As adds are found, we create a circuit and append it to our set of
|
||||||
@ -1435,6 +1446,7 @@ func (s *Switch) Start() error {
|
|||||||
go s.htlcForwarder()
|
go s.htlcForwarder()
|
||||||
|
|
||||||
if err := s.reforwardResponses(); err != nil {
|
if err := s.reforwardResponses(); err != nil {
|
||||||
|
s.Stop()
|
||||||
log.Errorf("unable to reforward responses: %v", err)
|
log.Errorf("unable to reforward responses: %v", err)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -1591,12 +1603,15 @@ func (s *Switch) Stop() error {
|
|||||||
|
|
||||||
close(s.quit)
|
close(s.quit)
|
||||||
|
|
||||||
|
s.wg.Wait()
|
||||||
|
|
||||||
|
// Wait until all active goroutines have finished exiting before
|
||||||
|
// stopping the mailboxes, otherwise the mailbox map could still be
|
||||||
|
// accessed and modified.
|
||||||
for _, mailBox := range s.mailboxes {
|
for _, mailBox := range s.mailboxes {
|
||||||
mailBox.Stop()
|
mailBox.Stop()
|
||||||
}
|
}
|
||||||
|
|
||||||
s.wg.Wait()
|
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user