View Source Tailscale.Supervisor (Tailscale v0.1.0)
Starting the Supervisor starts the ChangeServer and the Cluster servers.
To prevent starting the Cluster, pass [start_cluster: false]
.
By default, the ChangeServer re-runs the tailscale status --json
command every 30 seconds,
and then diffs the output. To change the refresh interval,
pass [refresh_interval: integer_in_milliseconds]
.
Summary
Functions
Returns a specification to start this module under a supervisor.
Starts the Tailscale Supervisor.
Functions
Returns a specification to start this module under a supervisor.
See Supervisor
.
Starts the Tailscale Supervisor.
Tailscale.Supervisor starts the Tailscale.ChangeServer and Tailscale.Cluster GenServers.
You can pass options to control the refresh_interval
of the ChangeServer, and the options for the Cluster in the opts of the Supervisor.
Options
:refresh_interval
- The interval in milliseconds to refresh the Tailscale status. Defaults to30_000
(30 seconds).:tag | :tags
- Either a tag string or a list of tags (without the "tag:" prefix that Tailscale adds). Defaults to["beam"]
.:match_tags
- Can be:any | :all
. Defaults to:any
.:start_cluster
- Whether to start the Tailscale Cluster. Defaults totrue
.:start_distribution
- Whether to start the Tailscale Distribution. Defaults totrue
. If you passfalse
here, you would have to start the distribution yourself but ensure that the format is<tailscale_node_name>@<tailscale_node_ip>
. For now, this library does not support automatically connecting to nodes named differently.