設定例集#16: アプリケーションコントロール(DPI = ディープパケットインスペクション)
本製品のアプリケーションコントロール(DPI = ディープパケットインスペクション)機能を利用すると、従来型ファイアウォールのようなIPアドレスやポート番号だけでなく、パケットのデータ部を監視することで特定のアプリケーションによる通信をコントロールすることが可能です。
この例では、サンドバイン社が提供するアプリケーションシグネチャデータベースを用いて、ルーター配下からのファイル共有ソフトShareとWinnyを使用したインターネットへの通信を制限しています。
なお、製品内蔵のアプリケーションシグネチャデータベースを使う場合の設定については、備考をご覧ください。
構成

| ISP接続用ユーザー名 | user@isp |
| ISP接続用パスワード | isppasswd |
| PPPoEサービス名 | 指定なし |
| WAN側IPアドレス | 動的割り当て(IPCP) |
| 接続形態 | 端末型 |
| WAN側物理インターフェース | eth1 |
| WAN側(ppp0)IPアドレス | 接続時にISPから取得 |
| LAN側(vlan1)IPアドレス | 192.168.10.1/24 |
設定開始前に
自動設定の確認と削除
本設定例に掲載されているコマンドは、設定がまったく行われていない本製品の初期状態(スタートアップコンフィグなしで起動した状態)から入力することを前提としています。そのため、通常は erase startup-config を実行し、スタートアップコンフィグが存在しない状態で起動してから、設定を始めてください。
ただし、本製品はスタートアップコンフィグなしで起動した場合でも、特定の条件を満たすと自動的な設定を行うことがあるため、その場合は設定例にしたがってコマンドを入力しても、コマンドがエラーになったり、全体として意図した動作にならない可能性があります。
これを避けるため、設定開始にあたっては次のいずれかの方法をとることをおすすめします。
- ネットワークケーブルを接続せずに起動する。
起動時に自動設定が実行されるための条件の一つに、特定インターフェースのリンクアップがあります。
ネットワークケーブルを接続しない状態で起動することにより、自動設定の適用を回避できます。
- 自動設定を手動で削除してから設定を行う。
前記の方法を採用できず自動設定が適用されてしまった場合は、「自動的な設定内容の削除」にしたがって、これらを手動で削除してから設定を開始してください。
システム時刻の設定
ログなどの記録日時を正確に保ち、各種機能を適切に動作させるため、システム時刻は正確にあわせて運用することをおすすめします。ご使用の環境にあわせ、次のいずれかの方法でシステム時刻を設定してください。
- 手動で設定する方法 - 「運用・管理」/「システム」
- NTPで自動設定する方法 - 「運用・管理」/「NTP」
ルーターの設定
- LANポートにおいて初期状態で有効化されているスパニングツリープロトコル(RSTP)を無効化します。これにはspanning-tree enableコマンドをno形式で実行します。
スパニングツリープロトコルの詳細は「L2スイッチング」/「スパニングツリープロトコル」をご覧ください。
no spanning-tree rstp enable
- DNS問い合わせ機能を有効にします。これには、ip domain-lookupコマンドを使います。
ip domain-lookup
- WANポートeth1上にPPPoEインターフェースppp0を作成します。これには、encapsulation pppコマンドを使います。
PPPの詳細は「PPP」/「一般設定」をご覧ください。
interface eth1 encapsulation ppp 0
- 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@isp ppp password isppasswd ip tcp adjust-mss pmtu
- LAN側インターフェースvlan1にIPアドレスを設定します。これにはip addressコマンドを使います。
IPインターフェースの詳細は「IP」/「IPインターフェース」をご覧ください。
interface vlan1 ip address 192.168.10.1/24
- アプリケーションコントロール(DPI)機能の設定を行います。
これには、dpi、provider、enableの各コマンドを使います。
アプリケーションコントロール(DPI)の詳細は「UTM」/「アプリケーションコントロール(DPI)」をご覧ください。
dpi provider procera enable
- ファイアウォールやNATのルール作成時に使うエンティティー(通信主体)を定義します。
エンティティー定義の詳細は「UTM」/「エンティティー定義」をご覧ください。
内部ネットワークを表すゾーン「private」を作成します。
これには、zone、network、ip subnetの各コマンドを使います。
zone private network lan ip subnet 192.168.10.0/24
- 外部ネットワークを表すゾーン「public」を作成します。
前記コマンドに加え、ここではhost、ip addressの各コマンドも使います。
zone public network wan ip subnet 0.0.0.0/0 interface ppp0 host ppp0 ip address dynamic interface ppp0
- 外部からの通信を遮断しつつ、内部からの通信は自由に行えるようにするファイアウォール機能の設定を行います。
これには、firewall、rule、protectの各コマンドを使います。
ここでは、アプリケーションコントロール(DPI)機能によってShareおよびWinnyの通信と判別された内→外のトラフィックを破棄するよう設定しています。
・rule 10 - 内部から外部への Share(sharep2p)通信を破棄します
・rule 20 - 内部から外部への Winny(winny)通信を破棄します
・rule 30 - 内部から内部への通信を許可します
・rule 40 - 内部から外部への通信を許可します
・rule 50 - アプリケーションシグネチャデータベースのダウンロード用に、本製品のWAN側インターフェースから外部へのDNS通信を許可します
・rule 60, 70, 80 - アプリケーションシグネチャデータベースのダウンロード用に、本製品のWAN側インターフェースから外部へのHTTPS、SSL、TCP通信を許可します
・rule 90 - 本製品のWAN側インターフェースから外部への通信について、DPIによる判別が完了していないトラフィックを許可します
(DPI機能の有効時には事前定義アプリケーション「dns」よりもDPIアプリケーション「dns」が優先されるため、ルール「50」を機能させるためにこのルールが必要です)
ファイアウォールの詳細は「UTM」/「ファイアウォール」をご覧ください。
firewall rule 10 deny sharep2p from private to public rule 20 deny winny from private to public rule 30 permit any from private to private rule 40 permit any from private to public rule 50 permit dns from public.wan.ppp0 to public rule 60 permit https from public.wan.ppp0 to public rule 70 permit ssl from public.wan.ppp0 to public rule 80 permit TCP from public.wan.ppp0 to public rule 90 permit undecided from public.wan.ppp0 to public protect
- LAN側ネットワークに接続されているすべてのコンピューターがダイナミックENAT機能を使用できるよう設定します。
これには、nat、rule、enableの各コマンドを使います。
NATの詳細は「UTM」/「NAT」をご覧ください。
nat rule 10 masq any from private to public enable
- デフォルト経路をPPPインターフェースppp0に向けます。これにはip routeコマンドを使います。
IP経路設定の詳細は「IP」/「経路制御」をご覧ください。
ip route 0.0.0.0/0 ppp0
- 以上で設定は完了です。
end
備考:製品内蔵のアプリケーションシグネチャデータベースを使う場合
サンドバイン社が提供するアプリケーションシグネチャデータベースではなく、製品内蔵のデータベースを使用する場合は一部の設定を変更する必要があります。以下、変更点だけを示します。
- アプリケーションシグネチャデータベースの提供元を製品内蔵のもの(built-in)に変更します。
dpi provider built-in enable
- ファイアウォールの設定を変更します。
アプリケーション「sharep2p」と「winny」は製品内蔵データベースでは検知できないため、検知可能なアプリケーションに変更します。
ここでは例として「facebook」と「youtube」を使用し、該当アプリケーションを破棄するよう設定します。
また、rule 50以降をまとめて1つのルールにします。
firewall rule 10 deny facebook from private to public rule 20 deny youtube from private to public rule 30 permit any from private to private rule 40 permit any from private to public rule 50 permit any from public.wan.ppp0 to public protect
設定の保存
設定が完了したら、現在の設定内容を起動時コンフィグとして保存してください。これには、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 local5
記録されたログを見るには、次のコマンド(show log)を実行します。ここでは、ファイアウォールが出力したログメッセージだけを表示させています。
awplus# show log | include Firewall
ルーターのコンフィグ
! no spanning-tree rstp enable ! ip domain-lookup ! interface eth1 encapsulation ppp 0 ! interface ppp0 ppp ipcp dns request keepalive ip address negotiated ppp username user@isp ppp password isppasswd ip tcp adjust-mss pmtu ! interface vlan1 ip address 192.168.10.1/24 ! dpi provider procera enable ! zone private network lan ip subnet 192.168.10.0/24 ! zone public network wan ip subnet 0.0.0.0/0 interface ppp0 host ppp0 ip address dynamic interface ppp0 ! firewall rule 10 deny sharep2p from private to public rule 20 deny winny from private to public rule 30 permit any from private to private rule 40 permit any from private to public rule 50 permit dns from public.wan.ppp0 to public rule 60 permit https from public.wan.ppp0 to public rule 70 permit ssl from public.wan.ppp0 to public rule 80 permit TCP from public.wan.ppp0 to public rule 90 permit undecided from public.wan.ppp0 to public protect ! nat rule 10 masq any from private to public enable ! ip route 0.0.0.0/0 ppp0 ! end