読み方:あいぴー
《internet protocol》プロトコル3の一種。インターネット上でコンピューター同士が通信を行うために定められた通信規約(プロトコル)。コンピューターにIPアドレスを割り振り、パケットを使って通信を行う。
IPとは、パケット交換の仕組みを用いてコンピュータやネットワークを相互接続する通信プロトコルのことである。RFC 791で定義されている。
IPはインターネット上でデータ伝送を行うためのプロトコルとして利用されている。逆に、IPによって結ばれたネットワークがインターネットである、と言うこともできる。
IPは、データ伝送を行う際、IPパケットと呼ばれる単位にデータを分割する。IPはパケット単位でコネクションを切断する(ステートレスな)伝送を行うため、ファイルなどの全体のデータ伝送を管理するためには、より上位のプロトコルであるTCPやUDPなどと共に用いる必要がある。多くの場合、IPはTCPとセットで利用され、まとめてTCP/IPとして扱われる。
IPによる通信では、相手先を指定するために、物理的なマシンを一意に特定できる、IPアドレスと呼ばれる値が用いられる。IPには、IPv4と次世代のIPv6という2つの主要なバージョンが登場している。IPv4では、IPアドレスは32ビット幅で表現されるが、そのアドレス空間には遠からず限界が訪れると指摘されている。一方、IPv6では、IPアドレスを現す部分は128ビットに拡張されているため、ほとんど無尽蔵に近い感覚でIPアドレスを用いることができるとされる。
IPアドレスは、ネットワークを意味する情報部分と、そのネットワーク内で特定のマシンを特定する情報部分を含んでいる。同じネットワーク内のマシンに対してパケットが送出された場合には、そのネットワーク内で直接通信を行うことができる。しかし、他のネットワークと通信したい場合には、指定されたパケットをどのような経路で流すか指定する必要がある。この経路選択(ルーティング)を行うためのデータ中継機器は、ルーターと呼ばれている。ルーターは、複数のルーターをどのように経由して目的のサーバーにパケットを届けるかを規定する。この経路を決定する方式は、経路決定アルゴリズムと呼ばれ、いくつかの種類が規定されている。
なお、IPで音声データの伝送を行い、通話を実現する技術はVoIPと呼ばれ、いわゆるIP電話に利用されている。
パケット交換は、理論的には1961年に発表され、1969年に米国DARPAの資金援助により実現されたARPANETにおいて開始されたものである。TCPおよびIPが発表されたのは1974年である。1983年にARPANETのプロトコルがTCP/IPベースに変更され、現在のインターネットの源流となった。その翌年の1984年、日本では、JUNETが発足した。
出典: フリー百科事典『ウィキペディア(Wikipedia)』 (2025/09/15 02:10 UTC 版)
| TCP/IP群 |
|---|
| アプリケーション層 |
|
| トランスポート層 |
| カテゴリ |
| インターネット層 |
| カテゴリ |
| リンク層 |
| カテゴリ |
Internet Protocol (インターネット・プロトコル、IP) はインターネットにおいて基本的に利用されている通信プロトコルである[1]。
Internet Protocol は、インターネット上のホストへデータを送信するための通信プロトコルである[2]。IPの利用により、各ネットワークごとの環境の違いを意識せずに宛先へデータを送信できる(#機能)。IPを用いて接続された世界規模の情報通信網がインターネットである。IPはイントラネットでも利用される。他のプロトコルとの関係性という観点では、OSI参照モデルのネットワーク層にほぼ対応する機能を持つ。またインターネット・プロトコル・スイートの中核をなしている。
IPでは各ホストコンピュータに一意の番号/番地であるIPアドレスを割り当て(アドレッシング)、伝達したいデータをパケットへ格納し(カプセル化)、IPアドレスで指定されたホストへパケットを送信する(#仕組み)。なお、パケット送出手順を指定するがその到達は保証しないため、その保証が必要な場合は上位のプロトコルとしてTCPなどを利用することになる(#信頼性)。
歴史的には、ヴィントン・サーフとロバート・カーンが1974年に発表した Transmission Control Program のコネクションレスのデータグラムサービス部分がIPである。コネクション指向の部分は Transmission Control Protocol (TCP) となった。現在広く利用されているIPは32ビットのアドレス空間を持つ「IPv4」と128ビットのアドレス空間を持つ「IPv6」である[3](#バージョンと歴史)。
誤解に基づく俗称としてIPアドレスを「IP」と呼ぶことがある。
IPは2つの側面から理解できる。1つはIP層でのデータ転送モデル、もう1つはプロトコルスタックの層を跨いだデータ転送手順である。
IPは、パケットのヘッダ部分に記された宛先アドレスに基づいてネットワーク内でパケットを転送することによってデータを送信する。
パケット(英: packet)[4]はIPにおける送受信単位である[5]。パケットはヘッダとペイロードからなり[6]、ヘッダの情報に基づいて宛先アドレスの経路へと送られる[7]。ヘッダ(英: header)[8]はメタデータの集合であり、バージョン番号・送信元アドレス・宛先アドレスなど、送受信に必要な情報が含まれている。ペイロード(英: payload)[9]はパケットのヘッダ以外の部分であり[10]、IPで転送するコンテンツが主体で、場合によりメタデータも含んでいる。
パケットは送信元から宛先へ直接送られるのではなく、いくつものホスト (gateway) を経由する。Gatewayはヘッダの宛先アドレスを確認し、宛先への経路上にある次のGateway(あるいは宛先そのもの)へとパケットを転送する。これを繰り返すことでパケットは最終的に宛先アドレスに到達する[11]。
経路上に転送可能サイズ上限があった場合はパケットが弾かれる可能性がある。IPではパケット長制限が無い代わりに、フラグメント化機能(パケットを小パケットへ分割する機能)を提供してこの制約を回避する。
IPはプロトコルスタックの1層をなす[12]。すなわち上層から転送対象と宛先アドレスを受け取り、リンク層へパケットを渡す[13]。
IPでは、各々のLANで通信可能な範囲をセグメントと呼び、セグメント内のコンピュータをホストと呼ぶ。同じセグメントに属するホスト同士はそのLANで使用されている通信プロトコルをデータリンク層とし、その上のネットワーク層で稼動する。
つまり同じセグメントに属するホスト同士は(IP以前からそうであったように)直接通信する。IPはセグメントの外と通信することが可能であり、そして何も変更せずに(全く同じ機器/ソフトウェア構成で)セグメント内とセグメント外との区別なく通信が可能となることである。そのため、LAN内の通信にあえてIPを使うイントラネットを採用することで、インターネット用のソフトウェア資産やノウハウをそのままLAN内通信に利用することができる。
同じセグメント内のホスト同士の通信では、そのLANで使われているプロトコルを使って通信する。そのためIPの各実装では、そのLANで使われているプロトコルから完全に独立することはできない。
まず、送信先となるIPアドレスを持つホストにデータリンク層のデータとして送信するために必要な情報を収集しなければならない。例えばイーサネットであれば、送信先のIPアドレスを持つホストのインターフェースが持っているMACアドレスが対象となる。そのためにブロードキャストもしくはマルチキャストによってその特定のIPアドレスを持つホストに返答を要求する。そのIPアドレスを持っているホストはそれに対してMACアドレスを返答する。
一般にブロードキャストは負荷が高くLAN内の通信を阻害するため、こうして得られたMACアドレスは今後同じIPアドレスに送信するときには再度ブロードキャストせずに、キャッシュに控えておく。
IPの実装では、こうしたアドレス解決と実際の送受信部分だけはデータリンク層のプロトコルに依存することになる。しかしこの依存部分は、実際にそのデータリンク層のプロトコル を使うホストでのみ必要になるため、世界中に存在する各セグメントとの通信の際には問題にならない。異なるデータリンク層のプロトコル を使うセグメントに分かれたホスト同士の通信の場合は、後述するゲートウェイがこれを解決する。
セグメントとセグメントの間、あるいはセグメントとWANの間にはルーティングを行なうための特別なホストであるルータが設置される。ルータにはあらかじめ、自身が繋がれているそれぞれのセグメントにいるホストのIPアドレスを教えてある。これはルーティングテーブルと呼ばれる。ルータは、一方のセグメントのホストから他方のセグメントのホストにパケットが送られようとしているとき、いったん受信側のホストの代わりにパケットを前者のLANのプロトコルで受け取る。ルーティングテーブルを参照してどのセグメントに送ればいいかを選択し、そのパケットを後者のLANのプロトコルで後者のホストに送る。ルータはルーティングテーブルにより、どのIPアドレスに送るにはどのセグメントに送ればよいかを把握している。経路の一部が破壊されても、このルーティングテーブルを書き換えるだけで破壊箇所を迂回することが可能になる。
ルータと似ているが、ルーティングテーブルを持たず、異なるLANのプロトコルを変換して互いに中継するブリッジと呼ばれるものがある。しかしブリッジはIPより下位の層(OSI参照モデルのデータリンク層)の機器であり、IPとは関係なく動作する。
また特に、異なるプロトコルを用いるセグメント同士の間をつなぐルータはゲートウェイ(門)と呼ばれる。本来、ゲートウェイはOSI参照モデルのネットワーク層におけるブリッジに相当するルータの基本機能の一部だが、セグメントのほとんどがイーサネットになっているため、特にセグメントとWANとの間にあるルータだけがゲートウェイであることが多い。またルータが把握していないIPアドレスは(ルーティング処理の一環として)全てデフォルトゲートウェイと呼ばれる特別なゲートウェイに送られる。デフォルトゲートウェイは通常WANとの接続部分にあるため、未知のIPアドレスへのパケットは全てWAN側(外の世界)のルータにパケットを送信することになる。そしてWANのルータが送信先となるIPアドレスの存在するセグメントのゲートウェイにパケットを送信し、ゲートウェイが送信先となるIPアドレスを持つホストにパケットを送信することで世界中のホストと通信が行なわれる。
Internet Protocol は、ホストのアドレッシング[14]とデータグラム(パケット)の送信元ホストから宛先ホストまでの1つまたは複数のIPネットワークをまたいだルーティングを担当する。このために、ホストの識別と論理的位置サービスの提供という2つの機能を持つアドレッシング体系を定義している。これは、標準データグラムと標準アドレッシング体系を定義することでなされる。
データグラムはヘッダとペイロードで構成される。IPヘッダには、送信元IPアドレス、宛先IPアドレス、データグラムのルーティングや転送に必要なメタデータが含まれる。ペイロードは転送すべきデータである。このようにデータ・ペイロードにパケットのヘッダを付与して入れ子状に構成していくことをカプセル化と呼ぶ。
IPアドレッシングとは、各ホストにIPアドレスを割り当てる方法であり、IPホストアドレス群を分割・グループ化してサブネットワークを形成する方法である。IPルーティングは全てのホストが行うが、最も重要な部分はルータが担っており、経路を決定するのに Interior Gateway Protocol (IGP) または Exterior Gateway Protocol (EGP) を使用する。
IPは「独立した単一パケットを、送信元から宛先へ、ネットワークのネットワークを介して、送ること」のみを上手くシンプルに扱うよう設計されている[15]。ゆえに意図時に提供しない機能がある[16]。
すなわち、送出に焦点を合わせているのでACKチェックや再送をおこなわない。また単一パッケージ管理を扱うので複数パケットに跨る流量制御や順序制御には関与しない。
IPの設計原理は、ネットワーク基盤はどのネットワーク要素や伝送媒体をとっても本質的に信頼できないと仮定しており、また、リンクやノードの可用性の面でも一定でないと仮定している。ネットワークの状態を追跡し維持する集中監視機能や性能測定機能は存在しない。ネットワークを単純化するため、知的な部分は意図的に各データ転送の端点であるノードに担わせ、これをエンドツーエンド原理と呼ぶ。転送経路の途中に位置するルーターは、宛先アドレスのルーティングプレフィックスにマッチする最も近いゲートウェイにパケットを転送するだけである。
このような設計の結果、IPはベストエフォート式配送のみを提供し、「信頼できない」と見なされている[誰によって?]。ネットワークアーキテクチャとしては「コネクションレス」プロトコルであり、コネクション指向の転送モードとは対照的である。信頼性がないため、データが壊れたり、パケットを消失したり、パケットが複製されたり、パケットの順序が入れ替わって受信されたりする。ルーティングはパケット毎に動的に行われ、ネットワークは以前のパケットが通った経路についても状態情報を保持しない。そのため一部のパケットが他より長い経路を通ることがあり、受信側でパケットを受信する順序がおかしくなる可能性がある。
信頼性のないIPv4で唯一確かなのは、IPパケットのヘッダには誤りがないという点である。ルーティングするノードは、パケットのチェックサムを計算する。もしチェックサムが合わない場合、そのノードはそのパケットを捨てる。そのノードは送信元にも宛先にも捨てたことを通知しないが、Internet Control Message Protocol (ICMP) でそのような通知をすることも可能である。一方、IPv6ではルーティングの高速化を優先してチェックサム計算をやめた。
上位層プロトコルは、この信頼性問題への対処を担う。例えば、アプリケーションにデータを渡す前にデータをキャッシュして正しい順序に並べ替えたりする。
信頼性問題に加え、動的性質とインターネットおよびその構成要素の多様性に関連し、データ転送経路のうちどれが適当かは全く保証できない。技術的制約の1つとして、リンクごとにデータパケットのサイズ上限が異なる。アプリケーションは適切な伝送特性を使うことを保証しなければならない。この責任の一端は、IPとアプリケーションの中間に位置する上位層プロトコル群にもある。ローカルなリンクにおける Maximum Transmission Unit (MTU) のサイズを調べるファシリティがあり、IPv6の場合は宛先までの経路全体を考慮したMTUサイズを調べるファシリティもある。IPv4には元のデータグラムを自動的に断片化する機能がある。この場合、IPは断片化されたパケット群の到着順序を正しく保つ必要がある[17]。
例えば Transmission Control Protocol (TCP) はセグメントサイズをMTUより小さく調整するプロトコルである。User Datagram Protocol (UDP) と Internet Control Message Protocol (ICMP) はMTUサイズを無視するので、必要ならIPが断片化を行う[18]。
1974年5月、Institute of Electrical and Electronic Engineers (IEEE) が "A Protocol for Packet Network Intercommunication" と題した論文を公表した[19]。この論文で筆者ヴィントン・サーフとロバート・カーンは、ノード間のパケット交換を使ってリソースを共有するインターネットワーキング・プロトコルを記述した。このモデルの中心となる制御コンポーネントが "Transmission Control Program" (TCP) で、コネクション指向のリンクとデータグラムサービスの両方を含んでいた。モノリシックな Transmission Control Program は後にモジュール化され、コネクション指向層の Transmission Control Protocol とインターネットワーキング(データグラム)層の Internet Protocol に分けられた。このモデルが一般に TCP/IP と呼ばれ、正式にはインターネット・プロトコル・スイートと呼ばれている。
Internet Protocol はインターネットを定義する要素の1つである。インターネット層におけるインターネットワーキング・プロトコルで2024年現在主に使われているのはIPv4 RFC 791 (1981) である。この4という番号はプロトコルのバージョン番号で、全てのIPデータグラムの先頭に書かれている。
IPアドレスの不足が発生することが予測されることから開発されたIPv4の後継がIPv6である。IPv4からの最大の変更点はアドレッシング体系である。IPv4は32ビットのアドレス(約40億、4.3×109)を使っていたが、IPv6では128ビットのアドレス(約 3.4×1038)を使っている。IPv6の採用はあまり拡大していないが、2008年6月、アメリカ合衆国連邦政府がバックボーンレベルのみではあるが全システムでIPv6のサポートを開始した[20]。
IPは様々な攻撃に対して脆弱である。網羅的な脆弱性アセスメントが対策の提案と共に2008年に公表され[24]、その後IETF内で対策を検討中である[25]。