tailscale/net/tstun
Joe Tsai 2e5d08ec4f
net/connstats: invert network logging data flow (#6272)
Previously, tstun.Wrapper and magicsock.Conn managed their
own statistics data structure and relied on an external call to
Extract to extract (and reset) the statistics.
This makes it difficult to ensure a maximum size on the statistics
as the caller has no introspection into whether the number
of unique connections is getting too large.

Invert the control flow such that a *connstats.Statistics
is registered with tstun.Wrapper and magicsock.Conn.
Methods on non-nil *connstats.Statistics are called for every packet.
This allows the implementation of connstats.Statistics (in the future)
to better control when it needs to flush to ensure
bounds on maximum sizes.

The value registered into tstun.Wrapper and magicsock.Conn could
be an interface, but that has two performance detriments:

1. Method calls on interface values are more expensive since
they must go through a virtual method dispatch.

2. The implementation would need a sync.Mutex to protect the
statistics value instead of using an atomic.Pointer.

Given that methods on constats.Statistics are called for every packet,
we want reduce the CPU cost on this hot path.

Signed-off-by: Joe Tsai <joetsai@digital-static.net>
2022-11-28 15:59:33 -08:00
..
constants.go wgengine/netstack: make netstack MTU be 1280 also 2022-06-01 12:16:41 -07:00
fake.go go.mod: upgrade wireguard-windows, de-fork wireguard-go 2021-05-25 13:18:21 -07:00
ifstatus_noop.go all: remove old +build tags 2022-11-04 07:25:42 -07:00
ifstatus_windows.go go.mod: upgrade wireguard-windows, de-fork wireguard-go 2021-05-25 13:18:21 -07:00
linkattrs_linux.go net/tstun: set link speed to SPEED_UNKNOWN 2022-02-27 23:11:35 -08:00
linkattrs_notlinux.go all: remove old +build tags 2022-11-04 07:25:42 -07:00
tap_linux.go cmd/tailscaled, net/tstun: add build tags to omit BIRD and TAP 2022-11-07 11:13:14 -05:00
tap_unsupported.go cmd/tailscaled, net/tstun: add build tags to omit BIRD and TAP 2022-11-07 11:13:14 -05:00
tun.go cmd/tailscaled, net/tstun: add build tags to omit BIRD and TAP 2022-11-07 11:13:14 -05:00
tun_linux.go net/tstun: diagnose /dev/net/tun fd leak, give better failure message 2022-07-16 14:21:56 -07:00
tun_macos.go all: remove old +build tags 2022-11-04 07:25:42 -07:00
tun_notwindows.go all: remove old +build tags 2022-11-04 07:25:42 -07:00
tun_windows.go net/tstun: update tun_windows for wintun 0.14 API revisions, update wireguard-go dependency to 82d2aa87aa623cb5143a41c3345da4fb875ad85d 2021-10-12 16:07:46 -06:00
wrap.go net/connstats: invert network logging data flow (#6272) 2022-11-28 15:59:33 -08:00
wrap_test.go net/connstats: invert network logging data flow (#6272) 2022-11-28 15:59:33 -08:00