この製品のマニュアルセットは、偏向のない言語を使用するように配慮されています。このマニュアルセットでの偏向のない言語とは、年齢、障害、性別、人種的アイデンティティ、民族的アイデンティティ、性的指向、社会経済的地位、およびインターセクショナリティに基づく差別を意味しない言語として定義されています。製品ソフトウェアのユーザーインターフェイスにハードコードされている言語、RFP のドキュメントに基づいて使用されている言語、または参照されているサードパーティ製品で使用されている言語によりドキュメントに例外が存在する場合があります。シスコのインクルーシブランゲージに対する取り組みの詳細は、こちらをご覧ください。
このドキュメントは、米国シスコ発行ドキュメントの参考和訳です。リンク情報につきましては、日本語版掲載時点で、英語版にアップデートがあり、リンク先のページが移動/変更されている場合がありますことをご了承ください。あくまでも参考和訳となりますので、正式な内容については米国サイトのドキュメントを参照ください。
目次
この章では、Cisco NX-OS デバイスで Dynamic Host Configuration Protocol(DHCP)スヌーピングを設定する手順について説明します。
DHCP スヌーピングは、信頼できないホストと信頼できる DHCP サーバとの間でファイアウォールのような機能を果たします。 DHCP スヌーピングでは次のアクティビティを実行します。
DHCP スヌーピングは、VLAN ベースごとにイネーブルに設定されます。 デフォルトでは、すべての VLAN でこの機能は非アクティブです。 この機能は、1 つの VLAN 上または VLAN の特定の範囲でイネーブルにできます。
DHCP スヌーピングを設定するときは、DHCP スヌーピング機能のイネーブル化と DHCP スヌーピングのグローバルなイネーブル化の違いを理解することが重要です。
DHCP スヌーピング機能は、デフォルトではディセーブルです。 DHCP スヌーピング機能がディセーブルになっていると、DHCP スヌーピングまたはこれに依存する機能を設定できません。 DHCP スヌーピングおよびその依存機能を設定するコマンドは、DHCP スヌーピングがディセーブルになっているときは使用できません。
DHCP スヌーピング機能をイネーブルにすると、スイッチで DHCP スヌーピング バインディング データベースの構築と維持が開始されます。 DHCP スヌーピング バインディング データベースに依存する機能は、その時点から使用できるようになり、設定も可能になります。
DHCP スヌーピング機能をイネーブルにしても、グローバルにイネーブルになるわけではありません。 DHCP スヌーピングをグローバルにイネーブルにするには、個別に行う必要があります。
DHCP スヌーピング機能をディセーブルにすると、スイッチから DHCP スヌーピングの設定がすべて削除されます。 DHCP スヌーピングをディセーブルにして設定を維持したい場合は、DHCP スヌーピング機能をディセーブルにするのではなく、DHCP スヌーピングをグローバルにディセーブル化します。
DHCP スヌーピングのイネーブル化の実行後、DHCP スヌーピングはデフォルトでグローバルにディセーブルになります。 グローバルなイネーブル化は第 2 レベルのイネーブル化です。これにより、DHCP スヌーピング バインディング データベースのイネーブル化とは別に、スイッチがアクティブに DHCP スヌーピングを実行しているかどうかを個別に制御できます。
DHCP スヌーピングをグローバルにイネーブルにすると、DHCP スヌーピングがイネーブルになっている VLAN の信頼できない各インターフェイスについて、受信した DHCP メッセージの検証が開始され、DHCP スヌーピング バインディング データベースを使用して、信頼できないホストからの以降の要求を検証します。
DHCP スヌーピングをグローバルにディセーブルにすると、DHCP メッセージの検証と、信頼できないホストからの以降の要求の検証を停止します。 DHCP スヌーピング バインディング データベースも削除されます。 DHCP スヌーピングをグローバルにディセーブルにしても、DHCP スヌーピングの設定や、DHCP スヌーピング機能に依存するその他の機能の設定は削除されません。
DHCP スヌーピングがトラフィックの送信元を信頼するかどうかを設定できます。 信頼できないソースの場合、トラフィック攻撃やその他の敵対的アクションが開始される可能性があります。 こうした攻撃を防ぐため、DHCP スヌーピングは信頼できない送信元からのメッセージをフィルタリングします。
企業ネットワークでは、信頼できる送信元はその企業の管理制御下にあるスイッチです。 これらのスイッチには、ネットワーク内のスイッチ、ルータ、およびサーバが含まれます。 ファイアウォールを越えるスイッチやネットワーク外のスイッチは信頼できない送信元です。 一般的に、ホスト ポートは信頼できない送信元として扱われます。
サービス プロバイダーの環境では、サービス プロバイダー ネットワークにないスイッチは、信頼できない送信元です(カスタマー スイッチなど)。 ホスト ポートは、信頼できないソースです。
Cisco Nexus 3000 シリーズ スイッチでは、接続インターフェイスの信頼状態を設定することにより送信元が信頼されることを示します。
すべてのインターフェイスのデフォルトの信頼状態は、信頼できない状態です。 DHCP サーバ インターフェイスは、信頼できるインターフェイスとして設定する必要があります。 ユーザのネットワーク内でスイッチ(スイッチまたはルータ)に接続されている場合、他のインターフェイスも信頼できるインターフェイスとして設定できます。 ホスト ポート インターフェイスは、通常、信頼できるインターフェイスとしては設定しません。
(注) |
DHCP スヌーピングを正しく機能させるためには、すべての DHCP サーバを信頼できるインターフェイス経由でスイッチに接続する必要があります。 |
DHCP スヌーピングは、代行受信した DHCP メッセージから抽出した情報を使用し、ダイナミックにデータベースを構築し維持します。 ホストが、DHCP スヌーピングがイネーブルになっている VLAN に関連付けられている場合、このデータベースには、リース IP アドレスを含む信頼できない各ホストのエントリが含まれています。 データベースには、信頼できるインターフェイスを介して接続するホストに関するエントリは保存されません。
(注) |
DHCP スヌーピング バインディング データベースは DHCP スヌーピング バインディング テーブルとも呼ばれます。 |
スイッチが特定の DHCP メッセージを受信すると、DHCP スヌーピングはデータベースをアップデートします。 たとえば、サーバからの DHCPACK メッセージをスイッチで受信すると、この機能により、データベースにエントリが追加されます。 IP アドレスのリース期限が切れると、またはホストからの DHCPRELEASE メッセージをスイッチで受信すると、この機能により、データベースのエントリが削除されます。
DHCP スヌーピング バインディング データベース内の各エントリには、ホストの MAC アドレス、リース IP アドレス、リース期間、バインディング タイプ、およびホストに関連付けられた VLAN 番号とインターフェイスの情報が含まれています。
clear ip dhcp snooping binding コマンドを使用すると、バインディング データベースからエントリ削除できます。
DHCP リレー エージェントを実行するようにデバイスを設定できます。DHCP リレー エージェントは、クライアントとサーバの間で DHCP パケットを転送します。 これは、クライアントとサーバが同じ物理サブネット上にない場合に便利な機能です。 リレー エージェントは DHCP メッセージを受信すると、新規の DHCP メッセージを生成して別のインターフェイスに送信します。 リレー エージェントはゲートウェイ アドレスを設定し(DHCP パケットの giaddr フィールド)、パケットにリレー エージェント情報のオプション(Option 82)を追加して(設定されている場合)、DHCP サーバに転送します。 サーバからの応答は、Option 82 を削除してからクライアントに転送されます。
Option 82 をイネーブルにすると、デバイスはデフォルトでバイナリの ifindex 形式を使用します。 必要に応じて Option 82 設定を変更して、代わりに符号化ストリング形式を使用できます。
(注) |
デバイスは、Option 82 情報がすでに含まれている DHCP 要求を中継するときには、Option 82 情報を変更せずに元のままの状態で要求と一緒に転送します。 |
DHCP ブロードキャスト メッセージを Virtual Routing and Forwarding(VRF; 仮想ルーティング/転送)インスタンスのクライアントから別の VRF の DHCP サーバに転送するように、DHCP リレー エージェントを設定できます。 単一の DHCP サーバを使用して複数の VRF のクライアントの DHCP をサポートできるため、IP アドレス プールを VRF ごとではなく 1 つにまとめることにより、IP アドレスを節約できます。
DHCP リレー エージェントに対する VRF サポートをイネーブルにするには、DHCP リレー エージェントに対する Option 82 をイネーブルにする必要があります。
DHCP リレー アドレスと VRF 情報を設定したインターフェイスに DHCP 要求が着信した場合、DHCP サーバのアドレスが、別の VRF のメンバであるインターフェイスのネットワークに属するものであれば、デバイスは要求に Option 82 情報を挿入し、サーバの VRF の DHCP サーバに転送されます。 Option 82 情報は次のとおりです。
DHCP 要求を受信するインターフェイスが属する VRF の名前。
DHCP 要求を受信するインターフェイスのサブネット アドレス。
DHCP 要求を受信するインターフェイスの IP アドレス。
(注) |
DHCP サーバは、[VPN identifier]、[link selection]、[server identifier override] の各オプションをサポートする必要があります。 |
デバイスは DHCP 応答メッセージを受信すると、Option 82 情報を取り除き、クライアントの VRF の DHCP クライアントに応答を転送します。
リレー バインディングは、リレー エージェントのアドレスおよびサブネットに、DHCP または BOOTP クライアントを関連付けるエントリです。 各リレー バインディングは、クライアントの MAC アドレス、アクティブなリレー エージェント アドレス、アクティブなリレー エージェント アドレス マスク、クライアントが接続されている論理および物理インターフェイス、giaddr リトライ回数、および合計リトライ回数を格納します。 giaddr リトライ回数は、リレー エージェント アドレスに送信される要求パケットの数です。合計リトライ回数は、リレー エージェントによって送信される要求パケットの合計数です。 1 つのリレー バインディング エントリが、各 DHCP または BOOTP クライアントに対して維持されます。
DHCP スヌーピングを設定する場合は、次の注意事項および制約事項を考慮してください。
パラメータ |
デフォルト |
---|---|
DHCP スヌーピング機能 |
ディセーブル |
DHCP スヌーピングのグローバルなイネーブル化 |
No |
DHCP スヌーピング VLAN |
なし |
DHCP スヌーピングの Option 82 サポート |
ディセーブル |
DHCP スヌーピング信頼状態 |
信頼できない |
コマンドまたはアクション | 目的 | |
---|---|---|
ステップ 1 | DHCP スヌーピング機能をイネーブルにします。 | DHCP スヌーピング機能がディセーブルになっていると、DHCP スヌーピングを設定できません。 詳細については、DHCP スヌーピング機能のイネーブル化またはディセーブル化を参照してください。 |
ステップ 2 | DHCP スヌーピングをグローバルにイネーブル化します。 | 詳細については、DHCP スヌーピングのグローバルなイネーブル化またはディセーブル化を参照してください。 |
ステップ 3 | 少なくとも 1 つの VLAN で、DHCP スヌーピングをイネーブルにします。 | デフォルトでは、DHCP スヌーピングはすべての VLAN でディセーブルになります。 詳細については、VLAN に対する DHCP スヌーピングのイネーブル化またはディセーブル化を参照してください。 |
ステップ 4 | DHCP サーバとスイッチが、信頼できるインターフェイスを使用して接続されていることを確認します。 | 詳細については、インターフェイスの信頼状態の設定を参照してください。 |
スイッチの DHCP スヌーピング機能をイネーブルまたはディセーブルに設定できます。 デフォルトでは、DHCP スヌーピングはディセーブルです。
DHCP スヌーピング機能をディセーブルにすると、DHCP スヌーピングの設定がすべて消去されます。 DHCP スヌーピングをオフにして DHCP スヌーピングの設定を維持したい場合は、DHCP をグローバルにディセーブル化します。
1. config t
2. [no] feature dhcp
3. (任意) show running-config dhcp
4. (任意) copy running-config startup-config
スイッチに対して DHCP スヌーピング機能のグローバルなイネーブル化またはディセーブル化が可能です。 DHCP スヌーピングをグローバルにディセーブルにすると、DHCP スヌーピングの実行や はスイッチで停止されますが、DHCP スヌーピングの設定は維持されます。
DHCP スヌーピング機能がイネーブルになっていることを確認します。 デフォルトでは、DHCP スヌーピングはグローバルにディセーブルです。
1. config t
2. [no] ip dhcp snooping
3. (任意) show running-config dhcp
4. (任意) copy running-config startup-config
1 つまたは複数の VLAN に対して DHCP スヌーピングをイネーブルまたはディセーブルに設定できます。
デフォルトでは、DHCP スヌーピングはすべての VLAN でディセーブルになります。
DHCP スヌーピングがイネーブルになっていることを確認してください。
(注) |
DHCP スヌーピングを使用して設定を行っている VLAN で VACL が設定されている場合、その VACL で DHCP サーバと DHCP ホストの間の DHCP トラフィックが許可されていることを確認します。 |
1. config t
2. [no] ip dhcp snooping vlan vlan-list
3. (任意) show running-config dhcp
4. (任意) copy running-config startup-config
DHCP スヌーピング機能では、DHCP パケットの厳密な検証をイネーブルまたはディセーブルにできます。 デフォルトでは、DHCP パケットの厳密な検証はディセーブルになっています。
1. config t
2. [no] ip dhcp packet strict-validation
3. (任意) show running-config dhcp
4. (任意) copy running-config startup-config
各インターフェイスが DHCP メッセージの送信元として信頼できるかどうかを設定できます。 DHCP の信頼状態は、次のタイプのインターフェイスに設定できます。
デフォルトでは、すべてのインターフェイスは信頼できません。
DHCP スヌーピングがイネーブルになっていることを確認してください。
1. config t
3. [no] ip dhcp snooping trust
4. (任意) show running-config dhcp
5. (任意) copy running-config startup-config
DHCP リレー エージェントをイネーブルまたはディセーブルに設定できます。 デフォルトでは、DHCP リレー エージェントはイネーブルです。
DHCP 機能がイネーブルであることを確認します。
1. config t
2. [no] ip dhcp relay
3. (任意) show ip dhcp relay
4. (任意) show running-config dhcp
5. (任意) copy running-config startup-config
ある VRF のインターフェイスで受信した DHCP 要求を、別の VRF の DHCP サーバにリレーする機能をサポートするように、デバイスを設定できます。
DHCP リレー エージェントの Option 82 をイネーブルにする必要があります。
1. config t
2. [no] ip dhcp relay information option vpn
3. [no] ip dhcp relay sub-option type cisco
4. (任意) show ip dhcp relay
5. (任意) show running-config dhcp
6. (任意) copy running-config startup-config
レイヤ 2 インターフェイスにスタティック DHCP ソース バインディングを作成できます。
DHCP スヌーピング機能がイネーブルになっていることを確認します。
1. config t
2. ip source binding IP-address MAC-address vlan vlan-id {interface ethernet slot/port | port-channel channel-no}
3. (任意) show ip dhcp snooping binding
4. (任意) show ip dhcp snooping binding dynamic
5. (任意) copy running-config startup-config
次に、イーサネット インターフェイス 2/3 上に、VLAN 100 に関連付ける固定 IP ソース エントリを作成する例を示します。
switch# configure terminal switch(config)# ip source binding 10.5.22.7 001f.28bd.0013 vlan 100 interface ethernet 2/3 switch(config)#
DHCP スヌーピングの設定情報を表示するには、次のいずれかの作業を行います。 これらのコマンド出力のフィールドの詳細については、『』、『Cisco Nexus 3000 Series NX-OS System Management Configuration Guide』を参照してください。
コマンド |
目的 |
---|---|
show running-config dhcp |
DHCP スヌーピング設定を表示します。 |
show ip dhcp snooping |
DHCP スヌーピングに関する一般的な情報を表示します。 |
DHCP スタティックおよびダイナミック バインディング テーブルを表示するには、show ip dhcp snooping binding コマンドを使用します。 DHCP ダイナミック バインディング テーブルを表示するには、show ip dhcp snooping binding dynamic を使用します。
このコマンドの出力フィールドの詳細については、『』、『Cisco Nexus 3000 Series NX-OS System Management Configuration Guide』を参照してください。
次に、スタティック DHCP バインディングを作成してから、show ip dhcp snooping binding コマンドを使用してバインディングを確認する例を示します。
switch# configuration terminal switch(config)# ip source binding 10.20.30.40 0000.1111.2222 vlan 400 interface port-channel 500 switch(config)# show ip dhcp snooping binding MacAddress IpAddress LeaseSec Type VLAN Interface ----------------- --------------- -------- ---------- ---- ------------- 00:00:11:11:22:22 10.20.30.40 infinite static 400 port-channel500
DHCP スヌーピング バインディング データベースからエントリを削除できます。1 つのエントリ、インターフェイスに関連するすべてのエントリ、データベース内のすべてのエントリなどを削除することが可能です。
DHCP スヌーピングがイネーブルになっていることを確認してください。
1. (任意) clear ip dhcp snooping binding
2. (任意) clear ip dhcp snooping binding interface ethernet slot/port[.subinterface-number]
3. (任意) clear ip dhcp snooping binding interface port-channel channel-number[.subchannel-number]
4. (任意) clear ip dhcp snooping binding vlan vlan-id mac mac-address ip ip-address interface {ethernet slot/port[.subinterface-number | port-channel channel-number[.subchannel-number] }
5. (任意) show ip dhcp snooping binding
次に、2 つの VLAN 上で DHCP スヌーピングをイネーブルにして、Option 82 サポートをイネーブルにし、さらに DHCP サーバがイーサネット インターフェイス 2/5 に接続されているためにそのインターフェイスを信頼できるインターフェイスとして設定する例を示します。
feature dhcp ip dhcp snooping ip dhcp snooping info option interface Ethernet 2/5 ip dhcp snooping trust ip dhcp snooping vlan 1 ip dhcp snooping vlan 50