TCP/IP

TCP/IPはプロトコルスタックの一種です。
OSI参照モデルよりも運用重視で、普及していきました。

TCPIPという2つのプロトコルを中心に4つのレイヤで構成されています。

  • アプリケーション層…ネットワークアプリケーションに必要なサービスを定義
  • トランスポート層…アプリケーション層のプロトコルに信頼性のあるサービスを提供
  • インターネット層…エンドツーエンドのデバイス間でパケットを転送するためのサービスを提供
  • リンク層…同一の物理ネットワークの隣接ノードと通信を行うために必要なプロトコルを定義

PDU

データ+ヘッダ(+トレーラ)のおデータ単位をPDU(Protocol Data Unit)といい各層の呼び名がOSI参照モデルと少し異なります。

<OSI参照モデルのPDU

<TCP/IPのPDU>

【TCPヘッダとUDPヘッダ】

  • トランスポート層ではTCPヘッダまだはUDPヘッダを付加してカプセル化します。
  • UDPにはないけど、TCPにはシーケンス番号確認応答番号があります。

Eahernetフレーム

  • ブリアンブル(7バイト)
  • SFD(1バイト)
  • 宛先MACアドレス(6バイト)
  • 送信元MACアドレス(6バイト)
  • タイプ(6バイト)
  • IPヘッダ、データ等(46〜1500バイト)
  • トレーラ(FCS)(4バイト)
    …Frame Check Sequenceと呼ばれるエラー検出用のフィールド。FCSはCRC値を格納しています。

IP

  • IP(Internet Protocol)はインターネット層で中心的な役割を担うプロトコルです。
  • IPアドレス論理アドレス)を使用してエンドツーエンドの通信を可能にします。
  • コネクションレス型‥送りっぱなし、届いたかどうかは関知しない
  • ベストエフォート型‥保証はしないが最善は尽くすという通信タイプ
  • データ回復機能なし‥データ破棄したら、再要求しない
  • 階層型アドレス方式…IPアドレスは、ネットワーク部とホスト部の2階層で構成する、階層型のアドレス方式になっています。

IPヘッダ(IPv4)

  • サービスタイプ‥パケットの送信優先度に応じた最適な通信を行うて目の仕組み
  • TTL(生存時間)‥ルータを中継できる回数
  • プロトコル‥上位のプロトコルを表す番号
  • ヘッダチェックサム‥送信時の情報が、受診時に壊れていないかチェックする

フラグメンテーションフラグメント処理

一度に伝送したいデータがMTU(エムティーユー / Maximum Transmission Unit)を超えた場合に、分割して送信することをフラグメント処理、フラグメンテーションといいます。

識別子、フラグ、フラグメントオフセットフラグメン処理に関与しています。

IPアドレス

https://ntorelabo.com/2022/09/08/ip%e3%82%a2%e3%83%89%e3%83%ac%e3%82%b9/

IPv4においてIPアドレスアドレスは32ビット持ち、ネットワークを表すネットワーク部と個々のノードを表すホスト部で構成される。

IPアドレスのクラス

https://ntorelabo.com/2022/10/13/arp/

TCP

  • TCP(Transmission Control Protocol)はインターネットにおいて標準的に利用されているプロトコルです。
  • 3ハンドシェイクによるコネクション型(信頼性を高めるために送信元、宛先双方で状況を確認し合う)という通信方式です。
  • オーバーヘッドが大きい
  • ウィンドウサイズを利用したフロー制御
  • 同期通信(データが正しく受信されたかどうか確認しながらやりとりする通信)

3ウェイハンドシェイク

  • ACKによる到達確認
  • TCPコネクションはデータを送信し始める前に確立する

TCPヘッダ

送信データはセグメント(ヘッダーとデータ)という単位送信されます。

  • 送信元、宛先ポート番号(16)
  • シーケンス番号(32)
  • 確認応答番号(32)
  • データオフセット(4)、予約(6)、制御ビット(6)
  • ウィンドウサイズ(16)
  • チェックサム(16)
  • 緊急ポインタ(16)
  • オプション・パディング(可変)

シーケンス番号

送信元→返信に送信する、分割データが元データと比較してどの位置にあるかを示す番号。送信時に分割されたデータはこれを手がかりに再構成される。

確認応答番号(ACK番号)

宛先→送信元に送信する、次に受信したいデータのシーケンス番号を送信元に示す番号。送信元はこれを受け取ると、「直前までのデータの送信の成功」を理解する。

ウィンドウ制御

ウィンドウと呼ばれる送信可能なサイズ幅を管理しつつ、確認応答を待たずに次々とデータを送信する、送信側の機能。

フロー制御

高負荷で処理がもたつきバッファ(データを一時的に保存ができる領域)が溢れそうな時などにウィンドウサイズを調整することで受信料(送信側の送信量)をコントロールする受信側の機能。

輻輳制御

ウィンドウサイズ分一気に送ってしまうと受信側の状況によっては処理しきれえず輻輳(ネットワーク上の混雑)を起こしてしまう可能性があるため、輻輳が起きないよう慎重にデータを送信していく機能。

UDP

  • コネクションレス
  • ベストエフォート
  • UDPで扱うデータの単位はUDPデータグラムといわれます。

<UDPヘッダ>

  • 送信元、宛先ポート番号(16)
  • データ長(16)
  • チェックサム(16)

プロトコル

https://ntorelabo.com/2022/10/13/tcp-ip%e3%82%a2%e3%83%97%e3%83%aa%e3%82%b1%e3%83%bc%e3%82%b7%e3%83%a7%e3%83%b3%e5%b1%a4%e3%83%97%e3%83%ad%e3%83%88%e3%82%b3%e3%83%ab/