<?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>Homelab on 怠惰技術ブログ</title>
    <link>https://techblog.wasutech.dev/tags/homelab/</link>
    <description>Recent content in Homelab 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/homelab/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>
    <item>
      <title>AdGuard HomeをProxmox LXCに立ててTailscale経由でDNSブロックする</title>
      <link>https://techblog.wasutech.dev/posts/tailscale-proxmox-adguard/</link>
      <pubDate>Mon, 06 Apr 2026 07:00:00 +0900</pubDate>
      <guid>https://techblog.wasutech.dev/posts/tailscale-proxmox-adguard/</guid>
      <description>&lt;h2 id=&#34;概要&#34;&gt;概要&lt;/h2&gt;
&lt;p&gt;はてな匿名ダイアリーとウーバーイーツをインフラレベルで封鎖したかった。
AdGuard HomeをProxmox LXCに立てて、Tailscale経由でDNSブロックする構成を作った。&lt;/p&gt;
&lt;h2 id=&#34;環境&#34;&gt;環境&lt;/h2&gt;
&lt;ul&gt;
&lt;li&gt;Proxmox VE&lt;/li&gt;
&lt;li&gt;Tailscale導入済み&lt;/li&gt;
&lt;li&gt;AdGuard Home v0.108.0&lt;/li&gt;
&lt;/ul&gt;
&lt;h2 id=&#34;手順&#34;&gt;手順&lt;/h2&gt;
&lt;h3 id=&#34;1-adguard-home-lxcをスクリプト一発で作成&#34;&gt;1. AdGuard Home LXCをスクリプト一発で作成&lt;/h3&gt;
&lt;p&gt;Proxmoxのノードシェルで以下を実行する。&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;bash -c &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;&lt;/span&gt;&lt;span style=&#34;color:#66d9ef&#34;&gt;$(&lt;/span&gt;curl -fsSL https://raw.githubusercontent.com/community-scripts/ProxmoxVE/main/ct/adguard.sh&lt;span style=&#34;color:#66d9ef&#34;&gt;)&lt;/span&gt;&lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;&lt;a href=&#34;https://github.com/community-scripts/ProxmoxVE&#34;&gt;community-scripts/ProxmoxVE&lt;/a&gt;が提供するスクリプト。
LXCのコンテナ作成からAdGuard Homeのインストールまで全自動でやってくれる。&lt;/p&gt;
&lt;p&gt;デフォルト構成はDebian 13、CPU 1コア、RAM 512MB、HDD 2GB。DNS用途なら十分。&lt;/p&gt;
&lt;h3 id=&#34;2-lxcにtunデバイスを追加する&#34;&gt;2. LXCにTUNデバイスを追加する&lt;/h3&gt;
&lt;p&gt;TailscaleはWireGuardベースのVPNで、動作に&lt;code&gt;/dev/net/tun&lt;/code&gt;が必要。&lt;/p&gt;
&lt;p&gt;&lt;code&gt;/dev/net/tun&lt;/code&gt;はLinuxの仮想ネットワークデバイス（TUNデバイス）。通常のネットワークデバイス（eth0等）は物理NICに紐づいているが、TUNはソフトウェアで作った仮想NIC。&lt;/p&gt;
&lt;p&gt;Tailscaleは以下の流れで通信を処理する。&lt;/p&gt;
&lt;ol&gt;
&lt;li&gt;通信をTailscaleプロセスが横取り&lt;/li&gt;
&lt;li&gt;WireGuardで暗号化&lt;/li&gt;
&lt;li&gt;暗号化したパケットを相手に送る&lt;/li&gt;
&lt;/ol&gt;
&lt;p&gt;この「横取り」の実装に&lt;code&gt;/dev/net/tun&lt;/code&gt;を使う。TUNデバイスを通してカーネルのネットワークスタックとTailscaleプロセスがやり取りする仕組みになっている。&lt;/p&gt;
&lt;p&gt;unprivileged LXCはセキュリティ上の理由でホストのデバイスに触れないようになっているため、明示的に&lt;code&gt;/dev/net/tun&lt;/code&gt;をコンテナに見せてあげる必要がある。&lt;/p&gt;
&lt;p&gt;Proxmoxのノードシェルで以下を実行してTUNを有効化する。&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;pct stop &lt;span style=&#34;color:#ae81ff&#34;&gt;106&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;echo &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;lxc.cgroup2.devices.allow: c 10:200 rwm&amp;#34;&lt;/span&gt; &amp;gt;&amp;gt; /etc/pve/lxc/106.conf
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;echo &lt;span style=&#34;color:#e6db74&#34;&gt;&amp;#34;lxc.mount.entry: /dev/net/tun dev/net/tun none bind,create=file&amp;#34;&lt;/span&gt; &amp;gt;&amp;gt; /etc/pve/lxc/106.conf
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;pct start &lt;span style=&#34;color:#ae81ff&#34;&gt;106&lt;/span&gt;
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;&lt;code&gt;106&lt;/code&gt;の部分は自分のLXCのIDに置き換える。IDは&lt;code&gt;pct list&lt;/code&gt;で確認できる。&lt;/p&gt;
&lt;h3 id=&#34;3-lxcにtailscaleを入れる&#34;&gt;3. LXCにTailscaleを入れる&lt;/h3&gt;
&lt;p&gt;LXCのシェルに入って以下を実行する。&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;curl -fsSL https://tailscale.com/install.sh | sh
&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;tailscale up
&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;認証URLが表示されるのでブラウザで開いてログインする。
認証後、TailscaleのMachines画面からAdGuard HomeのTailscale IPを確認しておく。&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
