ক্লায়েন্ট তৈরি এবং RPC কল করা

সার্ভার এবং ক্লায়েন্ট মডেল - অ্যাপাচি থ্রিফট (Apache Thrift) - Latest Technologies

273

 

Apache Thrift ব্যবহার করে ক্লায়েন্ট তৈরি এবং RPC (Remote Procedure Call) কল করার প্রক্রিয়া সহজ এবং কার্যকর। নিচে ক্লায়েন্ট তৈরি করার পদক্ষেপ এবং RPC কল করার উদাহরণ তুলে ধরা হলো।

ক্লায়েন্ট তৈরি করার পদক্ষেপ

১. IDL ফাইল তৈরি করা

প্রথমে একটি Thrift IDL (Interface Definition Language) ফাইল তৈরি করতে হবে যেখানে সার্ভিস এবং মেথডগুলি সংজ্ঞায়িত থাকবে।

example.thrift:

namespace py example

service ExampleService {
    string sayHello(1:string name)
}

২. Thrift Compiler ব্যবহার করে কোড জেনারেট করা

Thrift কমান্ড ব্যবহার করে IDL ফাইল থেকে ক্লায়েন্ট কোড জেনারেট করুন। নিচে Python ভাষার জন্য উদাহরণ দেওয়া হলো:

thrift --gen py example.thrift

এই কমান্ডটি gen-py নামে একটি ডিরেক্টরি তৈরি করবে, যেখানে Python কোড জেনারেট হবে।

৩. ক্লায়েন্ট প্রোগ্রাম তৈরি করা

Python ভাষায় ক্লায়েন্ট প্রোগ্রাম তৈরি করুন। এখানে একটি উদাহরণ দেওয়া হলো:

client.py:

from thrift import Thrift
from thrift.transport import TSocket
from thrift.transport import TTransport
from thrift.protocol import TBinaryProtocol
from example import ExampleService

def main():
    # সার্ভারের সাথে সংযোগ স্থাপন করুন
    transport = TSocket.TSocket("localhost", 9090)
    tfactory = TTransport.TBufferedTransportFactory()
    protocol = TBinaryProtocol.TBinaryProtocol(transport)
    client = ExampleService.Client(protocol)

    try:
        # সার্ভারের সাথে সংযোগ করুন
        transport.open()

        # RPC কল করুন
        name = "World"
        response = client.sayHello(name)
        print(response)  # সার্ভারের কাছ থেকে প্রাপ্ত ফলাফল প্রদর্শন করুন

    except Thrift.TException as tx:
        print(f"Thrift exception: {tx.message}")
    finally:
        # সংযোগ বন্ধ করুন
        transport.close()

if __name__ == "__main__":
    main()

৪. ক্লায়েন্ট চালানো

ক্লায়েন্ট প্রোগ্রামটি চালানোর জন্য, আপনার প্রথমে Thrift সার্ভার চালু করতে হবে (যা ExampleService সার্ভিসটি সরবরাহ করে) এবং তারপর ক্লায়েন্ট প্রোগ্রামটি চালাতে হবে:

bash

Copy code

python client.py

RPC কলের প্রক্রিয়া

  1. সংযোগ স্থাপন: ক্লায়েন্ট প্রথমে সার্ভারের সাথে TCP/IP সংযোগ স্থাপন করে।
  2. RPC কল: ক্লায়েন্ট সার্ভিসের মেথড (যেমন sayHello) কল করে এবং প্রয়োজনীয় প্যারামিটার (যেমন name) পাঠায়।
  3. ফলাফল প্রাপ্তি: সার্ভার ক্লায়েন্টের অনুরোধটি প্রক্রিয়া করে এবং ফলাফল (যেমন "Hello, World!") ফেরত পাঠায়।
  4. সংযোগ বন্ধ করা: ক্লায়েন্ট প্রোগ্রাম শেষে সার্ভারের সাথে সংযোগ বন্ধ করে।

উপসংহার

Apache Thrift ব্যবহার করে ক্লায়েন্ট তৈরি এবং RPC কল করার প্রক্রিয়া কার্যকর এবং সহজ। এই প্রক্রিয়ার মাধ্যমে ক্লায়েন্ট সার্ভারের সাথে সহজেই যোগাযোগ করতে পারে এবং বিভিন্ন কার্যক্রম সম্পন্ন করতে সক্ষম হয়। Thrift এর মাধ্যমে একাধিক প্রোগ্রামিং ভাষার মধ্যে কার্যকরী যোগাযোগ নিশ্চিত করা হয়, যা ডিস্ট্রিবিউটেড সিস্টেমে উপকারী।

Content added By
Promotion

Are you sure to start over?

Loading...