<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
  <channel>
    <title>Systemd on OHTLY Blog</title>
    <link>https://blog.ohtly.com/tags/systemd/</link>
    <description>Recent content in Systemd on OHTLY Blog</description>
    <generator>Hugo</generator>
    <language>zh-cn</language>
    <lastBuildDate>Tue, 23 Jun 2026 22:29:46 +0800</lastBuildDate>
    <atom:link href="https://blog.ohtly.com/tags/systemd/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>NetBird 客户端自动重连的 systemd 实现</title>
      <link>https://blog.ohtly.com/posts/2026-06-23-netbird-watchdog/</link>
      <pubDate>Tue, 23 Jun 2026 22:29:46 +0800</pubDate>
      <guid>https://blog.ohtly.com/posts/2026-06-23-netbird-watchdog/</guid>
      <description>&lt;p&gt;NetBird 客户端运行中偶遇 management server 不稳定时会断开连接，且不会自动恢复。需要手动 &lt;code&gt;netbird down &amp;amp;&amp;amp; netbird up&lt;/code&gt; 才能重连。&lt;/p&gt;&#xA;&lt;h2 id=&#34;问题特征&#34;&gt;&#xA;  问题特征&#xA;  &lt;a class=&#34;heading-link&#34; href=&#34;#%e9%97%ae%e9%a2%98%e7%89%b9%e5%be%81&#34;&gt;&#xA;    &lt;i class=&#34;fa-solid fa-link&#34; aria-hidden=&#34;true&#34; title=&#34;链接到标题&#34;&gt;&lt;/i&gt;&#xA;    &lt;span class=&#34;sr-only&#34;&gt;链接到标题&lt;/span&gt;&#xA;  &lt;/a&gt;&#xA;&lt;/h2&gt;&#xA;&lt;p&gt;日志如下：&lt;/p&gt;&#xA;&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;WARN management/client/grpc.go: job stream disconnected, will retry silently.&#xA;  Reason: unexpected HTTP status code received from server: 504 (Gateway Timeout)&#xA;ERRO management/client/grpc.go: stream receive error&#xA;INFO engine.go: stopped Netbird Engine&#xA;INFO server.go: service is down&#xA;&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;daemon 进程存活，但内部引擎已永久退出。只有手动重连才能恢复。&lt;/p&gt;&#xA;&lt;h2 id=&#34;原因&#34;&gt;&#xA;  原因&#xA;  &lt;a class=&#34;heading-link&#34; href=&#34;#%e5%8e%9f%e5%9b%a0&#34;&gt;&#xA;    &lt;i class=&#34;fa-solid fa-link&#34; aria-hidden=&#34;true&#34; title=&#34;链接到标题&#34;&gt;&lt;/i&gt;&#xA;    &lt;span class=&#34;sr-only&#34;&gt;链接到标题&lt;/span&gt;&#xA;  &lt;/a&gt;&#xA;&lt;/h2&gt;&#xA;&lt;p&gt;NetBird 客户端内部有一个 backoff 重试循环：&lt;/p&gt;&#xA;&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-go&#34; data-lang=&#34;go&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#75715e&#34;&gt;// 简化示意&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#a6e22e&#34;&gt;backoff&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;Retry&lt;/span&gt;(&lt;span style=&#34;color:#66d9ef&#34;&gt;func&lt;/span&gt;() &lt;span style=&#34;color:#66d9ef&#34;&gt;error&lt;/span&gt; {&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    &lt;span style=&#34;color:#66d9ef&#34;&gt;return&lt;/span&gt; &lt;span style=&#34;color:#a6e22e&#34;&gt;s&lt;/span&gt;.&lt;span style=&#34;color:#a6e22e&#34;&gt;connect&lt;/span&gt;(&lt;span style=&#34;color:#a6e22e&#34;&gt;ctx&lt;/span&gt;, &lt;span style=&#34;color:#f92672&#34;&gt;...&lt;/span&gt;)&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;}, &lt;span style=&#34;color:#a6e22e&#34;&gt;backOff&lt;/span&gt;)&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;重试耗尽后 &lt;code&gt;giveUpChan&lt;/code&gt; 关闭，引擎永久退出。此后即使网络恢复，客户端也不会再次尝试连接。&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
