基于WireGuard的VPN。免费支持最多20个节点。 https://tailscale.com/

Nick Khyl 01efddea01 docs/windows/policy: update ADMX/ADML policy definitions to include the new Always On setting 1 year ago
.bencher babd163aac bencher: add config to suppress failures on benchmark regressions. 4 years ago
.github 11cd98fab0 .github: Bump golangci/golangci-lint-action from 6.2.0 to 6.3.1 (#14963) 1 year ago
appc f1710f4a42 appc,ipn/ipnlocal: log DNS parsing errors in app connectors (#14607) 1 year ago
atomicfile fcf90260ce atomicfile: use ReplaceFile on Windows so that attributes and ACLs are preserved 1 year ago
chirp 71029cea2d all: update copyright and license headers 3 years ago
client 05ac21ebe4 all: use new LocalAPI client package location 1 year ago
clientupdate e19c01f5b3 clientupdate: refuse to update in tsnet binaries (#14911) 1 year ago
cmd f35c49d211 net/dns: update to illarion/gonotify/v3 to fix a panic 1 year ago
control 9706c9f4ff types/netmap,*: pass around UserProfiles as views (pointers) instead 1 year ago
derp 05ac21ebe4 all: use new LocalAPI client package location 1 year ago
disco 706e30d49e disco: correct noun for nacl box type in disco docs 2 years ago
docs 01efddea01 docs/windows/policy: update ADMX/ADML policy definitions to include the new Always On setting 1 year ago
doctor b9adbe2002 net/{interfaces,netmon}, all: merge net/interfaces package into net/netmon 1 year ago
drive cfda1ff709 cmd/viewer,all: consistently use "read-only" instead of "readonly" 1 year ago
envknob 66b2e9fd07 envknob/featureknob: allow use of exit node on unraid (#14754) 1 year ago
feature 68a66ee81b feature/capture: move packet capture to feature/*, out of iOS + CLI 1 year ago
gokrazy f572286bf9 gokrazy, various: use point versions of Go and update Nix deps 1 year ago
health bd9725c5f8 health: relax no-derp-home warnable to not fire if not in map poll 1 year ago
hostinfo 1562a6f2f2 feature/*: make Wake-on-LAN conditional, start supporting modular features 1 year ago
internal c6af5bbfe8 all: add test for package comments, fix, add comments as needed 1 year ago
ipn 9b32ba7f54 ipn/ipn{local,server}: move "staying alive in server mode" from ipnserver to LocalBackend 1 year ago
jsondb 71029cea2d all: update copyright and license headers 3 years ago
k8s-operator 5ef934b62d cmd/k8s-operator: reinstate HA Ingress reconciler (#14887) 1 year ago
kube b406f209c3 cmd/{k8s-operator,containerboot},kube: ensure egress ProxyGroup proxies don't terminate while cluster traffic is still routed to them (#14436) 1 year ago
licenses 2994dde535 licenses: update license notices 1 year ago
log 5d61d1c7b0 log/sockstatlog: don't block for more than 5s on shutdown 1 year ago
logpolicy 0b7087c401 logpolicy: expose MaxBufferSize and MaxUploadSize options (#14903) 1 year ago
logtail 0b7087c401 logpolicy: expose MaxBufferSize and MaxUploadSize options (#14903) 1 year ago
metrics 68b12a74ed metrics,syncs: add ShardedInt support to metrics.LabelMap 1 year ago
net f35c49d211 net/dns: update to illarion/gonotify/v3 to fix a panic 1 year ago
omit 1ea100e2e5 cmd/tailscaled, ipn/conffile: support ec2 user-data config file 1 year ago
packages eb6883bb5a go.mod: upgrade nfpm to v2 (#8786) 2 years ago
paths 9373a1b902 all: illumos/solaris userspace only support 1 year ago
portlist 7c1d6e35a5 all: use Go 1.22 range-over-int 1 year ago
posture 11d205f6c4 control/controlclient,posture,util/syspolicy: use predefined syspolicy keys instead of string literals 1 year ago
prober 05ac21ebe4 all: use new LocalAPI client package location 1 year ago
proxymap 9f9470fc10 ipnlocal,proxymap,wgengine/netstack: add optional WhoIs/proxymap debug 1 year ago
release e711ee5d22 release/dist: clamp min / max version for synology package centre (#13857) 1 year ago
safesocket 1bf4c6481a safesocket: add ability for Darwin clients to set explicit credentials (#14702) 1 year ago
safeweb 8bd04bdd3a go.mod: bump gorilla/csrf for security fix (#14822) 1 year ago
scripts 532e38bdc8 scripts/installer.sh: fix --yes argument for freebsd (#14958) 1 year ago
sessionrecording c2a7f17f2b sessionrecording: implement v2 recording endpoint support (#14105) 1 year ago
smallzstd 7c1d6e35a5 all: use Go 1.22 range-over-int 1 year ago
ssh 2f98197857 tempfork/sshtest/ssh: add fork of golang.org/x/crypto/ssh for testing only 1 year ago
syncs e8f1721147 syncs: add ShardedInt expvar.Var type 1 year ago
tailcfg 5a082fccec tailcfg: remove ancient UserProfiles.Roles field 1 year ago
taildrop 52ef27ab7c taildrop: fix defer in loop (#13757) 1 year ago
tempfork 2f98197857 tempfork/sshtest/ssh: add fork of golang.org/x/crypto/ssh for testing only 1 year ago
tka fd6686d81a tka: truncate long rotation signature chains 1 year ago
tool 0d76d7d21c tool/gocross: remove trimpath from test builds 1 year ago
tsconst 4c2e978f1e cmd/tailscale/cli: support passing network lock keys via files 1 year ago
tsd 0e0e53d3b3 util/usermetrics: make usermetrics non-global 1 year ago
tsnet 05ac21ebe4 all: use new LocalAPI client package location 1 year ago
tstest 05ac21ebe4 all: use new LocalAPI client package location 1 year ago
tstime 4a8cb1d9f3 all: use math/rand/v2 more 1 year ago
tsweb cb3b1a1dcf tsweb: add missing debug pprof endpoints 1 year ago
types 8b347060f8 types/bool: add Int (#14984) 1 year ago
util d832467461 client/tailscale,ipn/ipn{local,server},util/syspolicy: implement the AlwaysOn.OverrideWithReason policy setting 1 year ago
version 69b90742fe util/uniq,types/lazy,*: delete code that's now in Go std 1 year ago
wf d837e0252f wf/firewall: allow link-local multicast for permitted local routes when the killswitch is on on Windows 1 year ago
wgengine 7b3e5b5df3 wgengine/netstack: respond to service IPs in Linux tun mode 1 year ago
words 0c9ade46a4 words: Add scoville to scales.txt (#14084) 1 year ago
.gitattributes 1813c2a162 .: add .gitattributes entry to use Go hunk-header driver 4 years ago
.gitignore 8fad8c4b9b tstest/tailmac: add customized macOS virtualization tooling (#13146) 1 year ago
.golangci.yml 3f576fc4ca ci: run 'go vet' in golangci-lint; fix errors in tests 2 years ago
ALPINE.txt 377127c20c Revert "Dockerfile: bump base alpine image (#14604)" (#14620) 1 year ago
AUTHORS a8d8b8719a Move Linux client & common packages into a public repo. 6 years ago
CODEOWNERS 0913ec023b CODEOWNERS: add the start of an owners file 2 years ago
CODE_OF_CONDUCT.md 452b81d56b Add a code of conduct. 6 years ago
Dockerfile 377127c20c Revert "Dockerfile: bump base alpine image (#14604)" (#14620) 1 year ago
Dockerfile.base 377127c20c Revert "Dockerfile: bump base alpine image (#14604)" (#14620) 1 year ago
LICENSE 947c14793a all: update tools that manage copyright headers 3 years ago
Makefile 8c925899e1 go.mod: bump depaware, add --internal flag to stop hiding internal packages 1 year ago
PATENTS a8d8b8719a Move Linux client & common packages into a public repo. 6 years ago
README.md 60930d19c0 Update README to reference correct Commit Style URL 1 year ago
SECURITY.md e59605595e Add a SECURITY.md for vulnerability reports. 6 years ago
VERSION.txt 08dd4994d0 VERSION.txt: this is v1.81.0 (#14838) 1 year ago
api.md 124ff3b034 {api.md,publicapi}: remove old API docs (#13468) 1 year ago
assert_ts_toolchain_match.go 1005cbc1e4 tailscaleroot: panic if tailscale_go build tag but Go toolchain mismatch 1 year ago
build_dist.sh 68a66ee81b feature/capture: move packet capture to feature/*, out of iOS + CLI 1 year ago
build_docker.sh 44c8892c18 Makefile,./build_docker.sh: update kube operator image build target name (#14251) 1 year ago
flake.lock e93c160a39 nix: update nix and use go 1.23 1 year ago
flake.nix f572286bf9 gokrazy, various: use point versions of Go and update Nix deps 1 year ago
go.mod f35c49d211 net/dns: update to illarion/gonotify/v3 to fix a panic 1 year ago
go.mod.sri 4f2a2bfa42 go.mod.sri: update SRI hash for go.mod changes 1 year ago
go.sum f35c49d211 net/dns: update to illarion/gonotify/v3 to fix a panic 1 year ago
go.toolchain.branch 696711cc17 all: switch to and require Go 1.23 1 year ago
go.toolchain.rev 1047d11102 go.toolchain.rev: bump to Go 1.23.6 (#14976) 1 year ago
gomod_test.go aae1a28a2b go.mod: add test that replace directives aren't added in oss 2 years ago
header.txt 1a08ea5990 cmd/k8s-operator: operator can create subnetrouter (#9505) 2 years ago
pkgdoc_test.go c6af5bbfe8 all: add test for package comments, fix, add comments as needed 1 year ago
pull-toolchain.sh 0e4f2bdd0c pull-toolchain.sh: don't run update-flake.sh 3 years ago
shell.nix 4f2a2bfa42 go.mod.sri: update SRI hash for go.mod changes 1 year ago
staticcheck.conf 2716250ee8 all: cleanup unused code, part 2 (#10670) 2 years ago
update-flake.sh 50a570a83f Code Improvements (#11311) 2 years ago
version-embed.go 36ea792f06 Fix various linting, vet & static check issues 1 year ago
version_tailscale_test.go 1005cbc1e4 tailscaleroot: panic if tailscale_go build tag but Go toolchain mismatch 1 year ago
version_test.go 7e3bcd297e 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:

Legal

WireGuard is a registered trademark of Jason A. Donenfeld.