設定例集#51: ダイナミックDNSサービスを利用したホスト名(FQDN)によるIPsec接続
通常、インターネットVPNを構築するためには、少なくとも1つの拠点に固定グローバルIPアドレスが必要ですが、ダイナミックDNSサービスを利用すれば、VPNの接続先をIPアドレスではなく、ダイナミックDNSサービスサイトに登録したホスト名(FQDN)で指定できるようになります。これにより、すべての拠点が動的IPアドレスの場合でも、インターネットVPNを構築できるようになります。
ダイナミックDNSは、ダイナミックDNSサーバー(以下、サーバー)とダイナミックDNSクライアント(以下、クライアント)で構成されます。この設定例では、サーバーがダイナミックDNSサービスによって提供されていることを前提にします。クライアントは、ルーターのダイナミックDNSクライアント機能を使用します。
ルーターは起動時に自身のWAN側インターフェース情報(IPアドレス、FQDN)をサーバーに登録します。そして、その後IPアドレスが変更されたときには、自動的に登録アドレスを更新します。これにより、サーバーはつねにルーターのホスト名に対応する最新のIPアドレスを保持することができます。
ダイナミックDNSサービスに障害が発生した場合、IPsec VPNの確立が行えない場合があります。信頼性が必要とされるネットワークでは、固定IPアドレス契約の利用をご検討ください。
検証済みダイナミックDNSサービスは弊社ホームページをご確認ください。
構成

