You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 
Go to file
M. J. Fromberger 0663412559
util/eventbus: add basic throughput benchmarks (#15284)
Shovel small events through the pipeine as fast as possible in a few basic
configurations, to establish some baseline performance numbers.

Updates #15160

Change-Id: I1dcbbd1109abb7b93aa4dcb70da57f183eb0e60e
Signed-off-by: M. J. Fromberger <fromberger@tailscale.com>
9 months ago
.bencher bencher: add config to suppress failures on benchmark regressions. 4 years ago
.github .github: Bump peter-evans/create-pull-request from 7.0.7 to 7.0.8 (#15257) 9 months ago
appc appc: fix a deadlock in route advertisements (#15031) 10 months ago
atomicfile atomicfile: use ReplaceFile on Windows so that attributes and ACLs are preserved 11 months ago
chirp all: update copyright and license headers 3 years ago
client client/web: fix CSRF handler order in web UI (#15143) 9 months ago
clientupdate clientupdate: refuse to update in tsnet binaries (#14911) 10 months ago
cmd cmd/testwrapper: print failed tests preventing retry (#15270) 9 months ago
control control/controlclient, ipn: add client audit logging (#14950) 9 months ago
derp cmd/derper, derp/derphttp: support, generate self-signed IP address certs 9 months ago
disco disco: correct noun for nacl box type in disco docs 2 years ago
docs ipn/ipnlocal,util/syspolicy,docs/windows/policy: implement the ReconnectAfter policy setting 9 months ago
doctor net/{interfaces,netmon}, all: merge net/interfaces package into net/netmon 2 years ago
drive cmd/viewer,all: consistently use "read-only" instead of "readonly" 11 months ago
envknob ipn/ipnlocal, envknob: make it possible to configure the cert client to act in read-only mode (#15250) 9 months ago
feature feature/capture: move packet capture to feature/*, out of iOS + CLI 10 months ago
gokrazy gokrazy/natlab: update gokrazy, wire up natlab tests to GitHub CI 9 months ago
health health: relax no-derp-home warnable to not fire if not in map poll 10 months ago
hostinfo feature/*: make Wake-on-LAN conditional, start supporting modular features 10 months ago
internal client/tailscale,cmd/k8s-operator,internal/client/tailscale: move VIP service client methods into internal control client 10 months ago
ipn ipn/ipnlocal, envknob: make it possible to configure the cert client to act in read-only mode (#15250) 9 months ago
jsondb all: update copyright and license headers 3 years ago
k8s-operator cmd/k8s-operator: reinstate HA Ingress reconciler (#14887) 10 months ago
kube ipn/{ipnlocal,store},kube/kubeclient: store TLS cert and key pair to a Secret in a single operation. (#15147) 9 months ago
licenses licenses: update license notices 9 months ago
log log/sockstatlog: don't block for more than 5s on shutdown 1 year ago
logpolicy logpolicy: expose MaxBufferSize and MaxUploadSize options (#14903) 10 months ago
logtail logpolicy: expose MaxBufferSize and MaxUploadSize options (#14903) 10 months ago
maths maths: add exponentially weighted moving average type 9 months ago
metrics metrics,syncs: add ShardedInt support to metrics.LabelMap 11 months ago
net net/netmon, wgengine/magicsock: be quieter with portmapper logs 9 months ago
omit cmd/tailscaled, ipn/conffile: support ec2 user-data config file 2 years ago
packages/deb go.mod: upgrade nfpm to v2 (#8786) 2 years ago
paths all: illumos/solaris userspace only support 11 months ago
portlist all: use Go 1.22 range-over-int 2 years ago
posture control/controlclient,posture,util/syspolicy: use predefined syspolicy keys instead of string literals 1 year ago
prober all: use new LocalAPI client package location 10 months ago
proxymap ipnlocal,proxymap,wgengine/netstack: add optional WhoIs/proxymap debug 1 year ago
release release/dist: clamp min / max version for synology package centre (#13857) 1 year ago
safesocket safesocket, version: fix safesocket_darwin behavior for cmd/tailscale (#15275) 9 months ago
safeweb go.mod: bump gorilla/csrf for security fix (#14822) 10 months ago
scripts scripts/installer.sh: explicitly chmod 0644 installed files (#15171) 9 months ago
sessionrecording sessionrecording: implement v2 recording endpoint support (#14105) 1 year ago
smallzstd all: use Go 1.22 range-over-int 2 years ago
ssh/tailssh ssh/tailssh: fix typo in forwardedEnviron method, add docs 9 months ago
syncs syncs: add ShardedInt expvar.Var type 12 months ago
tailcfg control/controlclient, ipn: add client audit logging (#14950) 9 months ago
taildrop taildrop: fix defer in loop (#13757) 1 year ago
tempfork tempfork/acme: pull in latest changes for Go 1.24 (#15062) 10 months ago
tka tka: truncate long rotation signature chains 1 year ago
tool tool/gocross: remove trimpath from test builds 1 year ago
tsconst cmd/tailscale/cli: support passing network lock keys via files 1 year ago
tsd control/controlclient, ipn: add client audit logging (#14950) 9 months ago
tsnet tsnet,wgengine: fix src to primary Tailscale IP for TCP dials 9 months ago
tstest wgengine/magicsock: use learned DERP route as send path of last resort 9 months ago
tstime all: use math/rand/v2 more 2 years ago
tsweb tsweb: add title to DebugHandler and helper registration methods 9 months ago
types all: statically enforce json/v2 interface satisfaction (#15154) 9 months ago
util util/eventbus: add basic throughput benchmarks (#15284) 9 months ago
version safesocket, version: fix safesocket_darwin behavior for cmd/tailscale (#15275) 9 months ago
wf wf/firewall: allow link-local multicast for permitted local routes when the killswitch is on on Windows 1 year ago
wgengine net/netmon, wgengine/magicsock: be quieter with portmapper logs 9 months ago
words words: append to the tail of the wordlists (#15278) 9 months ago
.gitattributes .: add .gitattributes entry to use Go hunk-header driver 4 years ago
.gitignore tstest/tailmac: add customized macOS virtualization tooling (#13146) 1 year ago
.golangci.yml .github: Bump golangci/golangci-lint-action from 6.3.1 to 6.5.0 (#15046) 9 months ago
ALPINE.txt Revert "Dockerfile: bump base alpine image (#14604)" (#14620) 11 months ago
AUTHORS Move Linux client & common packages into a public repo. 6 years ago
CODEOWNERS CODEOWNERS: add the start of an owners file 2 years ago
CODE_OF_CONDUCT.md Add a code of conduct. 6 years ago
Dockerfile go.toolchain.branch: update to Go 1.24 (#15016) 10 months ago
Dockerfile.base Revert "Dockerfile: bump base alpine image (#14604)" (#14620) 11 months ago
LICENSE all: update tools that manage copyright headers 3 years ago
Makefile go.mod: bump depaware, add --internal flag to stop hiding internal packages 10 months ago
PATENTS Move Linux client & common packages into a public repo. 6 years ago
README.md Update README to reference correct Commit Style URL 11 months ago
SECURITY.md Add a SECURITY.md for vulnerability reports. 6 years ago
VERSION.txt VERSION.txt: this is v1.81.0 (#14838) 10 months ago
api.md {api.md,publicapi}: remove old API docs (#13468) 1 year ago
assert_ts_toolchain_match.go tailscaleroot: panic if tailscale_go build tag but Go toolchain mismatch 1 year ago
build_dist.sh feature/capture: move packet capture to feature/*, out of iOS + CLI 10 months ago
build_docker.sh Makefile,./build_docker.sh: update kube operator image build target name (#14251) 1 year ago
flake.lock nix: update nix and use go 1.23 1 year ago
flake.nix gokrazy, various: use point versions of Go and update Nix deps 1 year ago
go.mod util/eventbus: initial implementation of an in-process event bus 9 months ago
go.mod.sri go.mod.sri: update SRI hash for go.mod changes 1 year ago
go.sum util/eventbus: initial implementation of an in-process event bus 9 months ago
go.toolchain.branch go.toolchain.branch: update to Go 1.24 (#15016) 10 months ago
go.toolchain.rev go.toolchain.rev: bump to go1.24.1 (#15209) 9 months ago
gomod_test.go go.mod: add test that replace directives aren't added in oss 2 years ago
header.txt cmd/k8s-operator: operator can create subnetrouter (#9505) 2 years ago
pkgdoc_test.go all: add test for package comments, fix, add comments as needed 1 year ago
pull-toolchain.sh pull-toolchain.sh: don't run update-flake.sh 3 years ago
shell.nix go.mod.sri: update SRI hash for go.mod changes 1 year ago
staticcheck.conf all: cleanup unused code, part 2 (#10670) 2 years ago
update-flake.sh Code Improvements (#11311) 2 years ago
version-embed.go Fix various linting, vet & static check issues 11 months ago
version_tailscale_test.go tailscaleroot: panic if tailscale_go build tag but Go toolchain mismatch 1 year ago
version_test.go go.mod,wgengine/netstack: bump gvisor 2 years ago

README.md

Tailscale

https://tailscale.com

Private WireGuard® networks made easy

Overview

This repository contains the majority of Tailscale's open source code. Notably, it includes the tailscaled daemon and the tailscale CLI tool. The tailscaled daemon runs on Linux, Windows, macOS, and to varying degrees on FreeBSD and OpenBSD. The Tailscale iOS and Android apps use this repo's code, but this repo doesn't contain the mobile GUI code.

Other Tailscale repos of note:

For background on which parts of Tailscale are open source and why, see https://tailscale.com/opensource/.

Using

We serve packages for a variety of distros and platforms at https://pkgs.tailscale.com.

Other clients

The macOS, iOS, and Windows clients use the code in this repository but additionally include small GUI wrappers. The GUI wrappers on non-open source platforms are themselves not open source.

Building

We always require the latest Go release, currently Go 1.23. (While we build releases with our Go fork, its use is not required.)

go install tailscale.com/cmd/tailscale{,d}

If you're packaging Tailscale for distribution, use build_dist.sh instead, to burn commit IDs and version info into the binaries:

./build_dist.sh tailscale.com/cmd/tailscale
./build_dist.sh tailscale.com/cmd/tailscaled

If your distro has conventions that preclude the use of build_dist.sh, please do the equivalent of what it does in your distro's way, so that bug reports contain useful version information.

Bugs

Please file any issues about this code or the hosted service on the issue tracker.

Contributing

PRs welcome! But please file bugs. Commit messages should reference bugs.

We require Developer Certificate of Origin Signed-off-by lines in commits.

See git log for our commit message style. It's basically the same as Go's style.

About Us

Tailscale is primarily developed by the people at https://github.com/orgs/tailscale/people. For other contributors, see:

WireGuard is a registered trademark of Jason A. Donenfeld.