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
Brad Fitzpatrick 036f70b7b4 portlist: refactor, introduce OS-specific types
Add an osImpl interface that can be stateful and thus more efficient
between calls. It will later be implemented by all OSes but for now
this change only adds a Linux implementation.

Remove Port.inode. It was only used by Linux and moves into its osImpl.

Don't reopen /proc/net/* files on each run. Turns out you can just
keep then open and seek to the beginning and reread and the contents
are fresh.

    name                    old time/op    new time/op    delta
    GetListIncremental-8    7.29ms ± 2%    6.53ms ± 1%  -10.50%  (p=0.000 n=9+9)

    name                   old alloc/op   new alloc/op   delta
    GetListIncremental-8    1.30kB ±13%    0.70kB ± 5%  -46.38%  (p=0.000 n=9+10)

    name                  old allocs/op  new allocs/op  delta
    GetListIncremental-8      33.2 ±11%      18.0 ± 0%  -45.82%  (p=0.000 n=9+10)

Updates #5958

Change-Id: I4be83463cbd23c2e2fa5d0bdf38560004f53401b
Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>
2 years ago
.bencher bencher: add config to suppress failures on benchmark regressions. 3 years ago
.github .github: run CI on release branches 2 years ago
atomicfile refactor: move from io/ioutil to io and os packages 2 years ago
chirp all: fix spelling mistakes 2 years ago
client/tailscale tsnet,client/tailscale: add APIClient which runs API over Noise. 2 years ago
cmd portlist: remove unix.Readlink allocs on Linux 2 years ago
control net/wsconn: add back custom wrapper for turning a websocket.Conn into a net.Conn 2 years ago
derp net/wsconn: add back custom wrapper for turning a websocket.Conn into a net.Conn 2 years ago
disco all: fix spelling mistakes 2 years ago
docs docs/k8s: [proxy] fix sysctl command 2 years ago
doctor doctor: add package for running in-depth healthchecks; use in bugreport (#5413) 2 years ago
envknob ipn/ipnlocal: filter peers with bad signatures when tka is enabled 2 years ago
health envknob, health: support Synology, show parse errors in status 2 years ago
hostinfo refactor: move from io/ioutil to io and os packages 2 years ago
internal/tooldeps .github/workflows: add gofmt (goimports) check 2 years ago
ipn portlist: unexport all Poller fields, removing unused one, rework channels 2 years ago
jsondb jsondb: small package to load/save JSON DBs. 2 years ago
kube kube: handle 201 as a valid status code. 2 years ago
licenses licenses: update android licenses 2 years ago
log refactor: move from io/ioutil to io and os packages 2 years ago
logpolicy all: fix spelling mistakes 2 years ago
logtail logtail: default to 2s log flush delay on all platforms 2 years ago
metrics all: use testingutil.MinAllocsPerRun 3 years ago
net net/dnscache: Handle 4-in-6 addresses in DNS responses 2 years ago
packages/deb refactor: move from io/ioutil to io and os packages 2 years ago
paths all: fix spelling mistakes 2 years ago
portlist portlist: refactor, introduce OS-specific types 2 years ago
prober prober: optionally spread probes over time 2 years ago
safesocket refactor: move from io/ioutil to io and os packages 2 years ago
scripts scripts/installer.sh: add OSMC 2 years ago
smallzstd refactor: move from io/ioutil to io and os packages 2 years ago
ssh/tailssh ssh/tailssh: add password-forcing workaround for buggy SSH clients 2 years ago
syncs syncs: add generic AtomicValue 2 years ago
tailcfg net/netcheck, tailcfg: track whether OS supports IPv6 2 years ago
tempfork ssh/tailssh: add support for sending multiple banners 2 years ago
tka tka: make rotation signatures use nested keyID 2 years ago
tool .github/workflows: add tsconnect static build to wasm GitHub action 2 years ago
tsconst net/interfaces/windows: update Tailscale interface detection logic to 3 years ago
tsnet tsnet,client/tailscale: add APIClient which runs API over Noise. 2 years ago
tstest tstest/natlab: add Firewall.Reset method to drop firewall state 2 years ago
tstime tstime: add ParseDuration helper function 2 years ago
tsweb tsweb: sort top-level expvars after removing type prefixes 2 years ago
types types/key: add ChallengePublic, ChallengePrivate, NewChallenge 2 years ago
util cmd/tsconnect: pre-compress main.wasm when building the NPM package 2 years ago
version ipn/localapi: send Tailscale version in ACME User-Agent (#5499) 2 years ago
wf all: fix spelling mistakes 2 years ago
wgengine net/netcheck, tailcfg: track whether OS supports IPv6 2 years ago
words words: even the odds with something that reminds you of vacation (#6025) 2 years ago
.gitattributes .: add .gitattributes entry to use Go hunk-header driver 3 years ago
.gitignore Makefile: update make spk target to use the new go spk builder 3 years ago
ALPINE.txt Docker: add ALPINE.txt to manage alpine versions 2 years ago
AUTHORS Move Linux client & common packages into a public repo. 5 years ago
CODE_OF_CONDUCT.md Add a code of conduct. 5 years ago
Dockerfile Update Dockerfile to use golang:1.19-alpine 2 years ago
Dockerfile.base Dockerfile: bump alpine to 3.16 2 years ago
LICENSE LICENSE: Reformat for Github 4 years ago
Makefile Makefile: add publishdevimage target 2 years ago
PATENTS Move Linux client & common packages into a public repo. 5 years ago
README.md all: require Go 1.19 2 years ago
SECURITY.md Add a SECURITY.md for vulnerability reports. 5 years ago
VERSION.txt VERSION.txt: this is 1.33. 2 years ago
api.md api.md: add expirySeconds as parameter to post Tailnet keys 2 years ago
build_dist.sh build_dist.sh: add --box and --extra-small flag to produce smaller and boxed binaries 2 years ago
build_docker.sh Dockerfile: bump alpine to 3.16 2 years ago
go.mod prober: expand certificate verification logic in the TLS prober 2 years ago
go.sum ssh/tailssh: add password-forcing workaround for buggy SSH clients 2 years ago
go.toolchain.branch go.toolchain.rev: switch to Go 1.19rc2+ 2 years ago
go.toolchain.rev go.toolchain.rev: update to Go 1.19.2 2 years ago
pull-toolchain.sh go.toolchain.rev: add update script 3 years ago
shell.nix shell.nix: update Go toolchain to 1.19 2 years ago
staticcheck.conf staticcheck.conf: remove unnecessary warning 3 years ago
version-embed.go Docker: add ALPINE.txt to manage alpine versions 2 years ago
version_test.go Dockerfile: add test that build-env Alpine version matches go.mod 2 years ago

README.md

Tailscale

https://tailscale.com

Private WireGuard® networks made easy

Overview

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

The Android app is at https://github.com/tailscale/tailscale-android

The Synology package is at https://github.com/tailscale/tailscale-synology

Using

We serve packages for a variety of distros 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 that are not open source.

Building

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.

We require the latest Go release, currently Go 1.19.

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.

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.