設定例集#15: L2TPv3+IPsec VPNを利用したIEEE 802.1Qタグ付きパケットのブリッジング


構成
ルーターAの設定
ルーターBの設定
設定の保存
ファイアウォールログについて
ルーターAのコンフィグ
ルーターBのコンフィグ



本社・支社間のL2TPv3トンネル上でIEEE 802.1Qタグ付きパケットをリモートブリッジし、VLANネットワークを共有します。
この例ではL2TPv3トンネルをIPsec(ESP)で保護し、データの安全性も確保しています。

構成

 
ルーターA
(本社)
ルーターB
(支社)
ISPから提供された情報
ISP接続用ユーザー名 user@ispA user@ispB
ISP接続用パスワード isppasswdA isppasswdB
PPPoEサービス名 指定なし 指定なし
WAN側IPアドレス 10.1.1.1/32 10.1.1.2/32
ルーターの基本設定
WAN側物理インターフェース eth1 eth1
WAN側(ppp0)IPアドレス 10.1.1.1/32 10.1.1.2/32


[事前共有鍵]

ルーター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接続のための設定を行います。

    ・LCP EchoによるPPP接続状態の確認(keepalive
    ・IPCPによるIPアドレスの取得要求(ip address negotiated
    ・ユーザー名(ppp username
    ・パスワード(ppp password
    ・MSS書き換え(ip tcp adjust-mss

    PPPの詳細は「PPP」/「一般設定」をご覧ください。

    interface ppp0
     keepalive
     ip address negotiated
     ppp username userA@isp
     ppp password isppasswdA
     ip tcp adjust-mss pmtu
    

  4. VLANを作成します。
    これには、vlan databaseコマンドとvlanコマンドを使います。
    VLANの詳細は「L2スイッチング」/「バーチャルLAN」をご覧ください。

    vlan database
     vlan 2-3 state enable
    

  5. LANポート1.0.1をvlan2とvlan3のタグ付きポートに設定します。
    これには、switchport modeコマンド、switchport trunk allowed vlanコマンドを使います。
    VLANについては「L2スイッチング」/「バーチャルLAN」をご覧ください。

    interface port1.0.1
     switchport
     switchport mode trunk
     switchport trunk allowed vlan add 2-3
    

  6. ソフトウェアブリッジ「2」と「3」を作成します。これには、bridgeコマンドを使います。
    ブリッジングの詳細は「ブリッジング」/「一般設定」をご覧ください。

    bridge 2
    bridge 3
    

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

    crypto isakmp key secret address 10.1.1.2
    

  8. L2TPv3トンネルインターフェースtunnel0を作成し、さらにその上にvlan2とvlan3のタグ付きパケットを送受信する802.1Qサブインターフェースtunnel0.2とtunnel0.3を作成します。
    トンネルインターフェースはinterfaceコマンドで作成し、802.1Qサブインターフェースはencapsulation dot1qコマンドで作成します。また、L2TPv3の接続に必要な下記の設定を行います。

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

    トンネルインターフェースの詳細は「VPN」/「トンネルインターフェース」を、L2TPv3の詳細は「VPN」/「L2TPv3」を、IPsecの詳細は「VPN」/「IPsec」をご覧ください。

    interface tunnel0
     encapsulation dot1q 2
     encapsulation dot1q 3
     tunnel source ppp0
     tunnel destination 10.1.1.2
     tunnel local id 1
     tunnel remote id 2
     tunnel mode l2tp v3
     tunnel protection ipsec
     mtu 1500
    

  9. ソフトウェアブリッジ「2」に802.1Qサブインターフェースtunnel0.2をブリッジポートとして追加します。これにはbridge-groupコマンドを使います。

    interface tunnel0.2
     mtu 1500
     bridge-group 2
    

  10. ソフトウェアブリッジ「3」に802.1Qサブインターフェースtunnel0.3をブリッジポートとして追加します。これにはbridge-groupコマンドを使います。

    interface tunnel0.3
     mtu 1500
     bridge-group 3
    

  11. ソフトウェアブリッジ「2」にvlan2をブリッジポートとして追加します。これにはbridge-groupコマンドを使います。

    interface vlan2
     bridge-group 2
    

  12. ソフトウェアブリッジ「2」にvlan3をブリッジポートとして追加します。これにはbridge-groupコマンドを使います。

    interface vlan3
     bridge-group 3
    

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

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

    zone private
     network lan
      ip subnet 192.168.2.0/24
      ip subnet 192.168.3.0/24
    

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

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

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

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

    application esp
     protocol 50
    

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

    application isakmp
     protocol udp
     sport 500
     dport 500
    

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

    ・rule 10 - 内部から内部への通信を許可します
    ・rule 20 - 内部から外部への通信を許可します
    ・rule 30, 40 - ISAKMPパケットを許可します
    ・rule 50, 60 - IPsec(ESP)パケットを許可します
    ・rule 70, 80 - L2TPパケットを許可します

    ファイアウォールの詳細は「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 l2tp from public.wan.ppp0 to public.wan
     rule 80 permit l2tp from public.wan to public.wan.ppp0
     protect
    

  18. デフォルト経路をPPPインターフェースppp0に向けます。これにはip routeコマンドを使います。
    IP経路設定の詳細は「IPルーティング」/「経路制御」をご覧ください。

    ip route 0.0.0.0/0 ppp0
    

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

    end
    


ルーターBの設定

  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接続のための設定を行います。

    ・LCP EchoによるPPP接続状態の確認(keepalive
    ・IPCPによるIPアドレスの取得要求(ip address negotiated
    ・ユーザー名(ppp username
    ・パスワード(ppp password
    ・MSS書き換え(ip tcp adjust-mss

    PPPの詳細は「PPP」/「一般設定」をご覧ください。

    interface ppp0
     keepalive
     ip address negotiated
     ppp username userB@isp
     ppp password isppasswdB
     ip tcp adjust-mss pmtu
    

  4. VLANを作成します。
    これには、vlan databaseコマンドとvlanコマンドを使います。
    VLANの詳細は「L2スイッチング」/「バーチャルLAN」をご覧ください。

    vlan database
     vlan 2-3 state enable
    

  5. LANポート1.0.1をvlan2とvlan3のタグ付きポートに設定します。
    これには、switchport modeコマンド、switchport trunk allowed vlanコマンドを使います。
    VLANについては「L2スイッチング」/「バーチャルLAN」をご覧ください。

    interface port1.0.1
     switchport
     switchport mode trunk
     switchport trunk allowed vlan add 2-3
    

  6. ソフトウェアブリッジ「2」と「3」を作成します。これには、bridgeコマンドを使います。
    ブリッジングの詳細は「ブリッジング」/「一般設定」をご覧ください。

    bridge 2
    bridge 3
    

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

    crypto isakmp key secret address 10.1.1.1
    

  8. L2TPv3トンネルインターフェースtunnel0を作成し、さらにその上にvlan2とvlan3のタグ付きパケットを送受信する802.1Qサブインターフェースtunnel0.2とtunnel0.3を作成します。
    トンネルインターフェースはinterfaceコマンドで作成し、802.1Qサブインターフェースはencapsulation dot1qコマンドで作成します。また、L2TPv3の接続に必要な下記の設定を行います。

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

    トンネルインターフェースの詳細は「VPN」/「トンネルインターフェース」を、L2TPv3の詳細は「VPN」/「L2TPv3」を、IPsecの詳細は「VPN」/「IPsec」をご覧ください。

    interface tunnel0
     encapsulation dot1q 2
     encapsulation dot1q 3
     tunnel source ppp0
     tunnel destination 10.1.1.1
     tunnel local id 2
     tunnel remote id 1
     tunnel mode l2tp v3
     tunnel protection ipsec
     mtu 1500
    

  9. ソフトウェアブリッジ「2」に802.1Qサブインターフェースtunnel0.2をブリッジポートとして追加します。これにはbridge-groupコマンドを使います。

    interface tunnel0.2
     mtu 1500
     bridge-group 2
    

  10. ソフトウェアブリッジ「3」に802.1Qサブインターフェースtunnel0.3をブリッジポートとして追加します。これにはbridge-groupコマンドを使います。

    interface tunnel0.3
     mtu 1500
     bridge-group 3
    

  11. ソフトウェアブリッジ「2」にvlan2をブリッジポートとして追加します。これにはbridge-groupコマンドを使います。

    interface vlan2
     bridge-group 2
    

  12. ソフトウェアブリッジ「2」にvlan3をブリッジポートとして追加します。これにはbridge-groupコマンドを使います。

    interface vlan3
     bridge-group 3
    

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

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

    zone private
     network lan
      ip subnet 192.168.2.0/24
      ip subnet 192.168.3.0/24
    

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

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

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

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

    application esp
     protocol 50
    

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

    application isakmp
     protocol udp
     sport 500
     dport 500
    

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

    ・rule 10 - 内部から内部への通信を許可します
    ・rule 20 - 内部から外部への通信を許可します
    ・rule 30, 40 - ISAKMPパケットを許可します
    ・rule 50, 60 - IPsec(ESP)パケットを許可します
    ・rule 70, 80 - L2TPパケットを許可します

    ファイアウォールの詳細は「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 l2tp from public.wan.ppp0 to public.wan
     rule 80 permit l2tp from public.wan to public.wan.ppp0
     protect
    

  18. デフォルト経路をPPPインターフェースppp0に向けます。これにはip routeコマンドを使います。
    IP経路設定の詳細は「IPルーティング」/「経路制御」をご覧ください。

    ip route 0.0.0.0/0 ppp0
    

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

    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 program kernel msgtext Firewall


■ 記録されたログを見るには、次のコマンド(show log)を実行します。ここでは、ファイアウォールが出力したログメッセージだけを表示させています。

awplus# show log | include firewall


ルーターAのコンフィグ

!
no spanning-tree rstp enable
!
interface eth1
 encapsulation ppp 0
!
interface ppp0
 keepalive
 ip address negotiated
 ppp username userA@isp
 ppp password isppasswdA
 ip tcp adjust-mss pmtu
!
vlan database
 vlan 2-3 state enable
!
interface port1.0.1
 switchport
 switchport mode trunk
 switchport trunk allowed vlan add 2-3
!
bridge 2
bridge 3
!
crypto isakmp key secret address 10.1.1.2
!
interface tunnel0
 encapsulation dot1q 2
 encapsulation dot1q 3
 tunnel source ppp0
 tunnel destination 10.1.1.2
 tunnel local id 1
 tunnel remote id 2
 tunnel mode l2tp v3
 tunnel protection ipsec
 mtu 1500
!
interface tunnel0.2
 mtu 1500
 bridge-group 2
!
interface tunnel0.3
 mtu 1500
 bridge-group 3
!
interface vlan2
 bridge-group 2
!
interface vlan3
 bridge-group 3
!
zone private
 network lan
  ip subnet 192.168.2.0/24
  ip subnet 192.168.3.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 l2tp from public.wan.ppp0 to public.wan
 rule 80 permit l2tp from public.wan to public.wan.ppp0
 protect
!
ip route 0.0.0.0/0 ppp0
!
end


ルーターBのコンフィグ

!
no spanning-tree rstp enable
!
interface eth1
 encapsulation ppp 0
!
interface ppp0
 keepalive
 ip address negotiated
 ppp username userB@isp
 ppp password isppasswdB
 ip tcp adjust-mss pmtu
!
vlan database
 vlan 2-3 state enable
!
interface port1.0.1
 switchport
 switchport mode trunk
 switchport trunk allowed vlan add 2-3
!
bridge 2
bridge 3
!
crypto isakmp key secret address 10.1.1.1
!
interface tunnel0
 encapsulation dot1q 2
 encapsulation dot1q 3
 tunnel source ppp0
 tunnel destination 10.1.1.1
 tunnel local id 2
 tunnel remote id 1
 tunnel mode l2tp v3
 tunnel protection ipsec
 mtu 1500
!
interface tunnel0.2
 mtu 1500
 bridge-group 2
!
interface tunnel0.3
 mtu 1500
 bridge-group 3
!
interface vlan2
 bridge-group 2
!
interface vlan3
 bridge-group 3
!
zone private
 network lan
  ip subnet 192.168.2.0/24
  ip subnet 192.168.3.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 l2tp from public.wan.ppp0 to public.wan
 rule 80 permit l2tp from public.wan to public.wan.ppp0
 protect
!
ip route 0.0.0.0/0 ppp0
!
end




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

PN: 613-002107 Rev.J