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
Tom Proctor f421907c38
all-kube: create Tailscale Service for HA kube-apiserver ProxyGroup (#16572)
Adds a new reconciler for ProxyGroups of type kube-apiserver that will
provision a Tailscale Service for each replica to advertise. Adds two
new condition types to the ProxyGroup, TailscaleServiceValid and
TailscaleServiceConfigured, to post updates on the state of that
reconciler in a way that's consistent with the service-pg reconciler.
The created Tailscale Service name is configurable via a new ProxyGroup
field spec.kubeAPISserver.ServiceName, which expects a string of the
form "svc:<dns-label>".

Lots of supporting changes were needed to implement this in a way that's
consistent with other operator workflows, including:

* Pulled containerboot's ensureServicesUnadvertised and certManager into
  kube/ libraries to be shared with k8s-proxy. Use those in k8s-proxy to
  aid Service cert sharing between replicas and graceful Service shutdown.
* For certManager, add an initial wait to the cert loop to wait until
  the domain appears in the devices's netmap to avoid a guaranteed error
  on the first issue attempt when it's quick to start.
* Made several methods in ingress-for-pg.go and svc-for-pg.go into
  functions to share with the new reconciler
* Added a Resource struct to the owner refs stored in Tailscale Service
  annotations to be able to distinguish between Ingress- and ProxyGroup-
  based Services that need cleaning up in the Tailscale API.
* Added a ListVIPServices method to the internal tailscale client to aid
  cleaning up orphaned Services
* Support for reading config from a kube Secret, and partial support for
  config reloading, to prevent us having to force Pod restarts when
  config changes.
* Fixed up the zap logger so it's possible to set debug log level.

Updates #13358

Change-Id: Ia9607441157dd91fb9b6ecbc318eecbef446e116
Signed-off-by: Tom Proctor <tomhjp@users.noreply.github.com>
6 months ago
.bencher bencher: add config to suppress failures on benchmark regressions. 4 years ago
.github .github: Bump github/codeql-action from 3.29.1 to 3.29.2 (#16480) 6 months ago
appc appc: fix a deadlock in route advertisements (#15031) 11 months ago
atomicfile ipn/store: automatically migrate between plaintext and encrypted state (#16318) 6 months ago
chirp scripts/check_license_headers.sh: delete, rewrite as a Go test 7 months ago
client client/systray: look for ubuntu gnome 6 months ago
clientupdate clientupdate: fix MSI exit code handling, preserve MSI and updater logs on Windows 9 months ago
cmd all-kube: create Tailscale Service for HA kube-apiserver ProxyGroup (#16572) 6 months ago
control tstest/tlstest: simplify, don't even bake in any keys 7 months ago
derp derp/derphttp: fix DERP TLS client server name inclusion in URL form 6 months ago
disco disco,net/udprelay,wgengine/magicsock: support relay re-binding (#16388) 6 months ago
docs docs/windows/policy: add ExitNode.AllowOverride as an option to ExitNodeID policy 6 months ago
doctor all: remove non-applicable "linux" deps on Android 8 months ago
drive drive,ipn/ipnlocal: calculate peer taildrive URLs on-demand 6 months ago
envknob envknob/featureknob: restore SSH and exit-node capability for Home Assistant (#16263) 6 months ago
feature feature/tpm: try opening /dev/tpmrm0 before /tmp/tpm0 on Linux (#16600) 6 months ago
gokrazy gokrazy/natlab: update gokrazy, wire up natlab tests to GitHub CI 10 months ago
health tailcfg: send health update if DisplayMessage URL changes 6 months ago
hostinfo hostinfo, ipnlocal: add optional os-specific callback for querying the hostname (#15647) 9 months ago
internal all-kube: create Tailscale Service for HA kube-apiserver ProxyGroup (#16572) 6 months ago
ipn all-kube: create Tailscale Service for HA kube-apiserver ProxyGroup (#16572) 6 months ago
jsondb all: update copyright and license headers 3 years ago
k8s-operator all-kube: create Tailscale Service for HA kube-apiserver ProxyGroup (#16572) 6 months ago
kube all-kube: create Tailscale Service for HA kube-apiserver ProxyGroup (#16572) 6 months ago
licenses licenses: update license notices 9 months ago
log log/sockstatlog: don't block for more than 5s on shutdown 2 years ago
logpolicy all: detect JetKVM and specialize a handful of things for it 6 months ago
logtail logtail: remove unneeded IP redaction code 8 months ago
maths maths: add exponentially weighted moving average type 10 months ago
metrics metrics,syncs: add ShardedInt support to metrics.LabelMap 1 year ago
net net/udprelay: log socket read errors (#16573) 6 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: detect JetKVM and specialize a handful of things for it 6 months ago
portlist portlist: add Plan 9 support 9 months ago
posture posture: propagate serial number from MDM on Android 7 months ago
prober prober: speed up TestCRL ~450x by baking in some test keys 7 months ago
proxymap ipnlocal,proxymap,wgengine/netstack: add optional WhoIs/proxymap debug 1 year ago
release release/dist/qnap: upgrade to Ubuntu 24.04 Docker image 6 months ago
safesocket all: remove non-applicable "linux" deps on Android 8 months ago
safeweb safeweb: Set Cross-Origin-Opener-Policy for browser requests (#15936) 8 months ago
scripts scripts/check_license_headers.sh: delete, rewrite as a Go test 7 months ago
sessionrecording k8s-operator,sessionrecording: fixing race condition between resize (#16454) 6 months ago
smallzstd all: use Go 1.22 range-over-int 2 years ago
ssh/tailssh ssh/tailssh: fix path of "true" on Darwin (#16569) 6 months ago
syncs syncs: fix AtomicValue.CompareAndSwap (#16137) 7 months ago
tailcfg cmd/tailscale/cli: Add service flag to serve command (#16191) 6 months ago
tempfork tempfork/acme: update to latest version (#15543) 9 months ago
tka tka: reject removal of the last signing key 7 months ago
tool tool/gocross: remove GOROOT to ensure correct toolchain use 6 months ago
tsconsensus tsconsensus: skipping slow non-applicable tests on Windows for now 7 months ago
tsconst cmd/tailscale/cli: support passing network lock keys via files 1 year ago
tsd all: update the tsd.System constructor name (#15372) 9 months ago
tsnet cmd/tailscale/cli: add a risk message about rp_filter 7 months ago
tstest ipn/store: automatically migrate between plaintext and encrypted state (#16318) 6 months ago
tstime tstime: add GoDuration which JSON serializes with time.Duration.String (#15726) 9 months ago
tsweb scripts/check_license_headers.sh: delete, rewrite as a Go test 7 months ago
types types/geo: add geo.Point and its associated units (#16583) 6 months ago
util client/local,cmd/tailscale/cli,ipn/localapi: expose eventbus graph (#16597) 6 months ago
version cmd/tailscale/cli: add "configure jetkvm" subcommand 6 months ago
wf wf/firewall: allow link-local multicast for permitted local routes when the killswitch is on on Windows 1 year ago
wgengine wgengine/magicsock: add peer relay metrics (#16582) 6 months ago
words words: C what I did there? 9 months ago
.gitattributes .: add .gitattributes entry to use Go hunk-header driver 4 years ago
.gitignore cmd/k8s-operator: Add NOTES.txt to Helm chart (#16364) 6 months ago
.golangci.yml .github: Bump golangci/golangci-lint-action from 6.5.0 to 7.0.0 (#15476) 9 months ago
ALPINE.txt Bump Alpine, link iptables back to legacy (#15428) 10 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 Dockerfile,build_docker.sh: add a note on how to build local images (#16471) 6 months ago
Dockerfile.base Bump Alpine, link iptables back to legacy (#15428) 10 months ago
LICENSE all: update tools that manage copyright headers 3 years ago
Makefile ssh/tailssh: fix path of "true" on Darwin (#16569) 6 months ago
PATENTS Move Linux client & common packages into a public repo. 6 years ago
README.md commit-messages.md: make our git commit message style guide public 9 months ago
SECURITY.md Add a SECURITY.md for vulnerability reports. 6 years ago
VERSION.txt VERSION.txt: this is v1.85.0 (#16042) 8 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 hostinfo,tailcfg: report TPM availability on windows/linux (#15831) 8 months ago
build_docker.sh cmd/{k8s-operator,k8s-proxy}: add kube-apiserver ProxyGroup type (#16266) 6 months ago
flake.lock nix: update nix and use go 1.24 (#15578) 9 months ago
flake.nix nix: update nix and use go 1.24 (#15578) 9 months ago
go.mod go.mod: bump wireguard-go (#16578) 6 months ago
go.mod.sri nix: update nix and use go 1.24 (#15578) 9 months ago
go.sum go.mod: bump wireguard-go (#16578) 6 months ago
go.toolchain.branch go.toolchain.branch: update to Go 1.24 (#15016) 11 months ago
go.toolchain.rev go.toolchain.rev: bump to go 1.24.4 (#16230) 7 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
license_test.go scripts/check_license_headers.sh: delete, rewrite as a Go test 7 months ago
pkgdoc_test.go all: skip looking for package comments in .git/ repository (#15384) 10 months ago
pull-toolchain.sh pull-toolchain.sh: don't run update-flake.sh 3 years ago
shell.nix nix: update nix and use go 1.24 (#15578) 9 months 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 1 year ago
version_tailscale_test.go tailscaleroot: panic if tailscale_go build tag but Go toolchain mismatch 1 year ago
version_test.go .github/workflows: test that ./go/tool version matches go mod version 7 months 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 commit-messages.md (or skim git log) for our commit message 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.