設定例集#18: PPPoE接続環境におけるARX640Sとの2点間IPsec VPN(両側アドレス固定)


構成
ルーターA(本製品)の設定
ルーターB(ARX640S)の設定
設定の保存
ルーターA(本製品)のコンフィグ
ルーターB(ARX640S)のコンフィグ



PPPoEでインターネットに接続している拠点間をIPsecで結ぶVPN構築例です。
インターネットサービスプロバイダー(以下 ISP)から固定IPアドレスが割り当てられるルーター間をIPsec(ESP)トンネルで接続します。
この例では対向ルーターとして弊社のARX640Sを想定しています。

構成

 
ルーターA
(本製品)
ルーターB
(ARX640S)
ISPから提供された情報
ISP接続用ユーザー名 user@ispA user@ispB
ISP接続用パスワード isppasswdA isppasswdB
PPPoEサービス名 指定なし 指定なし
WAN側IPアドレス 10.10.10.1/32 10.20.20.1/32
ルーターの基本設定
WAN側物理インターフェース eth1 gigabitEthernet0
WAN側(ppp0)IPアドレス 10.10.10.1/32 10.20.20.1/32
LAN側(vlan1)IPアドレス 192.168.10.1/24 192.168.20.1/24
IPsecトンネル(tunnel0)IPアドレス 172.16.0.1/30 172.16.0.2/30


[事前共有鍵]

