|
|
@ -190,6 +190,16 @@ func probe() error {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
func probeNodePair(ctx context.Context, dm *tailcfg.DERPMap, from, to *tailcfg.DERPNode) (latency time.Duration, err error) {
|
|
|
|
func probeNodePair(ctx context.Context, dm *tailcfg.DERPMap, from, to *tailcfg.DERPNode) (latency time.Duration, err error) {
|
|
|
|
|
|
|
|
// The passed in context is a minute for the whole region. The
|
|
|
|
|
|
|
|
// idea is that each node pair in the region will be done
|
|
|
|
|
|
|
|
// serially and regularly in the future, reusing connections
|
|
|
|
|
|
|
|
// (at least in the happy path). For now they don't reuse
|
|
|
|
|
|
|
|
// connections and probe at most once every 15 seconds. We
|
|
|
|
|
|
|
|
// bound the duration of a single node pair within a region
|
|
|
|
|
|
|
|
// so one bad one can't starve others.
|
|
|
|
|
|
|
|
ctx, cancel := context.WithTimeout(ctx, 10*time.Second)
|
|
|
|
|
|
|
|
defer cancel()
|
|
|
|
|
|
|
|
|
|
|
|
fromc, err := newConn(ctx, dm, from)
|
|
|
|
fromc, err := newConn(ctx, dm, from)
|
|
|
|
if err != nil {
|
|
|
|
if err != nil {
|
|
|
|
return 0, err
|
|
|
|
return 0, err
|
|
|
|