<?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>Dnsmasq on 怠惰技術ブログ</title>
    <link>https://techblog.wasutech.dev/tags/dnsmasq/</link>
    <description>Recent content in Dnsmasq on 怠惰技術ブログ</description>
    <generator>Hugo -- 0.147.7</generator>
    <language>ja</language>
    <lastBuildDate>Sat, 18 Apr 2026 19:00:00 +0900</lastBuildDate>
    <atom:link href="https://techblog.wasutech.dev/tags/dnsmasq/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>自宅NWをKeepalivedとdnsmasqで作り直した話</title>
      <link>https://techblog.wasutech.dev/posts/home-nw-redundancy/</link>
      <pubDate>Sat, 18 Apr 2026 19:00:00 +0900</pubDate>
      <guid>https://techblog.wasutech.dev/posts/home-nw-redundancy/</guid>
      <description>&lt;h2 id=&#34;背景&#34;&gt;背景&lt;/h2&gt;
&lt;p&gt;自宅のネットワーク構成が辛かった。&lt;/p&gt;
&lt;p&gt;具体的には以下の問題があった。&lt;/p&gt;
&lt;ul&gt;
&lt;li&gt;ルータが1台構成で、死んだら自宅NW全滅&lt;/li&gt;
&lt;li&gt;メンテナンスで定期的に落としたいとかあっても、コストが大きい&lt;/li&gt;
&lt;li&gt;DNS/DHCPがルータに同居していて、役割が混在している&lt;/li&gt;
&lt;li&gt;WireGuardで外部接続していたが、外部からの入り方がだるい。&lt;/li&gt;
&lt;/ul&gt;
&lt;p&gt;特に「冗長化したい」という気持ちは何年も前からあったが、DNSとDHCPの同期という難問の前に何度も挫折してきた。&lt;/p&gt;
&lt;p&gt;結論からいえば、DNS,DHCPの冗長化は諦めた。&lt;/p&gt;
&lt;p&gt;諦めた上で出口のルータとDNS、DHCPは役割を分けた上で出口のルータとWIFIルータのみ冗長化を実施した。&lt;/p&gt;
&lt;h2 id=&#34;設計方針&#34;&gt;設計方針&lt;/h2&gt;
&lt;p&gt;過去の失敗から学んだ一番の教訓はやはり「DNS/DHCPの冗長化は難しい」ということだ。&lt;/p&gt;
&lt;p&gt;理論上可能ではあるが、私は万年初級自宅インフラエンジニアでいつまで経ってもできる目処が立たない。&lt;/p&gt;
&lt;p&gt;それでいて、生成AIという過ぎた兵器を持ってしても、この問題は解決しなかったので、難しいというよりは不可能とした。&lt;/p&gt;
&lt;p&gt;2台のサーバでDHCPを冗長化しようとすると、リースの同期問題が必ず発生する。同期ツールを使ったりしたが、どうしても同期しきれなかった。&lt;/p&gt;
&lt;p&gt;そこで今回は思い切って諦めた上で役割を分離する方針にした。&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;ルータ（冗長化） → GWとTailscaleだけ担当
AP             → hostapdのみ
DNS/DHCP       → 専用機1台に集約（冗長化しない）
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;DNSとDHCPは単一障害点になるが、自宅ラボであれば許容範囲だと判断した。&lt;/p&gt;
&lt;p&gt;&lt;strong&gt;てかどうしようもない。&lt;/strong&gt;&lt;/p&gt;
&lt;h2 id=&#34;構成&#34;&gt;構成&lt;/h2&gt;
&lt;p&gt;使用機材はすべてRaspberry Pi。封印していたタワーからも引っ張り出した。&lt;/p&gt;
&lt;table&gt;
  &lt;thead&gt;
      &lt;tr&gt;
          &lt;th&gt;ホスト&lt;/th&gt;
          &lt;th&gt;役割&lt;/th&gt;
      &lt;/tr&gt;
  &lt;/thead&gt;
  &lt;tbody&gt;
      &lt;tr&gt;
          &lt;td&gt;ルータA (MASTER)&lt;/td&gt;
          &lt;td&gt;Keepalived + Tailscale&lt;/td&gt;
      &lt;/tr&gt;
      &lt;tr&gt;
          &lt;td&gt;ルータB (BACKUP)&lt;/td&gt;
          &lt;td&gt;Keepalived + Tailscale&lt;/td&gt;
      &lt;/tr&gt;
      &lt;tr&gt;
          &lt;td&gt;DNS/DHCP機&lt;/td&gt;
          &lt;td&gt;dnsmasq専用&lt;/td&gt;
      &lt;/tr&gt;
      &lt;tr&gt;
          &lt;td&gt;AP x2&lt;/td&gt;
          &lt;td&gt;WIFI冗長化&lt;/td&gt;
      &lt;/tr&gt;
  &lt;/tbody&gt;
&lt;/table&gt;
&lt;p&gt;ネットワークセグメントはひとつ。VIPをデフォルトゲートウェイ兼DNSとして各クライアントに配布する。&lt;/p&gt;
&lt;h2 id=&#34;keepalivedの設定&#34;&gt;Keepalivedの設定&lt;/h2&gt;
&lt;p&gt;まずルータ2台にKeepalivedを入れる。&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-bash&#34; data-lang=&#34;bash&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;sudo apt install -y keepalived
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;MASTER側の設定:&lt;/p&gt;
&lt;pre tabindex=&#34;0&#34;&gt;&lt;code&gt;vrrp_instance VI_1 {
    state MASTER
    interface lan-if
    virtual_router_id 51
    priority 100
    advert_int 1
    authentication {
        auth_type PASS
        auth_pass xxxxxxxx
    }
    virtual_ipaddress {
        192.168.xx.1/24
    }
}
&lt;/code&gt;&lt;/pre&gt;&lt;p&gt;BACKUP側は &lt;code&gt;state BACKUP&lt;/code&gt; と &lt;code&gt;priority 90&lt;/code&gt; に変えるだけ。シンプルだ。&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
