Wojciech Bederski b014c0f91b make Pause()/Resume()/isPaused() behave more like a semaphore
see: https://github.com/hashicorp/consul/issues/1173 #1173

Reasoning: somewhere during consul development Pause()/Resume() and
PauseSync()/ResumeSync() were added to protect larger changes to
agent's localState.  A few of the places that it tries to protect are:

- (a *Agent) AddService(...)      # part of the method
- (c *Command) handleReload(...)  # almost the whole method
- (l *localState) antiEntropy(...)# isPaused() prevents syncChanges()

The main problem is, that in the middle of handleReload(...)'s
critical section it indirectly (loadServices()) calls  AddService(...).
AddService() in turn calls Pause() to protect itself against
syncChanges(). At the end of AddService() a defered call to Resume() is
made.

With the current implementation, this releases
isPaused() "lock" in the middle of handleReload() allowing antiEntropy
to kick in while configuration reload is still in progress.
Specifically almost all services and probably all check are unloaded
when syncChanges() is allowed to run.

This in turn can causes massive service/check de-/re-registration,
and since checks are by default registered in the critical state,
a majority of services on a node can be marked as failing.
It's made worse with automation, often calling `consul reload` in close
proximity on many nodes in the cluster.

This change basically turns Pause()/Resume() into P()/V() of
a garden-variety semaphore. Allowing Pause() to be called multiple times,
and releasing isPaused() only after all matching/defered Resumes() are
called as well.

TODO/NOTE: as with many semaphore implementations, it might be reasonable
to panic() if l.paused ever becomes negative.
2015-09-11 18:28:06 +02:00
..
2015-05-05 19:25:10 -07:00
2015-07-24 14:06:05 +10:00
2015-07-24 14:06:05 +10:00
2015-09-08 16:54:36 +02:00
2015-09-08 16:54:36 +02:00
2013-12-20 16:39:32 -08:00
2013-12-20 16:39:32 -08:00
2013-12-20 16:39:32 -08:00
2013-12-20 16:39:32 -08:00
2015-09-01 18:28:32 -07:00
2015-07-07 15:14:06 -06:00
2013-12-20 16:39:32 -08:00
2013-12-20 16:39:32 -08:00
2015-07-07 10:36:51 -06:00
2015-08-27 11:08:01 -07:00
2014-05-20 16:25:29 -07:00
2013-12-23 16:20:51 -08:00
2015-05-11 16:48:10 -07:00
2014-08-21 14:28:16 -07:00