<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:content="http://purl.org/rss/1.0/modules/content/">
  <channel>
    <title>开源 on Ops FreeEdge</title>
    <link>https://ops.freeedge.uk/tags/%E5%BC%80%E6%BA%90/</link>
    <description>Recent content in 开源 on Ops FreeEdge</description>
    <generator>Hugo</generator>
    <language>en-us</language>
    <lastBuildDate>Fri, 03 Apr 2026 23:00:00 +0000</lastBuildDate>
    <atom:link href="https://ops.freeedge.uk/tags/%E5%BC%80%E6%BA%90/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>Headscale vs Tailscale 托管版：自托管权衡与运营成本深度对比</title>
      <link>https://ops.freeedge.uk/posts/headscale-vs-tailscale/</link>
      <pubDate>Fri, 03 Apr 2026 23:00:00 +0000</pubDate>
      <guid>https://ops.freeedge.uk/posts/headscale-vs-tailscale/</guid>
      <description>&lt;h1 id=&#34;headscale-vs-tailscale-托管版自托管权衡与运营成本深度对比&#34;&gt;Headscale vs Tailscale 托管版：自托管权衡与运营成本深度对比&lt;/h1&gt;
&lt;h2 id=&#34;引言&#34;&gt;引言&lt;/h2&gt;
&lt;p&gt;在现代网络架构中，Tailscale 以其基于 WireGuard 的零配置 VPN 解决方案脱颖而出。它利用 NAT 穿越技术和 DERP（Detour Encrypted Routing Protocol）中继，实现设备间的 P2P 连接。自托管开源实现 Headscale 作为 Tailscale 控制服务器（Coordination Server）的替代品，提供完全控制权，但带来了运维负担。本文深入剖析 Headscale 的架构、与 Tailscale 托管版的对比、功能对等性、运营成本、迁移路径，并为不同团队规模给出推荐。&lt;/p&gt;
&lt;h2 id=&#34;headscale-架构剖析&#34;&gt;Headscale 架构剖析&lt;/h2&gt;
&lt;h3 id=&#34;协调服务器coordination-server&#34;&gt;协调服务器（Coordination Server）&lt;/h3&gt;
&lt;p&gt;Headscale 是 Tailscale 控制平面（Control Plane）的自托管实现，主要负责节点注册、公钥交换、IP 地址分配、ACL（Access Control List）策略执行和路由管理。它使用 Go 语言编写，支持单一 tailnet（Tailscale 网络），适合个人或小型团队。&lt;/p&gt;
&lt;p&gt;核心组件包括：&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;&lt;strong&gt;节点注册&lt;/strong&gt;：支持 Web 认证、预认证密钥（Pre-auth Keys）。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;数据库&lt;/strong&gt;：SQLite、PostgreSQL 或 MySQL 存储节点状态、用户和密钥。&lt;/li&gt;
&lt;li&gt;&lt;strong&gt;API 服务&lt;/strong&gt;：gRPC 和 HTTP 接口，用于客户端通信和 CLI 操作。&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;示例配置文件 &lt;code&gt;config.yaml&lt;/code&gt;：&lt;/p&gt;
&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#f8f8f2;background-color:#272822;-moz-tab-size:4;-o-tab-size:4;tab-size:4;&#34;&gt;&lt;code class=&#34;language-yaml&#34; data-lang=&#34;yaml&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;server_url&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;https://headscale.example.com:8080&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;listen_addr&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;0.0.0.0&lt;/span&gt;:&lt;span style=&#34;color:#ae81ff&#34;&gt;8080&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;private_key_path&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;/var/lib/headscale/private.key&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;noise&lt;/span&gt;:
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  &lt;span style=&#34;color:#f92672&#34;&gt;private_key_path&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;/var/lib/headscale/noise_private.key&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;db_type&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;sqlite3&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;db_path&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;/var/lib/headscale/db.sqlite&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;dns&lt;/span&gt;:
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  &lt;span style=&#34;color:#f92672&#34;&gt;magic_dns&lt;/span&gt;: &lt;span style=&#34;color:#66d9ef&#34;&gt;true&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  &lt;span style=&#34;color:#f92672&#34;&gt;base_domain&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;example.com&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  &lt;span style=&#34;color:#f92672&#34;&gt;nameservers&lt;/span&gt;:
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    - &lt;span style=&#34;color:#ae81ff&#34;&gt;1.1.1.1&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;acl_policy_path&lt;/span&gt;: &lt;span style=&#34;color:#ae81ff&#34;&gt;/etc/headscale/acl.hujson&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#f92672&#34;&gt;derp&lt;/span&gt;:
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;  &lt;span style=&#34;color:#f92672&#34;&gt;urls&lt;/span&gt;:
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    - &lt;span style=&#34;color:#ae81ff&#34;&gt;https://controlplane.tailscale.com/derpmap/default&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;h3 id=&#34;derp-中继服务器替换&#34;&gt;DERP 中继服务器替换&lt;/h3&gt;
&lt;p&gt;Tailscale 使用 DERP 服务器作为最后手段中继流量，当 P2P 失败时介入。Headscale 支持嵌入式 DERP 服务器，或指向 Tailscale 的公共 DERP 地图。但为完全自托管，可部署自定义 DERP：&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