|
ルーターA |
ルーターB |
ISPから提供された情報 |
ISP接続用ユーザー名 |
user@ispA |
user@ispB |
ISP接続用パスワード |
isppasswdA |
isppasswdB |
PPPoEサービス名 |
指定なし |
指定なし |
WAN側IPアドレス |
動的割り当て(IPCP) |
動的割り当て(IPCP) |
DNSサーバー |
自動取得(IPCP) |
自動取得(IPCP) |
接続形態 |
端末型 |
端末型 |
ルーターの基本設定 |
WAN側物理インターフェース |
eth1 |
eth1 |
WAN側(ppp0)IPアドレス |
接続時にISP-Aから取得 |
接続時にISP-Bから取得 |
LAN側(eth2)IPアドレス |
192.168.10.1/24 |
192.168.20.1/24 |
IKEフェーズ1(ISAKMP)設定 |
IKEバージョン |
IKEv2 |
ローカルID |
test1.dyndns.org |
test2.dyndns.org |
リモートID |
test2.dyndns.org |
test1.dyndns.org |
ダイナミックDNSサーバー情報 |
サーバーのFQDN |
members.dyndns.org |
members.dyndns.org |
サーバーのTCPポート番号 |
443 |
443 |
ダイナミックDNSクライアント情報 |
サーバー接続用ユーザー名 |
test |
test |
サーバー接続用パスワード |
test |
test |
ホスト名 |
test1.dyndns.org |
test2.dyndns.org |
IPアドレスを登録するインターフェース |
ppp0 |
ppp0 |
[事前共有鍵]
ルーターA、Bが使用するホスト名やダイナミックDNSサーバーにアクセスするためのアカウントは、あらかじめ取得してあるものとします。
上記構成図において、PC1からPC2への通信が開始されるまでの流れは次のようになります。
◆通常時
- ルーターA、Bは、自身のIPアドレスの登録先であるダイナミックDNSサーバー「members.dyndns.org」のIPアドレスを知るため、ISP接続時に通知されたDNSサーバーに名前解決を要求します。また、トリガー「3」により、IPsec VPNの接続先である対向ルーターのホスト名解決とISAKMP SAの削除を1分間隔で実行します。
- 解決したIPアドレス宛てにアップデートパケット(HTTPS)を送信し、自身のIPアドレスをダイナミックDNSサーバーに登録します。
- PC1 → PC2の通信が発生すると、IPsec VPNの接続先である対向ルーター「test2.dyndns.org」のIPアドレスを知るため、ISP接続時に通知されたDNSサーバーに名前解決を要求します。
- 名前解決後、取得したIPアドレスに対してIPsecの接続を開始します。
- IPsec接続が完了すると、PingポーリングがUPし、トリガー「3」が無効化されます。
◆ルーターA 障害 復旧時
- ルーターA、BでPingポーリングがDOWNすると、トリガー「3」が有効化され、IPsec VPNの接続先である対向ルーターのホスト名解決とISAKMP SAの削除を1分間隔で実行します。
- ルーターAは、自身のIPアドレスの登録先であるダイナミックDNSサーバー「members.dyndns.org」のIPアドレスを知るため、ISP接続時に通知されたDNSサーバーに名前解決を要求します。
- 解決したIPアドレス宛てにアップデートパケット(HTTPS)を送信し、自身のIPアドレスをダイナミックDNSサーバーに登録します。
- PC1 → PC2の通信が発生すると、IPsec VPNの接続先である対向ルーター「test2.dyndns.org」のIPアドレスを知るため、ISP接続時に通知されたDNSサーバーに名前解決を要求します。
- 名前解決後、取得したIPアドレスに対してIPsecの接続を開始します。
- IPsec接続が完了すると、ルーターA、BでPingポーリングがUPし、トリガー「3」が無効化されます。
設定開始前に
自動設定の確認と削除
本設定例に掲載されているコマンドは、設定がまったく行われていない本製品の初期状態(スタートアップコンフィグなしで起動した状態)から入力することを前提としています。
そのため、通常は erase startup-config を実行し、スタートアップコンフィグが存在しない状態で起動してから、設定を始めてください。
ただし、本製品はスタートアップコンフィグなしで起動した場合でも、特定の条件を満たすと自動的な設定を行うことがあるため、その場合は設定例にしたがってコマンドを入力しても、コマンドがエラーになったり、全体として意図した動作にならない可能性があります。
これを避けるため、設定開始にあたっては次のいずれかの方法をとることをおすすめします。
- ネットワークケーブルを接続せずに起動する。
起動時に自動設定が実行されるための条件の一つに、特定インターフェースのリンクアップがあります。
ネットワークケーブルを接続しない状態で起動することにより、自動設定の適用を回避できます。
- 自動設定を手動で削除してから設定を行う。
前記の方法を採用できず自動設定が適用されてしまった場合は、「自動的な設定内容の削除」にしたがって、これらを手動で削除してから設定を開始してください。
自動設定が行われる条件などの詳細については、AMF応用編のAMFネットワーク未検出時の拡張動作をご参照ください。
システム時刻の設定
ログなどの記録日時を正確に保ち、各種機能を適切に動作させるため、システム時刻は正確にあわせて運用することをおすすめします。
ご使用の環境にあわせ、次のいずれかの方法でシステム時刻を設定してください。
ルーターAの設定
- ダイナミックDNSクライアント機能を有効にします。これには、ddns enableコマンドを使います。
ダイナミックDNSクライアント機能の詳細は「IP付加機能」/「ダイナミックDNSクライアント」をご覧ください。
ddns enable
- ダイナミックDNSサービス固有の設定を行います。これには、ddns-update-methodコマンドでDDNSアップデートメソッドモードに入り、update-url、host-name、username、password、update-interval、retry-intervalの各コマンドで具体的なパラメーターを設定します。
ddns-update-method dyndns
update-url https://<USERNAME>:<PASSWORD>@members.dyndns.org/nic/update?SYSTEM=dyndns&hostname=<HOST-NAME>&myip=<IPADDRESS>
host-name test1.dyndns.org
username test
password test
update-interval 60
retry-interval 1 maximum-retries 5
- WANポートeth1上にPPPoEインターフェースppp0を作成します。これには、encapsulation pppコマンドを使います。
PPPの詳細は「PPP」/「一般設定」をご覧ください。
interface eth1
encapsulation ppp 0
- PPPインターフェースppp0に対し、PPPoE接続のための設定を行います。
・ダイナミックDNSクライアント機能によるIPアドレスの登録(ip ddns-update-method)
・IPCPによるDNSサーバーアドレスの取得要求(ppp ipcp dns)
・LCP EchoによるPPP接続状態の確認(keepalive)
・IPCPによるIPアドレスの取得要求(ip address negotiated)
・ユーザー名(ppp username)
・パスワード(ppp password)
・MSS書き換え(ip tcp adjust-mss)
PPPの詳細は「PPP」/「一般設定」をご覧ください。
interface ppp0
ip ddns-update-method dyndns
ppp ipcp dns request
keepalive
ip address negotiated
ppp username user@ispA
ppp password isppasswdA
ip tcp adjust-mss pmtu
- LAN側インターフェースeth2にIPアドレスを設定します。これにはip addressコマンドを使います。
IPインターフェースの詳細は「IP」/「IPインターフェース」をご覧ください。
interface eth2
ip address 192.168.10.1/24
- ファイアウォールやNATのルール作成時に使うエンティティー(通信主体)を定義します。
エンティティー定義の詳細は「UTM」/「エンティティー定義」をご覧ください。
内部ネットワークを表すゾーン「private」を作成します。
これには、zone、network、ip subnetの各コマンドを使います。
zone private
network lan
ip subnet 192.168.10.0/24
network peer
ip subnet 192.168.20.0/24 interface tunnel0
network tunnel
ip subnet 172.16.0.0/30
- 外部ネットワークを表すゾーン「public」を作成します。
これには、前記コマンドに加え、host、ip addressの各コマンドを使います。
zone public
network wan
ip subnet 0.0.0.0/0 interface ppp0
host ppp0
ip address dynamic interface ppp0
- ファイアウォールやNATのルール作成時に通信内容を指定するために使う「アプリケーション」を定義します。
これには、application、protocol、sport、dport、icmp-type、icmp-codeの各コマンドを使います。
アプリケーション定義の詳細は「UTM」/「アプリケーション定義」をご覧ください。
IPsecのESPパケットを表すカスタムアプリケーション「esp」を定義します。
application esp
protocol 50
- ISAKMPパケットを表すカスタムアプリケーション「isakmp」を定義します。
application isakmp
protocol udp
sport 500
dport 500
- 外部からの通信を遮断しつつ、内部からの通信は自由に行えるようにするファイアウォール機能の設定を行います。
これには、firewall、rule、protectの各コマンドを使います。
・rule 10 - 内部ネットワーク間の通信を許可します
・rule 20 - 内部ネットワークから外部への通信を許可します
・rule 30, 40 - ISAKMPパケットを許可します
・rule 50, 60 - IPsec(ESP)パケットを許可します
・rule 70 - 本製品のWAN側インターフェースから外部へのDNS通信を許可します
・rule 80 - ダイナミックDNSサーバーにアクセスしてIPアドレスを登録するため、本製品のWAN側インターフェースから外部へのHTTPS通信を許可します
ファイアウォールの詳細は「UTM」/「ファイアウォール」をご覧ください。
firewall
rule 10 permit any from private to private
rule 20 permit any from private to public
rule 30 permit isakmp from public.wan.ppp0 to public.wan
rule 40 permit isakmp from public.wan to public.wan.ppp0
rule 50 permit esp from public.wan.ppp0 to public.wan
rule 60 permit esp from public.wan to public.wan.ppp0
rule 70 permit dns from public.wan.ppp0 to public.wan
rule 80 permit https from public.wan.ppp0 to public.wan
protect
- LAN側ネットワークに接続されているすべてのコンピューターがダイナミックENAT機能を使用できるよう設定します。
これには、nat、rule、enableの各コマンドを使います。
NATの詳細は「UTM」/「NAT」をご覧ください。
nat
rule 10 masq any from private to public
enable
- 対向ルーターとの間で使用するISAKMPの事前共有鍵を設定します。これにはcrypto isakmp keyコマンドを使います。
ここでは、ダイナミックDNSサービスによって登録されたホスト名(FQDN)で対向ルーターを指定しています。
crypto isakmp key secret hostname test2.dyndns.org
- IPsecトンネルインターフェースtunnel0を作成します。
トンネルインターフェースの詳細は「VPN」/「トンネルインターフェース」を、IPsecの詳細は「VPN」/「IPsec」をご覧ください。
これには、interfaceコマンドでトンネルインターフェースを作成し、以下の情報を設定します。
ここでは、ダイナミックDNSサービスによって登録されたホスト名(FQDN)で対向装置のアドレスと自装置、対向装置のIDを指定しています。
・トンネルインターフェースのMTU(mtu)
・トンネルインターフェースから送信するデリバリーパケットの始点(自装置)アドレス(tunnel source)
・トンネルインターフェースから送信するデリバリーパケットの終点(対向装置)アドレス(tunnel destination)
・トンネルインターフェースにおける自装置ID(ローカルID)(tunnel local name)
・トンネルインターフェースにおける対向装置ID(リモートID)(tunnel remote name)
・トンネルインターフェースに対するIPsec保護の適用(tunnel protection ipsec)
・トンネリング方式(tunnel mode ipsec)
・トンネルインターフェースのIPアドレス(ip address)
・トンネルインターフェースにおけるMSS書き換え設定(ip tcp adjust-mss)
interface tunnel0
mtu 1300
tunnel source ppp0
tunnel destination test2.dyndns.org
tunnel local name test1.dyndns.org
tunnel remote name test2.dyndns.org
tunnel protection ipsec
tunnel mode ipsec ipv4
ip address 172.16.0.1/30
ip tcp adjust-mss 1260
- トンネルインターフェース tunnel0 経由での対向ルーターへの接続性を監視するPingポーリング「1」を作成します。
これには、ping-poll、ip、activeの各コマンドを使います。
Pingポーリングの詳細は「IP付加機能」/「Pingポーリング」をご覧ください。
ping-poll 1
ip 172.16.0.2
active
- Pingポーリングトリガーを作成します。
これには、trigger、type ping-poll、scriptの各コマンドを使います。
・trigger 1 - tunnel0 経由での対向ルーターへの接続性が失われた場合に、trigger 3を作成することで 1分おきに FQDN での再接続を試みる periodic-update.scpスクリプトを実行する
・trigger 2 - tunnel0 経由での対向ルーターへの接続性が回復した場合に、trigger 3を削除することで 1分おきの再接続を停止する periodic-update-delete.scpスクリプトを実行する
・trigger 3 - ISAKMP SA を強制的に削除し、対向ルーターのFQDNを解決した上で再接続を試みる host-change.scpスクリプトを1分おきに実行する(trigger 1によって作成・起動され、trigger 2によって削除・停止される)
トリガースクリプトの具体的内容は「トリガースクリプト」を、トリガーの詳細は「運用・管理」/「トリガー」をご覧ください。
trigger 1
type ping-poll 1 down
script 1 periodic-update.scp
trigger 2
type ping-poll 1 up
script 1 periodic-update-delete.scp
trigger 3
type periodic 1
script 1 host-change.scp
- デフォルト経路(0.0.0.0/0)とルーターBのLAN側(192.168.20.0/24)への経路を設定します。これにはip routeコマンドを使います。
ただし、ルーター間のVPN接続が有効になるまでは、対向側LANへの経路は使用できないように設定します。
IP経路設定の詳細は「IP」/「経路制御」をご覧ください。
ip route 0.0.0.0/0 ppp0
ip route 192.168.20.0/24 tunnel0
ip route 192.168.20.0/24 Null 254
- DNSリレー機能を有効にします。これには、ip dns forwardingコマンドを使います。
DNSリレー機能の詳細は「IP付加機能」/「DNSリレー」をご覧ください。
ip dns forwarding
- 以上で設定は完了です。
end
ルーターBの設定
- ダイナミックDNSクライアント機能を有効にします。これには、ddns enableコマンドを使います。
ダイナミックDNSクライアント機能の詳細は「IP付加機能」/「ダイナミックDNSクライアント」をご覧ください。
ddns enable
- ダイナミックDNSサービス固有の設定を行います。これには、ddns-update-methodコマンドでDDNSアップデートメソッドモードに入り、update-url、host-name、username、password、update-interval、retry-intervalの各コマンドで具体的なパラメーターを設定します。
ddns-update-method dyndns
update-url https://<USERNAME>:<PASSWORD>@members.dyndns.org/nic/update?SYSTEM=dyndns&hostname=<HOST-NAME>&myip=<IPADDRESS>
host-name test2.dyndns.org
username test
password test
update-interval 60
retry-interval 10 maximum-retries 5
- WANポートeth1上にPPPoEインターフェースppp0を作成します。これには、encapsulation pppコマンドを使います。
PPPの詳細は「PPP」/「一般設定」をご覧ください。
interface eth1
encapsulation ppp 0
- PPPインターフェースppp0に対し、PPPoE接続のための設定を行います。
・ダイナミックDNSクライアント機能によるIPアドレスの登録(ip ddns-update-method)
・IPCPによるDNSサーバーアドレスの取得要求(ppp ipcp dns)
・LCP EchoによるPPP接続状態の確認(keepalive)
・IPCPによるIPアドレスの取得要求(ip address negotiated)
・ユーザー名(ppp username)
・パスワード(ppp password)
・MSS書き換え(ip tcp adjust-mss)
PPPの詳細は「PPP」/「一般設定」をご覧ください。
interface ppp0
ip ddns-update-method dyndns
ppp ipcp dns request
keepalive
ip address negotiated
ppp username user@isp2
ppp password isppasswd2
ip tcp adjust-mss pmtu
- LAN側インターフェースeth2にIPアドレスを設定します。これにはip addressコマンドを使います。
IPインターフェースの詳細は「IP」/「IPインターフェース」をご覧ください。
interface eth2
ip address 192.168.20.1/24
- ファイアウォールやNATのルール作成時に使うエンティティー(通信主体)を定義します。
エンティティー定義の詳細は「UTM」/「エンティティー定義」をご覧ください。
内部ネットワークを表すゾーン「private」を作成します。
これには、zone、network、ip subnetの各コマンドを使います。
zone private
network lan
ip subnet 192.168.20.0/24
network peer
ip subnet 192.168.10.0/24 interface tunnel0
network tunnel
ip subnet 172.16.0.0/30
- 外部ネットワークを表すゾーン「public」を作成します。
これには、前記コマンドに加え、host、ip addressの各コマンドを使います。
zone public
network wan
ip subnet 0.0.0.0/0 interface ppp0
host ppp0
ip address dynamic interface ppp0
- ファイアウォールやNATのルール作成時に通信内容を指定するために使う「アプリケーション」を定義します。
これには、application、protocol、sport、dport、icmp-type、icmp-codeの各コマンドを使います。
アプリケーション定義の詳細は「UTM」/「アプリケーション定義」をご覧ください。
IPsecのESPパケットを表すカスタムアプリケーション「esp」を定義します。
application esp
protocol 50
- ISAKMPパケットを表すカスタムアプリケーション「isakmp」を定義します。
application isakmp
protocol udp
sport 500
dport 500
- 外部からの通信を遮断しつつ、内部からの通信は自由に行えるようにするファイアウォール機能の設定を行います。
これには、firewall、rule、protectの各コマンドを使います。
・rule 10 - 内部ネットワーク間の通信を許可します
・rule 20 - 内部ネットワークから外部への通信を許可します
・rule 30, 40 - ISAKMPパケットを許可します
・rule 50, 60 - IPsec(ESP)パケットを許可します
・rule 70 - 本製品のWAN側インターフェースから外部へのDNS通信を許可します
・rule 80 - ダイナミックDNSサーバーにアクセスしてIPアドレスを登録するため、本製品のWAN側インターフェースから外部へのHTTPS通信を許可します
ファイアウォールの詳細は「UTM」/「ファイアウォール」をご覧ください。
firewall
rule 10 permit any from private to private
rule 20 permit any from private to public
rule 30 permit isakmp from public.wan.ppp0 to public.wan
rule 40 permit isakmp from public.wan to public.wan.ppp0
rule 50 permit esp from public.wan.ppp0 to public.wan
rule 60 permit esp from public.wan to public.wan.ppp0
rule 70 permit dns from public.wan.ppp0 to public.wan
rule 80 permit https from public.wan.ppp0 to public.wan
protect
- LAN側ネットワークに接続されているすべてのコンピューターがダイナミックENAT機能を使用できるよう設定します。
これには、nat、rule、enableの各コマンドを使います。
NATの詳細は「UTM」/「NAT」をご覧ください。
nat
rule 10 masq any from private to public
enable
- 対向ルーターとの間で使用するISAKMPの事前共有鍵を設定します。これにはcrypto isakmp keyコマンドを使います。
ここでは、ダイナミックDNSサービスによって登録されたホスト名(FQDN)で対向ルーターを指定しています。
crypto isakmp key secret hostname test1.dyndns.org
- IPsecトンネルインターフェースtunnel0を作成します。
トンネルインターフェースの詳細は「VPN」/「トンネルインターフェース」を、IPsecの詳細は「VPN」/「IPsec」をご覧ください。
これには、interfaceコマンドでトンネルインターフェースを作成し、以下の情報を設定します。
ここでは、ダイナミックDNSサービスによって登録されたホスト名(FQDN)で対向装置のアドレスと自装置、対向装置のIDを指定しています。
・トンネルインターフェースのMTU(mtu)
・トンネルインターフェースから送信するデリバリーパケットの始点(自装置)アドレス(tunnel source)
・トンネルインターフェースから送信するデリバリーパケットの終点(対向装置)アドレス(tunnel destination)
・トンネルインターフェースにおける自装置ID(ローカルID)(tunnel local name)
・トンネルインターフェースにおける対向装置ID(リモートID)(tunnel remote name)
・トンネルインターフェースに対するIPsec保護の適用(tunnel protection ipsec)
・トンネリング方式(tunnel mode ipsec)
・トンネルインターフェースのIPアドレス(ip address)
・トンネルインターフェースにおけるMSS書き換え設定(ip tcp adjust-mss)
interface tunnel0
mtu 1300
tunnel source ppp0
tunnel destination test1.dyndns.org
tunnel local name test2.dyndns.org
tunnel remote name test1.dyndns.org
tunnel protection ipsec
tunnel mode ipsec ipv4
ip address 172.16.0.2/30
ip tcp adjust-mss 1260
- トンネルインターフェース tunnel0 経由での対向ルーターへの接続性を監視するPingポーリング「1」を作成します。
これには、ping-poll、ip、activeの各コマンドを使います。
Pingポーリングの詳細は「IP付加機能」/「Pingポーリング」をご覧ください。
ping-poll 1
ip 172.16.0.1
active
- Pingポーリングトリガーを作成します。
これには、trigger、type ping-poll、scriptの各コマンドを使います。
・trigger 1 - tunnel0 経由での対向ルーターへの接続性が失われた場合に、trigger 3を作成することで 1分おきに FQDN での再接続を試みる periodic-update.scpスクリプトを実行する
・trigger 2 - tunnel0 経由での対向ルーターへの接続性が回復した場合に、trigger 3を削除することで 1分おきの再接続を停止する periodic-update-delete.scpスクリプトを実行する
・trigger 3 - ISAKMP SA を強制的に削除し、対向ルーターのFQDNを解決した上で再接続を試みる host-change.scpスクリプトを1分おきに実行する(trigger 1によって作成・起動され、trigger 2によって削除・停止される)
トリガースクリプトの具体的内容は「トリガースクリプト」を、トリガーの詳細は「運用・管理」/「トリガー」をご覧ください。
trigger 1
type ping-poll 1 down
script 1 periodic-update.scp
trigger 2
type ping-poll 1 up
script 1 periodic-update-delete.scp
trigger 3
type periodic 1
script 1 host-change.scp
- デフォルト経路(0.0.0.0/0)とルーターAのLAN側(192.168.10.0/24)への経路を設定します。これにはip routeコマンドを使います。
ただし、ルーター間のVPN接続が有効になるまでは、対向側LANへの経路は使用できないように設定します。
IP経路設定の詳細は「IP」/「経路制御」をご覧ください。
ip route 0.0.0.0/0 ppp0
ip route 192.168.10.0/24 tunnel0
ip route 192.168.10.0/24 Null 254
- DNSリレー機能を有効にします。これには、ip dns forwardingコマンドを使います。
DNSリレー機能の詳細は「IP付加機能」/「DNSリレー」をご覧ください。
ip dns forwarding
- 以上で設定は完了です。
end
設定の保存
■ 設定が完了したら、現在の設定内容を起動時コンフィグとして保存してください。これには、copyコマンドを「copy running-config startup-config
」の書式で実行します。
awplus# copy running-config startup-config ↓
Building configuration...
[OK]
また、write fileコマンド、write memoryコマンドでも同じことができます。
awplus# write memory ↓
Building configuration...
[OK]
その他、設定保存の詳細については「運用・管理」/「コンフィグレーション」をご覧ください。
ファイアウォールログについて
■ ファイアウォールのログをとるには、次のコマンド(log(filter))を実行します。
awplus(config)# log buffered level informational facility kern msgtext Firewall ↓
■ 記録されたログを見るには、次のコマンド(show log)を実行します。ここでは、ファイアウォールが出力したログメッセージだけを表示させています。
awplus# show log | include Firewall ↓
ルーターAのコンフィグ
!
ddns enable
!
ddns-update-method dyndns
update-url https://<USERNAME>:<PASSWORD>@members.dyndns.org/nic/update?SYSTEM=dyndns&hostname=<HOST-NAME>&myip=<IPADDRESS>
host-name test1.dyndns.org
username test
password test
update-interval 60
retry-interval 1 maximum-retries 5
!
interface eth1
encapsulation ppp 0
!
interface ppp0
ip ddns-update-method dyndns
ppp ipcp dns request
keepalive
ip address negotiated
ppp username user@ispA
ppp password isppasswdA
ip tcp adjust-mss pmtu
!
interface eth2
ip address 192.168.10.1/24
!
zone private
network lan
ip subnet 192.168.10.0/24
network peer
ip subnet 192.168.20.0/24 interface tunnel0
network tunnel
ip subnet 172.16.0.0/30
!
zone public
network wan
ip subnet 0.0.0.0/0 interface ppp0
host ppp0
ip address dynamic interface ppp0
!
application esp
protocol 50
!
application isakmp
protocol udp
sport 500
dport 500
!
firewall
rule 10 permit any from private to private
rule 20 permit any from private to public
rule 30 permit isakmp from public.wan.ppp0 to public.wan
rule 40 permit isakmp from public.wan to public.wan.ppp0
rule 50 permit esp from public.wan.ppp0 to public.wan
rule 60 permit esp from public.wan to public.wan.ppp0
rule 70 permit dns from public.wan.ppp0 to public.wan
rule 80 permit https from public.wan.ppp0 to public.wan
protect
!
nat
rule 10 masq any from private to public
enable
!
crypto isakmp key secret hostname test2.dyndns.org
!
interface tunnel0
mtu 1300
tunnel source ppp0
tunnel destination test2.dyndns.org
tunnel local name test1.dyndns.org
tunnel remote name test2.dyndns.org
tunnel protection ipsec
tunnel mode ipsec ipv4
ip address 172.16.0.1/30
ip tcp adjust-mss 1260
!
ping-poll 1
ip 172.16.0.2
active
!
trigger 1
type ping-poll 1 down
script 1 periodic-update.scp
trigger 2
type ping-poll 1 up
script 1 periodic-update-delete.scp
trigger 3
type periodic 1
script 1 host-change.scp
!
ip route 0.0.0.0/0 ppp0
ip route 192.168.20.0/24 tunnel0
ip route 192.168.20.0/24 Null 254
!
ip dns forwarding
!
end
ルーターBのコンフィグ
!
ddns enable
!
ddns-update-method dyndns
update-url https://<USERNAME>:<PASSWORD>@members.dyndns.org/nic/update?SYSTEM=dyndns&hostname=<HOST-NAME>&myip=<IPADDRESS>
host-name test2.dyndns.org
username test
password test
update-interval 60
retry-interval 10 maximum-retries 5
!
interface eth1
encapsulation ppp 0
!
interface ppp0
ip ddns-update-method dyndns
ppp ipcp dns request
keepalive
ip address negotiated
ppp username user@isp2
ppp password isppasswd2
ip tcp adjust-mss pmtu
!
interface eth2
ip address 192.168.20.1/24
!
zone private
network lan
ip subnet 192.168.20.0/24
network peer
ip subnet 192.168.10.0/24 interface tunnel0
network tunnel
ip subnet 172.16.0.0/30
!
zone public
network wan
ip subnet 0.0.0.0/0 interface ppp0
host ppp0
ip address dynamic interface ppp0
!
application esp
protocol 50
!
application isakmp
protocol udp
sport 500
dport 500
!
firewall
rule 10 permit any from private to private
rule 20 permit any from private to public
rule 30 permit isakmp from public.wan.ppp0 to public.wan
rule 40 permit isakmp from public.wan to public.wan.ppp0
rule 50 permit esp from public.wan.ppp0 to public.wan
rule 60 permit esp from public.wan to public.wan.ppp0
rule 70 permit dns from public.wan.ppp0 to public.wan
rule 80 permit https from public.wan.ppp0 to public.wan
protect
!
nat
rule 10 masq any from private to public
enable
!
crypto isakmp key secret hostname test1.dyndns.org
!
interface tunnel0
mtu 1300
tunnel source ppp0
tunnel destination test1.dyndns.org
tunnel local name test2.dyndns.org
tunnel remote name test1.dyndns.org
tunnel protection ipsec
tunnel mode ipsec ipv4
ip address 172.16.0.2/30
ip tcp adjust-mss 1260
!
ping-poll 1
ip 172.16.0.1
active
!
trigger 1
type ping-poll 1 down
script 1 periodic-update.scp
trigger 2
type ping-poll 1 up
script 1 periodic-update-delete.scp
trigger 3
type periodic 1
script 1 host-change.scp
!
ip route 0.0.0.0/0 ppp0
ip route 192.168.10.0/24 tunnel0
ip route 192.168.10.0/24 Null 254
!
ip dns forwarding
!
end
ルーターAのトリガースクリプト
■ periodic-update.scp
enable
con t
trigger 3
active
end
■ periodic-update-delete.scp
enable
con t
trigger 3
no active
end
■ host-change.scp
enable
clear isakmp sa peer test2.dyndns.org force
con t
int tunnel0
tunnel destination test2.dyndns.org
end
ルーターBのトリガースクリプト
■ periodic-update.scp
enable
con t
trigger 3
active
end
■ periodic-update-delete.scp
enable
con t
trigger 3
no active
end
■ host-change.scp
enable
clear isakmp sa peer test1.dyndns.org force
con t
int tunnel0
tunnel destination test1.dyndns.org
end
(C) 2016 - 2019 アライドテレシスホールディングス株式会社
PN: 613-002311 Rev.S