プライバシー保護とネットワークの自由を追求するユーザーにとって、DNS漏洩(DNS Leak)は避けては通れない技術的課題です。プロキシを使用してIPアドレスを隠していても、DNSクエリがISPのサーバーに直接送信されていれば、訪問先のドメイン情報は筒抜けになってしまいます。2026年現在、Clash (特に Mihomo カーネル) は、この問題を解決するための強力な武器を備えています。
本記事では、Clashのコア機能である Fake-IP モードと TUN インターフェース を活用し、DNS漏洩を完全にシャットアウトするための高度な設定を深掘りします。初心者向けの基本設定から、ネットワークエンジニアも納得の構成案まで、1500文字を超える詳細な解説をお届けします。まずは、なぜ従来のプロキシ設定だけでは不十分なのか、その仕組みから理解していきましょう。
DNS漏洩とは何か:なぜ発生するのか
通常、ブラウザでウェブサイトにアクセスしようとすると、OSはまずドメイン名(例:google.com)をIPアドレスに変換するためにDNSクエリを送信します。多くのプロキシクライアントは「システムプロキシ」として動作しますが、この場合、ブラウザ自体がプロキシを認識してクエリを転送する必要があります。しかし、多くのアプリケーションやOSのバックグラウンドプロセスは、このプロキシ設定を無視して、OS標準のDNSリゾルバ(通常はISPのDNS)へ直接クエリを投げてしまいます。
これがDNS漏洩の正体です。IPアドレスはプロキシサーバーのものに変わっていても、「誰が、いつ、どのサイトを見ようとしたか」という記録がISP側に残ってしまいます。これを防ぐには、OSレベルで全てのDNSトラフィックを捕捉し、Clash内部のセキュアなDNSモジュールへ強制的にリダイレクトする仕組みが必要になります。
Fake-IP モードの仕組みとメリット
ClashのDNS設定で最も推奨されるのが enhanced-mode: fake-ip です。このモードは、従来のDNS解決プロセスを根本から変える画期的な仕組みです。
通常(Real-IP)の流れでは、DNS解決が完了するまで通信を開始できません。しかし Fake-IP モードでは、アプリケーションがDNSクエリを投げると、Clashは即座に 198.18.x.x などの仮想的なIPアドレス(Fake-IP)を返します。アプリケーションはその Fake-IP を宛先として通信を開始し、Clashはそのパケットを受け取った瞬間に、内部のデータベースを参照して本来のドメイン名を特定し、最適なノードを選択して接続を確立します。
Fake-IP を使うべき3つの理由
- 超高速なレスポンス:DNS解決を待たずに通信を開始できるため、体感速度が大幅に向上します。
- DNS汚染の無効化:ローカルで本物のIPを知る必要がないため、ISPによるDNS改ざんの影響を全く受けません。
- 漏洩の防止:全ての解決がClash内部で完結するため、外部へクエリが漏れる隙を与えません。
ヒント:一部の古いゲームや、IPアドレスを直接ハードコードしているアプリでは Fake-IP が原因で接続エラーが起きることがあります。その場合は fake-ip-filter に対象ドメインを追加することで回避可能です。
TUN モードによる全トラフィックの捕捉
DNS漏洩対策の完成形は、TUN モードとの組み合わせです。TUN モードはOSに仮想ネットワークカードを作成し、L3(ネットワーク層)で全てのパケットを捕捉します。これにより、プロキシ設定を無視するコマンドラインツールやゲーム、さらにはOS自体のDNSクエリも逃さず Clash に送ることができます。
2026年のトレンドである Mihomo カーネルでは、auto-route や auto-detect-interface といった機能により、複雑なルーティングテーブルの手動設定なしで安定した透明プロキシ環境が構築できます。
DNS漏洩を防ぐ最強の YAML 設定例
以下に、DNS漏洩を完全に防ぎ、かつ国内・海外のトラフィックを最適に分流するための dns セクションの設定例を示します。この構成は、プライバシーとパフォーマンスを両立させたプロフェッショナル仕様です。
dns:
enable: true
ipv6: false
listen: 0.0.0.0:1053
enhanced-mode: fake-ip
fake-ip-range: 198.18.0.1/16
# DNSハイジャックを有効にし、OSのDNSクエリを強制捕捉
fake-ip-filter:
- '*.lan'
- 'localhost.pt'
nameserver:
- 'https://doh.pub/dns-query' # 国内用DoH
- 'https://dns.alidns.com/dns-query'
fallback:
- 'https://1.1.1.1/dns-query' # 海外用DoH(プロキシ経由で解決)
- 'https://8.8.8.8/dns-query'
fallback-filter:
geoip: true
geoip-code: CN
geosite:
- gfw
- geolocation-!cn
高度な設定を適用する手順
実際に Clash Verge Rev やその他の Mihomo ベースのクライアントで設定を有効化する手順を解説します。
管理者権限での実行 — TUN モードの有効化には仮想アダプタの作成権限が必要です。Windows では「管理者として実行」、macOS ではシステム拡張の許可を必ず行ってください。
DNS 設定の編集 — 設定画面の「DNS」セクション、または構成ファイルの YAML を開き、enhanced-mode を fake-ip に設定します。nameserver-policy を活用して、国内ドメインは国内DNSで解決するように設定すると、CDNの最適化が維持されます。
TUN モードのスイッチをオン — クライアントのメイン画面で TUN モードを有効にします。この際、システムプロキシ(System Proxy)はオフにしても構いませんが、互換性のために両方オンにすることを推奨します。
漏洩テストの実施 — dnsleaktest.com などの検証サイトにアクセスし、表示されるDNSサーバーがプロキシサーバーのもの、あるいはパブリックDNS(1.1.1.1等)のみであることを確認します。ISPのサーバーが表示されたら設定失敗です。
注意:IPv6が有効な環境では、IPv6経由でDNSが漏洩するケースが非常に多いです。特別な理由がない限り、Clash設定内の ipv6: false を設定するか、OS側でIPv6を無効にすることを強く推奨します。
よくある質問 FAQ
Fake-IP モードでネットが繋がらなくなるアプリがあるのはなぜ?
一部のアプリは、返された Fake-IP がプライベートIP帯域(198.18.x.x)であることを検知し、「不正なIP」として通信を遮断したり、独自にDNS解決を試みようとして失敗したりします。これは fake-ip-filter にそのアプリが使用するドメインを追加することで解決できます。
DoH (DNS over HTTPS) は必須ですか?
必須ではありませんが、強く推奨します。通常のUDP/53ポートのDNSクエリは平文であり、たとえプロキシを通しても出口ノードから先の通信が傍受される可能性があります。DoHを使用すれば、ClashからDNSサーバーまでの通信が暗号化されるため、より安全です。
TUN モードをオンにすると速度が落ちますか?
理論上、仮想アダプタを経由するため僅かなオーバーヘッドが発生しますが、現代のCPU(特に Intel 第12世代以降や Apple Silicon)であれば、1Gbps 程度の通信でも無視できるレベルの負荷です。むしろDNS解決の高速化によるメリットの方が大きいです。
今すぐダウンロードして安全な環境を
DNS漏洩対策は、単なる設定の一つではなく、プライバシーを守るための「壁」そのものです。Clash Verge Rev や FlClash といった最新のクライアントは、今回解説した複雑な設定を直感的なUIで提供しています。ISPの監視から解放され、真に自由で安全なインターネット環境を手に入れましょう。最新の安定版は、以下のリンクから入手可能です。Clashクライアントのダウンロードページから無料でダウンロードできます。