myHotTake

How Do WebSockets Power Real-Time Chat Apps?

If you find this story enjoyable and helpful, feel free to give it a like or share it with others who might also appreciate it!


I am a lighthouse keeper, responsible for ensuring ships can communicate safely as they navigate treacherous waters. In this analogy, the lighthouse represents a chat application, and the signal light is the WebSocket connection that keeps the conversation flowing smoothly and continuously.

One day, I decide to upgrade my lighthouse. Instead of using the old method of sending and receiving single, isolated light signals (much like the traditional HTTP requests), I install a new, light that can stay on and allow for real-time communication. This is my WebSocket.

To set it up, I first establish a connection with a ship out at sea. I shine my light in a specific pattern, like a handshake, to start the conversation. This is akin to opening a WebSocket connection using JavaScript’s new WebSocket(url) method, where url is the address of the server.

Once the connection is established, my light allows me to send messages back and forth with the ship without having to reinitiate contact each time. I simply flash a message in Morse code, and the ship quickly responds with its own message. This is like using the ws.send(message) method to send information and the ws.onmessage event listener to receive messages instantly.

If a storm suddenly hits, I need a way to gracefully close the communication channel to prevent confusion. I signal to the ship with a special pattern, indicating that we will temporarily cease communication. This is similar to using the ws.close() method to close the WebSocket connection gracefully.

Throughout the night, as long as the weather holds and the connection is stable, my light keeps shining, ensuring that the ships and I can communicate seamlessly. This continuous interaction is the beauty of WebSocket: a persistent connection that facilitates real-time, bidirectional data exchange.

So, in this story, I am the lighthouse keeper, and the WebSocket is my beacon of light, enabling smooth, ongoing conversations between the shore and the sea, much like a chat application keeps users connected in real time.


Establishing the Connection

Just as I would shine the light to establish a connection with a ship, in JavaScript, I initiate a WebSocket connection using:

const socket = new WebSocket('ws://example.com/socket');

This line of code tells my application to reach out to a specific server, much like my lighthouse reaching out to a distant ship.

Handling Incoming Messages

To keep the conversation going, I need to listen for incoming messages from the ship. In JavaScript, I set up an event listener for messages:

socket.onmessage = function(event) {
  console.log('Message from server ', event.data);
};

This code acts like my ability to read the Morse code flashed back by the ship, allowing me to understand and process the message.

Sending Messages

When I want to send a message, I use my light to flash a pattern. In the chat application, sending a message is as simple as:

socket.send('Hello, ship!');

This sends a string through the WebSocket, much like my lighthouse would send a message across the water.

Closing the Connection

If I need to stop communication, I signal with my light. In JavaScript, I close the connection gracefully:

socket.close();

This tells the server that I’m done communicating for now, just like lowering my light to indicate the end of our conversation.

Final Thoughts

  • Persistent Connection: WebSockets provide a continuous, open connection, much like the ever-present light of the lighthouse, enabling real-time communication.
  • Bidirectional Communication: Messages can be sent and received without the overhead of constantly reopening a connection, just like smoothly exchanging signals with ships.
  • Efficiency: WebSockets are efficient for chat applications because they reduce the latency and bandwidth usage compared to traditional HTTP requests.

Comments

Leave a Reply

Your email address will not be published. Required fields are marked *