উদাহরণসহ Network Communication এ FlatBuffers এর প্রয়োগ

FlatBuffers এবং Network Communication - ফ্লাট বাফারস (Flat Buffers) - Latest Technologies

232

FlatBuffers নেটওয়ার্ক কমিউনিকেশনে দ্রুত ডাটা সিরিয়ালাইজ এবং ডেসিরিয়ালাইজ করার জন্য একটি কার্যকর মাধ্যম। এটি সাধারণত ক্লায়েন্ট-সার্ভার যোগাযোগে, সেন্সর ডাটা ট্রান্সমিশনে এবং রিয়েল-টাইম কমিউনিকেশন সিস্টেমে ব্যবহার করা হয়। এখানে উদাহরণসহ FlatBuffers ব্যবহার করে নেটওয়ার্ক কমিউনিকেশন কীভাবে করা যায় তা দেখানো হলো।

উদাহরণ: ক্লায়েন্ট-সার্ভার ডাটা আদান-প্রদান

ধরুন, একটি সার্ভারে IoT ডিভাইস তার ডাটা পাঠাচ্ছে যেখানে প্রতিটি ডাটা প্যাকেটে সেন্সরের টাইপ, মান এবং টাইমস্ট্যাম্প রয়েছে। FlatBuffers ব্যবহার করে ডাটা কম্প্যাক্ট আকারে সিরিয়ালাইজ এবং দ্রুত নেটওয়ার্কে পাঠানো যাবে।

Step 1: স্কিমা তৈরি করা

প্রথমে একটি .fbs ফাইল তৈরি করতে হবে যা ডাটার স্ট্রাকচার ডিফাইন করবে। এটি সার্ভার এবং ক্লায়েন্ট উভয়ের জন্যই প্রয়োজন হবে।

// sensor_data.fbs
namespace Network;

table SensorData {
  sensor_type: string;
  value: float;
  timestamp: long;
}

root_type SensorData;

Step 2: FlatBuffers থেকে কোড জেনারেট করা

FlatBuffers কম্পাইলার (flatc) ব্যবহার করে .fbs ফাইলটি থেকে কোড জেনারেট করতে হবে যা সিরিয়ালাইজ এবং ডেসিরিয়ালাইজ করতে ব্যবহৃত হবে। উদাহরণস্বরূপ, Python এ কোড জেনারেট করতে কমান্ডটি হবে:

flatc --python sensor_data.fbs

Step 3: ক্লায়েন্ট সাইডে ডাটা সিরিয়ালাইজ এবং পাঠানো

FlatBuffers দিয়ে সেন্সর ডাটা সিরিয়ালাইজ করে তা TCP স্যকেটের মাধ্যমে সার্ভারে পাঠানো হবে।

import Network.SensorData as SensorData
from flatbuffers import Builder
import time
import socket

def send_sensor_data():
    # FlatBuffer বিল্ডার তৈরি
    builder = Builder(1024)

    # ডাটা তৈরি করা
    sensor_type = builder.CreateString("Temperature")
    timestamp = int(time.time())

    # SensorData টেবিল সিরিয়ালাইজ করা
    SensorData.Start(builder)
    SensorData.AddSensorType(builder, sensor_type)
    SensorData.AddValue(builder, 23.5)
    SensorData.AddTimestamp(builder, timestamp)
    sensor_data = SensorData.End(builder)

    builder.Finish(sensor_data)

    # সিরিয়ালাইজড ডাটা
    serialized_data = builder.Output()

    # নেটওয়ার্কে পাঠানো (TCP স্যকেটের মাধ্যমে)
    with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as sock:
        sock.connect(('127.0.0.1', 12345))
        sock.sendall(serialized_data)

# ফাংশন কল করা
send_sensor_data()

Step 4: সার্ভার সাইডে ডাটা গ্রহণ এবং ডেসিরিয়ালাইজ করা

FlatBuffers ব্যবহার করে সার্ভার সাইডে ডাটাকে ডেসিরিয়ালাইজ করে প্রয়োজনীয় তথ্য বের করা হবে।

