


TCP 接続の 3 ウェイ ハンドシェイクと 4 ウェイ ハンドシェイクのプロセス TCP 3 ウェイ ハンドシェイクとは何ですか? TCP は 3 ウェイ ハンドシェイク ポイントを使用します。
TCP 接続を使用してデータを送信するプロセスでは、クライアントとサーバーは接続を確立するために 3 方向ハンドシェイクを実行し、切断するために 4 方向ハンドシェイクを実行する必要があります。
詳細は以下の図に示されています
上図は、TCP接続の確立から切断までの詳細なプロセスを示しています。具体的なメッセージの詳細については、以下で説明します。
接続を確立するための TCP スリーウェイ ハンドシェイク中に、クライアントはまず SYN=1, Sequence=p 要求パケットをサーバーに送信します。
サーバーがクライアントにリンクを許可することに同意すると、ACK=p+1、SYN=1、Sequence=qの応答パケットを送信します。
最後に、クライアントはサーバーから応答パケットを受信した後、サーバーにも応答パケットを送信します。具体的な内容はACK=q+1、SYN=0、Sequence=p+1です。
TCP 切断には 4 回のハンドシェイクが必要ですが、なぜ 3 回のハンドシェイクではないのでしょうか? 具体的な理由は次のとおりです:
サーバーはクライアントから SYN 接続要求メッセージを受信すると、SYN+ACK メッセージを直接送信できます。 ACK メッセージは応答に使用され、SYN メッセージは同期に使用されます。しかし、接続を閉じるとき、サーバーが FIN メッセージを受信したときに、SOCKET はすぐには閉じられない可能性が高いため、最初に ACK メッセージで応答し、クライアントに「送信された FIN メッセージを受信しました。 」 FIN メッセージはサーバー側のすべてのメッセージが送信された場合にのみ送信できるため、一緒に送信することはできません。したがって、4 段階のハンドシェイクが必要です。
切断のプロセスは最初にクライアントによって開始されます。まず、クライアントはFIN=1およびSequence=mを使用して切断要求パケットを送信します。
リクエストを受信した後、サーバーは確認パケットACK=m+1、Sequence=nを送信します。
この時点で、クライアントからサーバーへの一方的な接続が切断され、クライアントはサーバーにデータ パケットを送信しなくなります。サーバーは、データ パケットの送信後にクライアントにデータを送信する必要がない場合でも、この時点でクライアントに切断要求を送信できます。 FIN=1、シーケンス=m+s、ACK=m+1。
クライアントはサーバーの切断要求を受信した後、確認パケットを送信します。 Sequence=m+1,ACK=m+s+1;
クライアントは最後の ACK パケットを送信した後も、パケットが失われる可能性があるため、2MSL (最大セグメント生存時間) 待機することに注意してください。クライアントは、サーバーが ACK パケットを受信しないことを懸念し、FIN 要求を再送信するため、2MSL を待ちます。
以上、TCP 接続と 3 ウェイ ハンドシェイクの内容を含め、TCP 接続の 3 ウェイ ハンドシェイクと 4 ウェイ ハンドシェイクの解消プロセスを紹介しました。PHP チュートリアルに興味のある友人の参考になれば幸いです。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

記事では、入力検証、認証、定期的な更新など、脆弱性から保護するためのフレームワークの重要なセキュリティ機能について説明します。