ルーターA(本製品)の設定

  1. LANポートにおいて初期状態で有効化されているスパニングツリープロトコル(RSTP)を無効化します。これにはspanning-tree enableコマンドをno形式で実行します。
    スパニングツリープロトコルの詳細は「L2スイッチング」/「スパニングツリープロトコル」をご覧ください。

    no spanning-tree rstp enable
    

  2. WANポートeth1上にPPPoEインターフェースppp0を作成します。これには、encapsulation pppコマンドを使います。
    PPPの詳細は「PPP」/「一般設定」をご覧ください。

    interface eth1
     encapsulation ppp 0
    

  3. PPPインターフェースppp0に対し、PPPoE接続のための設定を行います。

    ・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
     ppp ipcp dns request
     keepalive
     ip address negotiated
     ppp username user@ispA
     ppp password isppasswdA
     ip tcp adjust-mss 1414
    

  4. LAN側インターフェースvlan1にIPアドレスを設定します。これにはip addressコマンドを使います。
    IPインターフェースの詳細は「IPルーティング」/「IPインターフェース」をご覧ください。

    interface vlan1
     ip address 192.168.10.1/24
    

  5. ファイアウォールやNATのルール作成時に使うエンティティー(通信主体)を定義します。
    エンティティー定義の詳細は「UTM」/「エンティティー定義」をご覧ください。

    内部ネットワークを表すゾーン「private」を作成します。
    これには、zonenetworkip subnetの各コマンドを使います。

    zone private
     network lan
      ip subnet 192.168.10.0/24
      ip subnet 192.168.20.0/24
    

  6. 外部ネットワークを表すゾーン「public」を作成します。
    前記コマンドに加え、ここではhostip addressの各コマンドも使います。

    zone public
     network wan
      ip subnet 0.0.0.0/0 interface ppp0
      host ppp0
       ip address dynamic interface ppp0
    

  7. ファイアウォールやNATのルール作成時に通信内容を指定するために使う「アプリケーション」を定義します。
    これには、applicationprotocolsportdporticmp-typeicmp-codeの各コマンドを使います。
    アプリケーション定義の詳細は「UTM」/「アプリケーション定義」をご覧ください。

    IPsecのESPパケットを表すカスタムアプリケーション「esp」を定義します。

    application esp
     protocol 50
    

  8. ISAKMPパケットを表すカスタムアプリケーション「isakmp」を定義します。

    application isakmp
     protocol udp
     sport 500
     dport 500
    

  9. 外部からの通信を遮断しつつ、内部からの通信は自由に行えるようにするファイアウォール機能の設定を行います。
    これには、firewallruleprotectの各コマンドを使います。

    ・rule 10 - 内部から内部への通信を許可します
    ・rule 20 - 内部から外部への通信を許可します
    ・rule 30, 40 - ISAKMPパケットを許可します
    ・rule 50, 60 - IPsec(ESP)パケットを許可します
    ・rule 70 - 本製品のWAN側インターフェースから外部へのDNS通信を許可します

    ファイアウォールの詳細は「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
     protect
    

  10. LAN側ネットワークに接続されているすべてのコンピューターがダイナミックENAT機能を使用できるよう設定します。
    これには、natruleenableの各コマンドを使います。
    NATの詳細は「UTM」/「NAT」をご覧ください。

    nat
     rule 10 masq any from private to public
     enable
    

  11. 対向ルーターとの間で使用するISAKMPの事前共有鍵を設定します。これにはcrypto isakmp keyコマンドを使います。

    crypto isakmp key secret address 10.20.20.1
    

  12. IPsecトンネルインターフェースtunnel0を作成します。
    トンネルインターフェースの詳細は「VPN」/「トンネルインターフェース」を、IPsecの詳細は「VPN」/「IPsec」をご覧ください。

    これには、interfaceコマンドでトンネルインターフェースを作成し、以下の情報を設定します。

    ・トンネルインターフェースのIPアドレス(ip address
    ・トンネルインターフェースから送信するデリバリーパケットの始点(自装置)アドレス(tunnel source
    ・トンネルインターフェースから送信するデリバリーパケットの終点(対向装置)アドレス(tunnel destination
    ・トンネリング方式(tunnel mode ipsec
    ・トンネルインターフェースに対するIPsec保護の適用(tunnel protection ipsec

    interface tunnel0
     ip address 172.16.0.1/30
     tunnel source ppp0
     tunnel destination 10.20.20.1
     tunnel mode ipsec ipv4
     tunnel protection ipsec
    

  13. DNSリレー機能を有効にします。これには、ip dns forwardingコマンドを使います。
    DNSリレー機能の詳細は「IP付加機能」/「DNSリレー」をご覧ください。

    ip dns forwarding
    

  14. デフォルト経路(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
    

  15. 以上で設定は完了です。

    end
    


ルーターB(ARX640S)の設定

Note - ARX640Sの設定に関する詳細は、ARX640Sのドキュメントをご参照ください。

  1. IPインターフェースがリンクダウンしているときでも、そのインターフェース宛の通信に応答できるように設定します。

    ip address-up-always
    

  2. ISPから通知されたPPPユーザー名やパスワード等のPPP設定情報を作成します。

    ppp profile pppoe0
     my-username user@ispB password isppasswdB
    

  3. WAN0インターフェース(gigabitEthernet 0)を有効にします。

    interface gigabitEthernet 0
     no shutdown
    

  4. WAN0インターフェース上にPPPoEインターフェース(gigabitEthernet 0.1)を作成し、インターフェースを使用できるようにします。
    接続時にIPアドレス割り当ての要求を行うように設定し、このインターフェース上で使用するPPP設定情報を括り付けます。
    また、LAN側ネットワークに接続されているすべてのコンピューターがENAT(NAPT)機能を使用できるよう設定します。
    外部からのアタック検出時やアタック発生中にパケットを破棄するように設定します。

    interface gigabitEthernet 0.1
     ip address ipcp
     ip tcp mss auto
     no shutdown
     pppoe enable
      ppp bind-profile pppoe0
     ip napt inside any
     ip traffic-filter pppoe0-in in
     ip traffic-filter pppoe0-out out
     ip ids in protect
    

  5. LAN側インターフェース(vlan 1)にIPアドレスを設定します。

    interface vlan 1
     ip address 192.168.20.1/24
     no shutdown
    

  6. トンネルインターフェース(tunnel 0)を作成し、インターフェースを使用できるようにします。
    このトンネルインターフェースに対応するIPsecポリシーを設定します。

    interface tunnel 0
     tunnel mode ipsec
     ip address 172.16.0.2/30
     ip tcp mss auto
     no shutdown
     tunnel policy vpn
    

  7. IPsec処理の適用対象パケットを指定するためのアクセスリストipsecを作成します。

    access-list ip extended ipsec
     permit ip any any
    

  8. ISAKMPパケットだけを許可し他の通信はすべて遮断するアクセスリストpppoe-inを作成します。

    access-list ip extended pppoe0-in
     dynamic permit udp any interface gigabitEthernet 0.1 eq 500
    

  9. すべての通信を許可するアクセスリストpppoe0-outを作成します。

    access-list ip extended pppoe0-out 
     dynamic permit ip any any
    

  10. フェーズ1のプロポーザルを設定します。

    isakmp proposal isakmp encryption aes256 prf sha1 hash sha1 group 14 
    isakmp proposal isakmp lifetime 86400
    

  11. ISAKMPポリシーを設定します。

    isakmp policy vpn
     peer 10.10.10.1
     mode ikev2
     auth preshared key secret
     proposal isakmp
     keepalive enable
     nat-traversal enable
    

  12. フェーズ2のプロポーザルを設定します。

    ipsec proposal ipsec esp encryption aes256 hash sha1 
    ipsec proposal ipsec lifetime 28800
    

  13. IPsecポリシーを設定します。

    ipsec policy vpn
     peer 10.10.10.1
     access-list ipsec
     proposal ipsec
     always-up-sa
    

  14. DNSリレー機能を有効にします。

    proxydns ip enable
    

  15. デフォルト経路(0.0.0.0/0)とルーターAのLAN側(192.168.10.0/24)への経路を設定します。
    ただし、ルーター間のVPN接続が有効になるまでは、対向側LANへの経路は使用できないように設定します。

    ip route default gigabitEthernet 0.1
    ip route 192.168.10.0/24 tunnel 0
    ip route 192.168.10.0/24 Null 254
    

  16. 以上で設定は完了です。

    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]


その他、設定保存の詳細については「運用・管理」/「コンフィグレーション」をご覧ください。

ルーターA(本製品)のコンフィグ

!
no spanning-tree rstp enable
!
interface eth1
 encapsulation ppp 0
!
interface ppp0
 ppp ipcp dns request
 keepalive
 ip address negotiated
 ppp username user@ispA
 ppp password isppasswdA
 ip tcp adjust-mss 1414
!
interface vlan1
 ip address 192.168.10.1/24
!
zone private
 network lan
  ip subnet 192.168.10.0/24
  ip subnet 192.168.20.0/24
!
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
 protect
!
nat
 rule 10 masq any from private to public
 enable
!
crypto isakmp key secret address 10.20.20.1
!
interface tunnel0
 ip address 172.16.0.1/30
 tunnel source ppp0
 tunnel destination 10.20.20.1
 tunnel mode ipsec ipv4
 tunnel protection ipsec
!
ip dns forwarding
!
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
!
end


ルーターB(ARX640S)のコンフィグ

Note - ARX640Sの設定に関する詳細は、ARX640Sのドキュメントをご参照ください。

!
ip address-up-always
!
ppp profile pppoe0
 my-username user@ispB password isppasswdB
!
interface gigabitEthernet 0
 no shutdown
!
interface gigabitEthernet 0.1
 ip address ipcp
 ip tcp mss auto
 no shutdown
 pppoe enable
  ppp bind-profile pppoe0
 ip napt inside any
 ip traffic-filter pppoe0-in in
 ip traffic-filter pppoe0-out out
 ip ids in protect
!
interface vlan 1
 ip address 192.168.20.1/24
 no shutdown
!
interface tunnel 0
 tunnel mode ipsec
 ip address 172.16.0.2/30
 ip tcp mss auto
 no shutdown
 tunnel policy vpn
!
access-list ip extended ipsec
 permit ip any any
!
access-list ip extended pppoe0-in
 dynamic permit udp any interface gigabitEthernet 0.1 eq 500
!
access-list ip extended pppoe0-out 
 dynamic permit ip any any
!
isakmp proposal isakmp encryption aes256 prf sha1 hash sha1 group 14 
isakmp proposal isakmp lifetime 86400
!
isakmp policy vpn
 peer 10.10.10.1
 mode ikev2
 auth preshared key secret
 proposal isakmp
 keepalive enable
 nat-traversal enable
!
ipsec proposal ipsec esp encryption aes256 hash sha1 
ipsec proposal ipsec lifetime 28800
!
ipsec policy vpn
 peer 10.10.10.1
 access-list ipsec
 proposal ipsec
 always-up-sa
!
proxydns ip enable
!
ip route default gigabitEthernet 0.1
ip route 192.168.10.0/24 tunnel 0
ip route 192.168.10.0/24 Null 254
!
end




(C) 2015 アライドテレシスホールディングス株式会社

PN: 613-002107 Rev.F