মেসেজ ব্রোকার কি?
মেসেজ ব্রোকার হল একটি ইন্টারমিডিয়ারি কম্পিউটার প্রোগ্রাম মডিউল যা সেন্ডারের ফরমাল মেসেজিং প্রোটোকল থেকে রিসিভারের ফরমাল মেসেজিং প্রোটোকলে একটি মেসেজ ট্রান্সলেটে করে।
মেসেজ ব্রোকার হল একটি ইন্টারমিডিয়ারি প্রোগ্রাম যা অ্যাপ্লিকেশন এবং সার্ভিসগুলি একে অপরের সাথে তথ্য বিনিময় করতে ব্যবহার করে। মেসেজ ব্রোকাররা রিকয়ারড ডেস্টিনেশানে মেসেজ যাচাই, স্টোর, রুট এবং ডেলিভার করতে ব্যবহার করা হয় । বিভিন্ন প্রোগ্রামিং ভাষায় প্রয়োগ করা হলেও শুধুমাত্র অ্যাপ্লিকেশনগুলিই তথ্য যোগাযোগ করতে পারে না। যেহেতু মেসেজ ব্রোকাররা একটি মধ্যস্থতাকারী/ইন্টারমিডিয়ারি প্রোগ্রাম হিসাবে কাজ করে, সেহেতু প্রেরকের/সেন্ডারের কোন ধারণা নেই যে রিসিভার অনলাইনে থাকলেও কতজন আছে।
সবচেয়ে গুরুত্বপূর্ণ হচ্ছে ব্রোকাররা নিশ্চিত করে যে রিসিভাররা অনলাইনে বা সক্রিয় না থাকলেও মেসেজ পেয়েছেন। (এটি ইমেলের মতো। আপনাকে অনলাইনে থাকতে হবে না কিন্তু আপনি মেসেজটি পাবেন)।
মেসেজ ব্রোকাররা এটির জন্য একটি মেসেজ কিউ ব্যবহার করে এবং এটি মেমরি বা একটি হার্ড ডিস্কে সংরক্ষণ করা হয়। এটা মেসেজ সংরক্ষণ এবং মেসেজ ডেলিভার করতে ব্যবহার করা হয়. (আমি আশা করি আপনি ডাটা স্ট্রাকচার “কিউ” এর সাথে পরিচিত। এটিও একই, ফার্স্ট ইন ফার্স্ট আউট)।
মেসেজ কিউ মেসেজগুলিকে সেগুলি যে অর্ডারে রীসিভ হয় সেই অর্ডারে স্টোর করে এবং একই অর্ডারে রিসিভারকে পাঠায়৷ যদি কোনোভাবে একটি মেসেজ ডেলিভার করা সম্ভব না হয় (নেটওয়ার্কের সমস্যা) তাহলে মেসেজটি পরে কিউতে থাকার জন্য পুনরায় নির্ধারণ করা হবে। এছাড়াও একটি মেসেজ কিউতে, মেসেজগুলি সঠিক অর্ডারে রাখা হয় যেখানে সেগুলি প্রেরণ/সেন্ড করা হয়েছিল এবং প্রাপ্তি নিশ্চিত না হওয়া পর্যন্ত কিউতে থাকে৷
মেসেজ কিউ দিয়ে অ্যাপ্লিকেশনগুলি অ্যাসিঙ্ক্রোনাসভাবে কাজ করতে পারে এটি ডেটা লস প্রতিরোধ করে এবং প্রচেস বা কানেকশন ফেল হলে সিস্টেমগুলিকে কাজ চালিয়ে যেতে সক্ষম করে। এটি ডেভেলপারদের প্রচেসস এবং অ্যাপ্লিকেশনগুলিকে আলাদা রাখতে দেয়,
মেসেজ কিউ একটি ডেটা স্ট্রাকচার এবং এটি মেসেজ ব্রোকারের একটি অংশ।
Components of a message broker
এখন আসি মেসেজ ব্রোকারের মৌলিক উপাদানগুলি কি:
Producer - এই কম্পনেন্টস মেসেজ পাঠানোর জন্য রিস্পন্সিবল। এটি মেসেজ ব্রোকারের সাথে সংযুক্ত। পাবলিশ/সাবস্ক্রাইব প্যাটারনে (আমরা নীচের বিভাগে আলোচনা করেছি) তাদের পাবলিসার বলা হয়।
Consumer - এই কম্পনেন্টস মেসেজ ব্রোকারে মেসেজ গ্রহণ করে। পাবলিশ/সাবস্ক্রাইব প্যাটার্নে তাদের সাবস্ক্রাইবারস বলা হয়।
Queue/topic — মেসেজ ব্রোকার এখানে মেসেজ স্টোর করে।
Real-world use cases of message brokers
Integrating microservices
যখন একটি সিস্টেম তৈরি করতে মাইক্রোসার্ভিস আর্কিটেকচার ব্যবহার করা হয়, তখন ডেভেলপমেন্ট শেষে একাধিক মাইক্রোসার্ভিস থাকতে পারে। সমস্যা হল একে অপরের সাথে কমিউনিকেশন।
একটি মেসেজ ব্রোকার একটি সেন্ট্রাল ব্রোকার হিসাবে ব্যবহার করা যেতে পারে এবং মাইক্রোসার্ভিস একে অপরের সাথে যোগাযোগ করতে পারে। এছাড়াও, যদি আপনি এটিতে অন্য সার্ভিস যোগ করতে চান তবে আপনাকে এটি শুধুমাত্র মেসেজ ব্রোকারের সাথে সংযুক্ত করতে হবে।
Rest API’s
বর্তমানে প্রায়শই আমরা একটি REST API ব্যাকএন্ড সহ ওয়েব ফ্রন্টএন্ড বা মোবাইল অ্যাপ্লিকেশন ডেভেলপমেন্ট করি। ক্লায়েন্ট এবং সার্ভার আর্কিটেকচার যোগাযোগের জন্য HTTP প্রোটোকল ব্যবহার করে।
কিন্তু যদি রিকোয়েস্ট থেকে ডেটা দীর্ঘ সময়ের জন্য প্রসেসের প্রয়োজন হয় তাহলে কী হবে। 10 মিনিটের মত হলে। যদি একটি সময় সাপেক্ষ হিসাব করতে হয়?
এছাড়াও, সেই সময়ে ইউজারের যদি সংযোগের সমস্যা হয় তবে কী হবে। রিস্পপন্সটি ইউজার কখনই নাও পেতে পারে। একটি মেসেজ ব্রোকার এখানে ব্যবহার করা যেতে পারে যাতে মেসেজ সরবরাহ নিশ্চিত করা যায়।
Mobile Applications
মনে করুন আপনি একটি মোবাইল অ্যাপে বিজ্ঞপ্তি পাঠাতে চান। কিন্তু কিছু ইউজার অনলাইন না হলে কি হবে। একটি মেসেজ ব্রোকার ব্যবহার করে, আপনি নিশ্চিত করতে পারেন যে তারা অনলাইনে এলে মেসেজটি পাবে।
Different messaging models/distribution patterns
যদিও বেশ কিছু মেসেজ ব্রোকার মডেল আছে আমরা এখানে প্রধান 02 মেসেজিং প্যাটার্ন নিয়ে আলোচনা করব।
Point-to-Point.
- মেসেজের কিউতে মেসেজের সেন্ডার (প্রডিউসার) এবং রিসিভার (কঞ্জুমার) এর সাথে ওয়ান টু ওয়ান সম্পর্ক রয়েছে।
- কিউতে থাকা প্রতিটি মেসেজ শুধুমাত্র একজন রিসিভারের কাছে পাঠানো হয় এবং শুধুমাত্র একবার রীসিভ হয়।
- ফাইনান্সিয়াল ট্রাঞ্জেকশানের জন্য এফিশিএন্ট যেহেতু পেমেন্ট শুধুমাত্র একবার করা প্রয়োজন৷
Publish-Subscribe.
- এই মেসেজ মডেলটি "পাব/সাব" নামেও পরিচিত৷
- এই মডেলে, মেসেজের কিউগুলির মেসেজ সেন্ডার এবং রিসিভারের সাথে এক থেকে একাধিক সম্পর্ক রয়েছে৷ এছাড়াও, সেন্ডার পাবলিসার হিসাবে পরিচিত এবং রিসিভার সাবস্ক্রাইবার হিসাবে পরিচিত।
- এই মডেল অনুসারে, একজন সেন্ডার একটি টপিকে মেসেজ পাবলিশ করে। এই মেসেজগুলি সমস্ত কঞ্জুমারের মধ্যে ডিস্ট্রিবিউট করা হয় যারা টপিকটিতে সাবস্ক্রাইব করেসে৷
- এই মডেলটি এমন একটি সিস্টেমের জন্য ব্যবহার করা যেতে পারে যেখানে ডেটা ক্রমাগত বিভিন্ন পক্ষের মধ্যে ভাগ করা উচিত। যেমন: একটি এয়ারলাইন সিস্টেম তার অবতরণ সময় এবং অবস্থান সম্পর্কে ক্রমাগত আপডেট শেয়ার করা উচিত। এই আপডেটগুলি বিভিন্ন পক্ষের মধ্যে শেয়ার করা উচিত যেমন গ্রাউন্ড ক্রু (ল্যান্ডিংয়ের জন্য প্রস্তুত করা), নিয়ন্ত্রণ কেন্দ্র (ফ্লাইট পরিচালনা করার জন্য), জনসাধারণ ইত্যাদি।
মেসেজ ব্রোকার ব্যবহার করার সুবিধা কি কি?
- মেসেজ ডেলিভারি গ্যারান্টি — কঞ্জুমার অফলাইনে থাকলেও অনলাইনে আসলে মেসেজটি ডেলিভার করা হবে।
- অ্যাসিঙ্ক্রোনাস প্রচেসসিং এর সাথে সিস্টেমের পারফরমেন্স বৃদ্ধি পায় — দীর্ঘ সময় নেয় এমন প্রচেসগুলি আলাদাভাবে প্রচেস করা যেতে পারে এবং তাহলে অ্যাপ্লিকেশনের মূল থ্রেড প্রভাবিত হবে না।
- একে অপরের সাথে যোগাযোগের জন্য অ্যাপ্লিকেশন, এমনকি যদি সেগুলি বিভিন্ন প্রোগ্রামিং ভাষায় প্রয়োগ করা হয় — (যেমন: SOAP, REST API, IoT ডিভাইস ইত্যাদি)।
মেসেজ ব্রোকার ব্যবহার করার কিছু অসুবিধা কি কি?
- লার্নিং কার্ভ — এখানে বেশ কিছু মেসেজিং ব্রোকার এবং ডিজাইন প্যাটার্ন রয়েছে যা আপনি ব্যবহার করতে পারেন। আপনার পার্থক্য জানতে হবে এবং কোনটি ব্যবহার করতে হবে।
- ডিবাগিং — সিস্টেমের জটিলতার সাথে, ডিবাগিং কঠিন হতে পারে।
- কমপ্লেক্সিটি — একটি মেসেজ ব্রোকার থাকা অবশ্যই সিস্টেম আর্কিটেকচারে সম্পূর্ণ নতুন উপাদান যোগ করে।
সর্বাধিক জনপ্রিয় মেসেজ ব্রোকার:
কিছু বিখ্যাত মেসেজ ব্রোকার হল Apache Kafka, RabbitMQ এবং Amazon SNS।
Top comments (0)