NURO光のONU(F660A) ルーター機能を外せないから対策してみた(IPv4,IPv6対応)


追記

NURO光はデュアルスタックからMAP-Eに順次切り替えていく方針のようです。切り替えられたらもうDMZもポート開放もできません。オプションすら用意せずに勝手に切り替えていくのはどうかしていますね。

ちなみに自前のONUを用意すればグローバルIPが降ってくるし強制FWアプデももちろん関係なくデュアルスタックできますが、NUROに怒られます。

しょうがないのでWebとVPNサーバーをポート開放なしで立てた記録


NURO光を契約したらONUとルーターがくっついたF660Aが来ました。
ルーターは別に用意してONUの機能だけ使いたいと思ってましたが、ルーター機能はどうやっても切れないっぽいです。


別のルーターを普通に繋げたら二重NAPTになってしまうので対策してみました。

用意したルーターはYAMAHAのRTX1200です。

手順

まず最初にF660AとRTX1200のLAN2のポートを繋げます。

IPv4

IPv4はDMZ転送を利用します。
これでF660Aが把握していない通信はすべてRTX1200に流れます。

①RTX1200のMACアドレス確認

RTX1200の管理画面に入って、左の項目のハードウェアをクリック
LAN2ポートのMACアドレスを確認します。

②F660AのDMZ転送設定

F660Aの管理画面に入って、アプリケーション-DMZの項目をクリック
一番上の”有効にする”と、”MACアドレスのマッピングを有効にする”を選択。
そしてさっき調べたMACアドレスを入れて設定を押します。

③RTX1200のLAN2のIPを自動取得にする

またRTX1200の管理画面に入って、インターフェース-LAN2の詳細をクリック
基本項目の”設定”をクリックしてIPアドレスを”DHCPで自動的に取得する”を選択して確認を押します。

IPv4はこれで終わりです。次にIPv6を設定します

IPv6

NuroではONUに/56のプレフィックスが付与されます。

が、このゴミONUは/64のアドレスしか払い出せない仕様です。
つまり、F660Aの下にそのままルーター繋いでもその配下でIPv6ネットワークを組めません。
(ipv6は全体が128bitで、前半64bitがネットワークの識別子で後半64bitがデバイスの識別子になるため)

そこで、上流にあるルータの代理でDHCPv6を下流に提供するNDプロキシを使います。
(YAMAHAではRAプロキシと呼ばれてるみたい)

RTX1200の設定から、保守→コマンドの入力

この設定でうまくいきました。

最初打ってもLAN1配下のPCからなぜかIPv6通らなくて、F660AとRTX1200繋ぐポート変えてみたり、RTX1200のIPv6関係のコンフィグを消してから打ち直したりしたら無事疎通しました。
前にIPv6をやりかけてやめたときのコンフィグが悪さしてたかもしれません。

とりあえずこれでIPv4,v6ともに繋がったと思います。

ネームサーバー

何も設定しないとRTX1200はF660Aに名前解決しに行ってしまうので、DNSサーバーをGoogleのアレに設定しました。


番外編

ONUを弄ってみる?(NUROから怒りのお手紙が来ても知りません)

HG8045Qは例の脆弱性騒ぎのマスターアカウントで入るとブリッジモードに設定できたようです。
現在このマスターアカウントはOLT経由で送信された強制アプデで変更されました。

F660AとF660Tはこういうの使って頑張ってみてください。
WebUIに管理者で入れて、rootでtelnetに入り好き勝手できるところまではいけましたが、ブリッジさせるのはどうやってもできませんでした;;

https://github.com/zainarbani/ztelnet
https://github.com/TommyLau/ztecfg

pon0とethをbtctlでブリッジさせても何も起こりませんでした。何がどうなっているのでしょうか


参考にしたサイト

https://qiita.com/hellfire/items/e10bf16bfffdf21d30f6

https://qiita.com/buttyo_kuny/items/c2521d8c6919b982861e

おすすめ

1件の返信

  1. これから NURO 光を契約することになりそうな とあるサーバ管理人ですが 同じことが知りたいです。
    G-PON ONUはたしかにありますが それが可能か知りたいです。

コメントを残す

メールアドレスが公開されることはありません。 が付いている欄は必須項目です