Streaming of Data Using Python between two different Machines

Streaming data from one Python code to another is a common task when working with distributed systems. This allows different parts of a system to communicate and exchange data in real-time, enabling a wide range of use cases such as data processing, machine learning, and real-time analytics. In this article, we will look at how to stream data from one Python code to another running on different machines.

To stream data from one Python code to another, we need to use a protocol that allows the transfer of data over a network connection. A common protocol for this purpose is the Transmission Control Protocol (TCP), which provides a reliable and efficient means of transmitting data over the network.

The following is an example of how to stream data from one Python code to another running on different machines:

Source or Sender Machine-A

This code runs on the machine where the data is generated and will be streamed to another machine. The following code generates random numbers and sends them to the destination machine over a TCP connection:

import socket
import random

def send_data():
    sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    server_address = ('destination_machine_ip', 12345)
    sock.connect(server_address)

    while True:
        data = str(random.randint(0, 100)) + "\n"
        sock.sendall(data.encode())
        
if __name__ == "__main__":
    send_data()

In this code, we first create a TCP socket using the socket module. The socket.AF_INET parameter specifies that we are using the IP version 4 protocol, and the socket.SOCK_STREAM parameter specifies that we are using TCP.

Next, we connect to the destination machine using the connect method and specify the IP address and port number of the destination machine. In this example, the destination machine IP is destination_machine_ip and the port number is 12345.

In the while loop, we generate a random number and convert it to a string. We then encode the string and send it to the destination machine using the sendall method.

Destination or Receiver Machine-B

This code runs on the machine where the data will be received from the source machine. The following code listens for incoming data over a TCP connection and prints the received data:

import socket

def receive_data():
    sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    server_address = ('0.0.0.0', 12345)
    sock.bind(server_address)
    sock.listen(1)

    connection, client_address = sock.accept()

    while True:
        data = connection.recv(16)
        if data:
            print(data.decode(), end="")
        else:
            break
        
if __name__ == "__main__":
    receive_data()

In this code, we create a TCP socket and bind it to a specific IP address and port number using the bind method. The 0.0.0.0 IP address specifies that we are listening for incoming connections from any IP address. The listen method specifies that we are allowing one incoming connection.

Next,

, we use the accept method to listen for incoming connections and get the first connection that arrives. The connection.recv method is used to receive the incoming data in chunks of 16 bytes. We decode the received data and print it to the console.

Note that in this example, we are only receiving and printing the data, but in a real-world scenario, you may want to process the data in some way before saving it to a database or a file, for example.

Idea behind this Streaming of Data Using Python

In this article, we have seen how to stream data from one Python code to another running on different machines. We used the TCP protocol to transfer the data and the socket module in Python to implement the communication.

This is just a basic example and there are many other ways to stream data from one Python code to another, such as using the User Datagram Protocol (UDP), WebSockets, or other protocols. However, the concepts and techniques used in this example can be applied to other methods as well.

With this knowledge, you can now start implementing real-time data streaming in your own projects and unlock new possibilities for data processing and analysis.

Subscribe
Notify of
1 Comment
Most Voted
Newest Oldest
Inline Feedbacks
View all comments
Scroll to Top