import Network.SensorData as SensorData
import socket

def receive_sensor_data():
    # TCP স্যকেট তৈরি
    with socket.socket(socket.AF_INET, socket.SOCK_STREAM) as server_socket:
        server_socket.bind(('127.0.0.1', 12345))
        server_socket.listen(1)
        print("Server listening on port 12345...")

        while True:
            conn, addr = server_socket.accept()
            with conn:
                print("Connected by", addr)
                # ডাটা রিসিভ করা
                received_data = conn.recv(1024)

                # FlatBuffers ব্যবহার করে ডেসিরিয়ালাইজ করা
                sensor_data = SensorData.SensorData.GetRootAsSensorData(received_data, 0)

                # ডাটা প্রিন্ট করা
                print("Sensor Type:", sensor_data.SensorType().decode("utf-8"))
                print("Value:", sensor_data.Value())
                print("Timestamp:", sensor_data.Timestamp())

# ফাংশন কল করা
receive_sensor_data()

উদাহরণটির কাজের প্রক্রিয়া

ক্লায়েন্ট সাইডে ডাটা সিরিয়ালাইজেশন: ক্লায়েন্ট প্রথমে sensor_data.fbs এর মাধ্যমে ডাটা সিরিয়ালাইজ করে যা সেন্সর টাইপ, মান এবং টাইমস্ট্যাম্প ধারণ করে।

স্যকেট দিয়ে ডাটা ট্রান্সমিশন: ক্লায়েন্ট একটি TCP স্যকেট ব্যবহার করে সিরিয়ালাইজ করা ডাটা সরাসরি সার্ভারে পাঠায়।

সার্ভার সাইডে ডেসিরিয়ালাইজেশন: সার্ভার সাইডে FlatBuffers এর GetRootAsSensorData ফাংশন ব্যবহার করে ডাটা ডেসিরিয়ালাইজ করে, যার ফলে ডাটা সরাসরি এক্সেস করা যায়।

ডাটা প্রক্রিয়াকরণ: সার্ভার সেই ডাটা প্রক্রিয়াকরণ করতে পারে বা লগ রাখতে পারে।

FlatBuffers কেন নেটওয়ার্ক কমিউনিকেশনে কার্যকর?

দ্রুত সিরিয়ালাইজেশন এবং ডেসিরিয়ালাইজেশন: FlatBuffers তাত্ক্ষণিক ডেসিরিয়ালাইজেশন করে কারণ এটি সরাসরি মেমোরি থেকে ডাটা পড়ে, অতিরিক্ত ডাটা কপি বা প্রসেসিং প্রয়োজন হয় না।

কম মেমোরি ব্যবহার: FlatBuffers সিরিয়ালাইজড ডাটা খুবই কমপ্যাক্ট আকারে থাকে, ফলে এটি ব্যান্ডউইথ সাশ্রয় করে এবং ডাটা ট্রান্সমিশনের সময় দ্রুততা বাড়ায়।

বহু ভাষার সমর্থন: FlatBuffers একই স্কিমা ফাইল ব্যবহার করে একাধিক ভাষায় কোড জেনারেট করতে পারে, ফলে বিভিন্ন প্ল্যাটফর্ম এবং ডিভাইসের মধ্যে সহজেই কমিউনিকেশন করা সম্ভব।

কম ল্যাটেন্সি: রিয়েল-টাইম অ্যাপ্লিকেশনের জন্য FlatBuffers এ ডাটা ট্রান্সমিশনের ল্যাটেন্সি অনেক কম, ফলে দ্রুত রেসপন্স পাওয়া যায়।

FlatBuffers নেটওয়ার্ক কমিউনিকেশনের ক্ষেত্রে পারফরম্যান্স বৃদ্ধিতে সহায়ক কারণ এটি সরাসরি মেমোরিতে কাজ করতে পারে এবং কম সময়ে ডাটা ট্রান্সমিশন সম্পন্ন করতে পারে।

Content added By
Promotion

Are you sure to start over?

Loading...