Address Class

Class 1 2 3 4 5 6-8 9-16 17-24 25-32
A 0 Network ID Host ID
B 1 0 Network ID Host ID
C 1 1 0 Network Id Host ID
D 1 1 1 0 Multicast Address
E 1 1 1 1 0 Reserved

Class E is reserved for IAB, so we can not use.

Network ID

ID that represents local network.

Host ID

ID that represents one host.

Number of addresses

Class Network Host
A 126 16,777,214
B 16,382 65,534
C 2,097,150 254

Address Meaning

Network ID Host ID  
0 0 Used when emitting host doesn’t know own address for bootstrap, etc. Special use.
0 Host Number Network
Network Number 1 for all Broadcast for the network
127 Whatever For loopback test

Multihomed host

  • ルータではないホストは、複数のループバックではないネットワークインターフェースを持つことができる。
    • 例 * 有線LANインターフェースと無線LANインターフェース
    • 必ずしも物理的に異なるインターフェースでなくてもよい。
      • ひとつのインターフェースに複数のIPを関連づけることもできる。
        • ひとつのMACアドレスを共有することになる。
    • サーバとして動く場合や異なるドメイン名に対応する場合に用いられる。
  • RFC 1222
    • The Strong End-System model: IPアドレスごとにMACアドレスを分ける
    • The Weak End-System model: IPアドレスでMACアドレスをシェア
      • Linuxはデフォルトでこのモデルを使用。
      • ARP Request に対して1つのMACアドレスしか返さないので、LAN内の通信では速度の早いIPだけ使われることになる場合がある。

Address Resolution Protocol

  • ARP: IP アドレスから MAC アドレスを取得する。
  • RARP: MAC アドレス から IP アドレス を取得する。

プロセス

  1. あるホストが、 Broadcast で知りたい IP アドレスを送る。
    • 「このIP持っているのは誰ですか?」
    • ブロードキャストで送るデータには、送信元ホスト自身の IP アドレス と MAC アドレス を 含める。
  2. 前述のブロードキャストを受け取ったホストで、IPが該当するホストは、自身がリプライするべきだとわかる。
  3. ARP Cacheの更新
    • 該当ホストが 送信元を ARP Cache に追加する。
    • ブロードキャストを受け取った他のホストは、送信元ホストのエントリが ARP Cache にあれば上書きする。
      • これは、イーサネットインターフェースが交換された場合に、古いキャッシュを使ってしまわないようにするのに役立つ。
        • USB のインターフェースは簡単に交換できる。
  4. 該当ホストが 送信元ホストへ ARP のリプライを送る、 または送信元LANへの “is-at” メッセージ を送る。
    • ユニキャスト (1対1の通信、ブロードキャストではない。)
    • 送信されるデータには、 MACアドレスが含まれる。

ARP cache

  • すべてのホストは ARP Cache を管理している。
  • 各エントリは、 IPv4 と LAN Address (MAC Address) のペア
  • ARP のブロードキャストで応答があった場合、 ブロードキャストしたホストと、応答したホストは、相手のホストをエントリに追加する。
  • ARP キャッシュのエントリは、 10分程度で期限切れとなる。
    • Linux ではもっと短い間隔で期限切れになる。 (2012年では30秒以内だった)
  • タイムアウトしたエントリに対するARPクエリは、最初に、ブロードキャストではなくユニキャストで、前のイーサネットアドレスに送信される。
    • ブロードキャストトラフィックの総量を削減する。
  • ARPキャッシュの調べ方
    • Linux: ip -sneigh
    • windows: arp-a

ARP Spoofing

  • ホストBがホストSになりすまして、正しい接続元ホストAからのアクセスを受ける例
    1. Bは、Sのスケジュールされたダウンタイムまで待機するか、Sに対してDOS攻撃を行って、Sがダウンしている状態にする。
    2. Aが接続を試みるときに、Sを探すARPリクエストを行う。
    3. Bは B の MACAddress を Sのものとしてリプライを返す。
      • Bが自分のIPアドレスをSのIPアドレスに変更すればよい。
    4. AはBに接続し、Bにパスワードを送信する。
    5. BはSへの接続情報を手に入れる。
    6. BはAに、あとで接続を促すメッセージを返すなどする。
  • SSH の相手のキーが変更されて場合に受け取るメッセージは、 ARP Spoofing の可能性を示唆している。

ARP failover

  • できること
    • サーバーAとB (Bは例えばバックアップ用) について、 Aがフリーズした場合にBが介入できるようにする。
  • 手順
    1. A の IP と B の IP を同じものに設定します。
      • 当面はBがネットワークを使用しないため、この重複は問題にならない。
    2. Bは、Aがダウンしているというメッセージを取得したら、 A の IP への ARPクエリーを、 BのMACアドレスつきで送信する。
    3. ゲートウェイルータは A の ARP Cache エントリを B の MACアドレス で書き換える。

Sniffer detection

  • Sniffer を検出する
    1. あるホストAがプロミスキャスモードにあるかどうかを確認するため、ARPをAに送信する。
      • ブロードキャストイーサネットアドレスではなく、存在しないイーサネットアドレスとする。
        • ブロードキャストだとA以外も反応することがある。
        • Aが全てのパケットを見ているかをチェックしたい。
    2. 応答を確認する。
      • プロミスキャスモードがオフの場合、Aのネットワークインターフェイスはパケットを無視します。
      • プロミスキャスモードがオンの場合、AのネットワークインターフェイスはARP要求をA自体に渡し、A自体がそれに応答する可能性があります。
  • Linux は ARPソフトウェアレベルで、自身以外のMACアドレスへのARPクエリを拒否する。ただし、ff:ff:ff:00:00:00やff:ff:ff:ff:ff:feなどの偽のイーサネットマルチキャストアドレスには応答する。
  • プロミスキャスモード
    • イーサネットインターフェイスなどで、自分あてだけでなく、ネットワーク上を流れている全パケットを取り込む動作モード

ARP and multihomed hosts

  • ホストAが同じLAN内に2つのインターフェース (iface1[MAC Address=A1], iface2[MAC Address=A2]) を持っている場合、 それぞれのインターフェースは交換可能なものとして使われることが多い。
    • A1へのトラフィックをiface2で受信したり、A2へのトラフィックをiface1で受診したりする。
    • A1からのトラフィックをiface2で送信したり、A2からのトラフィックをiface2で送信したりする。