Interview surprise: Why does TCP need a three-way handshake?

Interview surprise: Why does TCP need a three-way handshake?

The TCP three-way handshake is a classic interview question. It means that before TCP transmits data, it needs to interact three times to formally establish a connection and transmit data. The reason why TCP needs three handshakes is that both sides of TCP are full-duplex. The so-called full-duplex means that either end of TCP is both the sender and the receiver of data. Therefore, this requires both sides of TCP communication to ensure their own sending capabilities and receiving capabilities. This is like when making a phone call, both parties must ensure that their microphones (transmitting sound) and headphones (receiving sound) are normal, so that effective communication can be carried out. Usually, when making a phone call, it starts like this:

  • Me: Hello, can you hear me?
  • Other person: I can hear you, can you hear me?
  • Me: I can hear you, so let’s get down to business.

The same is true for TCP three-way handshake. The capabilities of the three-way handshake are as follows:

TCP three-way handshake process

The TCP three-way handshake process is as follows:

  • The client sends SYN to the server, indicating that it wishes to establish a connection;
  • After receiving the message, the server responds with a SYN and ACK (confirmation response) to the client;
  • After receiving the SYN message from the server, the client responds with an ACK message.

The specific execution process is shown in the following figure:

Summarize

The reason why TCP needs three handshakes is that both parties of TCP communication are full-duplex, so three interactions are required to confirm the sending and receiving capabilities of both parties, and the TCP handshake must be three times. If it is a two-way handshake, it cannot prove the sending capability of the server and the receiving capability of the client; it cannot be a four-way handshake either, because if three handshakes can already prove something, there is no need for another interactive handshake.

References & Acknowledgements

"Code Efficiently: Java Development Manual"

《Offer is coming》

<<:  AI identification and root cause location of 5G wireless problems help improve network quality

>>:  5G and its impact on the Internet of Things

Recommend

PacificRack: $8/month Windows VPS-4GB/60G SSD/30M unlimited/Los Angeles

At the end of last month, I just shared the news ...

New wireless technology extends 5G value proposition indoors

Since most 5G networks are deployed using the 3.5...

Modbus protocol: the cornerstone of industrial communication

In the wave of modern industrial automation, real...

The impact of the novel coronavirus on remote networking

As the new coronavirus spreads widely, many compa...

The second half of the 5G era begins

On June 6, 2019, China officially issued 5G licen...

Is the network model seven layers, five layers, or four layers?

When we are doing network development, we often h...

10 Things You Need to Know About Cisco Global Gold Certification

Welcome to Cisco Global Gold! For the first time ...

All in ONE! Borei Data launches an integrated intelligent observability platform

On May 20, Borei Data officially launched the int...

With the launch of 5G and Wi-Fi 6, where will wireless network products go?

Today, topics about 5G and Wi-Fi are endless, and...