open-consul/vendor/github.com/hashicorp
Paul Banks 3adfe86f03 Update Serf and memberlist (#4511)
This includes fixes that improve gossip scalability on very large (> 10k node) clusters.

The Serf changes:
 - take snapshot disk IO out of the critical path for handling messages hashicorp/serf#524
 - make snapshot compaction much less aggressive - the old fixed threshold caused snapshots to be constantly compacted (synchronously with request handling) on clusters larger than about 2000 nodes! hashicorp/serf#525

Memberlist changes:
 - prioritize handling alive messages over suspect/dead to improve stability, and handle queue in LIFO order to avoid acting on info that 's already stale in the queue by the time we handle it. hashicorp/memberlist#159
 - limit the number of concurrent pushPull requests being handled at once to 128. In one test scenario with 10s of thousands of servers we saw channel and lock blocking cause over 3000 pushPulls at once which ballooned the memory of the server because each push pull contained a de-serialised list of all known 10k+ nodes and their tags for a total of about 60 million objects and 7GB of memory stuck. While the rest of the fixes here should prevent the same root cause from blocking in the same way, this prevents any other bug or source of contention from allowing pushPull messages to stack up and eat resources. hashicorp/memberlist#158
2018-08-09 13:16:13 -04:00
..
errwrap Manage dependencies via Godep 2016-02-12 16:50:37 -08:00
go-checkpoint Updating go-checkpoint lib to have a fixed timeout (#3564) 2017-10-17 17:01:23 -07:00
go-cleanhttp Updates hashicorp/go-cleanhttp to pick up new sanitizer. 2017-12-20 13:48:49 -08:00
go-discover Vendoring update for go-discover. (#4412) 2018-07-25 16:21:04 -07:00
go-hclog Vendor the vault api 2018-06-25 12:26:10 -07:00
go-immutable-radix Govendor update go-memdb and go-immutable-radix to pick up changes for DeletePrefix 2017-07-25 17:28:43 -05:00
go-memdb Govendor update go-memdb and go-immutable-radix to pick up changes for DeletePrefix 2017-07-25 17:28:43 -05:00
go-msgpack Cleans up go-msgpack vendoring. 2016-11-14 17:37:05 -08:00
go-multierror Manage dependencies via Godep 2016-02-12 16:50:37 -08:00
go-plugin Vendor the vault api 2018-06-25 12:26:10 -07:00
go-retryablehttp Vendor the vault api 2018-06-25 12:26:10 -07:00
go-rootcerts Vendor the go-rootcerts lib for the client tls options 2017-04-14 13:46:19 -07:00
go-sockaddr vendor: update github.com/hashicorp/go-sockaddr (#3633) 2017-10-31 17:05:57 -07:00
go-syslog Updates hashicorp/go-syslog. 2016-08-09 17:24:40 -07:00
go-uuid Updates hashicorp/go-uuid. 2016-08-09 17:24:40 -07:00
go-version Add advanced autopilot features 2017-03-22 15:25:16 -07:00
golang-lru Updates hashicorp/golang-lru. 2016-08-09 16:26:59 -07:00
hcl Replace monkey patch with code from https://github.com/hashicorp/hcl/pull/213 2017-09-26 12:42:03 +02:00
hil Updates hashicorp/hcl and hashicorp/hil. 2016-08-09 17:24:13 -07:00
logutils Updates hashicorp/logutils. 2016-08-09 17:24:40 -07:00
memberlist Update Serf and memberlist (#4511) 2018-08-09 13:16:13 -04:00
net-rpc-msgpackrpc Manage dependencies via Godep 2016-02-12 16:50:37 -08:00
raft Updates vendor directory for raft to record raft v1.0.0. No functional changes 2017-10-03 17:19:10 -05:00
raft-boltdb Updating vendor directory for raft address provider interface changes 2017-08-30 09:57:48 -05:00
scada-client/test vendor: remove github.com/hashicorp/scada-client 2017-05-22 11:07:46 +02:00
serf Update Serf and memberlist (#4511) 2018-08-09 13:16:13 -04:00
vault Remove build tags from vendored vault file to allow for this to merge properly into enterprise 2018-06-25 12:26:10 -07:00
yamux Update yamux vendoring 2018-06-04 16:02:50 -04:00