DEV Community

Zihadul Islam
Zihadul Islam

Posted on

1

Introduction to Message Brokers

মেসেজ ব্রোকার কি?
মেসেজ ব্রোকার হল একটি ইন্টারমিডিয়ারি কম্পিউটার প্রোগ্রাম মডিউল যা সেন্ডারের ফরমাল মেসেজিং প্রোটোকল থেকে রিসিভারের ফরমাল মেসেজিং প্রোটোকলে একটি মেসেজ ট্রান্সলেটে করে।

মেসেজ ব্রোকার হল একটি ইন্টারমিডিয়ারি প্রোগ্রাম যা অ্যাপ্লিকেশন এবং সার্ভিসগুলি একে অপরের সাথে তথ্য বিনিময় করতে ব্যবহার করে। মেসেজ ব্রোকাররা রিকয়ারড ডেস্টিনেশানে মেসেজ যাচাই, স্টোর, রুট এবং ডেলিভার করতে ব্যবহার করা হয় । বিভিন্ন প্রোগ্রামিং ভাষায় প্রয়োগ করা হলেও শুধুমাত্র অ্যাপ্লিকেশনগুলিই তথ্য যোগাযোগ করতে পারে না। যেহেতু মেসেজ ব্রোকাররা একটি মধ্যস্থতাকারী/ইন্টারমিডিয়ারি প্রোগ্রাম হিসাবে কাজ করে, সেহেতু প্রেরকের/সেন্ডারের কোন ধারণা নেই যে রিসিভার অনলাইনে থাকলেও কতজন আছে।

সবচেয়ে গুরুত্বপূর্ণ হচ্ছে ব্রোকাররা নিশ্চিত করে যে রিসিভাররা অনলাইনে বা সক্রিয় না থাকলেও মেসেজ পেয়েছেন। (এটি ইমেলের মতো। আপনাকে অনলাইনে থাকতে হবে না কিন্তু আপনি মেসেজটি পাবেন)।

Image description

মেসেজ ব্রোকাররা এটির জন্য একটি মেসেজ কিউ ব্যবহার করে এবং এটি মেমরি বা একটি হার্ড ডিস্কে সংরক্ষণ করা হয়। এটা মেসেজ সংরক্ষণ এবং মেসেজ ডেলিভার করতে ব্যবহার করা হয়. (আমি আশা করি আপনি ডাটা স্ট্রাকচার “কিউ” এর সাথে পরিচিত। এটিও একই, ফার্স্ট ইন ফার্স্ট আউট)।

মেসেজ কিউ মেসেজগুলিকে সেগুলি যে অর্ডারে রীসিভ হয় সেই অর্ডারে স্টোর করে এবং একই অর্ডারে রিসিভারকে পাঠায়৷ যদি কোনোভাবে একটি মেসেজ ডেলিভার করা সম্ভব না হয় (নেটওয়ার্কের সমস্যা) তাহলে মেসেজটি পরে কিউতে থাকার জন্য পুনরায় নির্ধারণ করা হবে। এছাড়াও একটি মেসেজ কিউতে, মেসেজগুলি সঠিক অর্ডারে রাখা হয় যেখানে সেগুলি প্রেরণ/সেন্ড করা হয়েছিল এবং প্রাপ্তি নিশ্চিত না হওয়া পর্যন্ত কিউতে থাকে৷

মেসেজ কিউ দিয়ে অ্যাপ্লিকেশনগুলি অ্যাসিঙ্ক্রোনাসভাবে কাজ করতে পারে এটি ডেটা লস প্রতিরোধ করে এবং প্রচেস বা কানেকশন ফেল হলে সিস্টেমগুলিকে কাজ চালিয়ে যেতে সক্ষম করে। এটি ডেভেলপারদের প্রচেসস এবং অ্যাপ্লিকেশনগুলিকে আলাদা রাখতে দেয়,
মেসেজ কিউ একটি ডেটা স্ট্রাকচার এবং এটি মেসেজ ব্রোকারের একটি অংশ।

Components of a message broker

এখন আসি মেসেজ ব্রোকারের মৌলিক উপাদানগুলি কি:

Producer - এই কম্পনেন্টস মেসেজ পাঠানোর জন্য রিস্পন্সিবল। এটি মেসেজ ব্রোকারের সাথে সংযুক্ত। পাবলিশ/সাবস্ক্রাইব প্যাটারনে (আমরা নীচের বিভাগে আলোচনা করেছি) তাদের পাবলিসার বলা হয়।

Consumer - এই কম্পনেন্টস মেসেজ ব্রোকারে মেসেজ গ্রহণ করে। পাবলিশ/সাবস্ক্রাইব প্যাটার্নে তাদের সাবস্ক্রাইবারস বলা হয়।

Queue/topic — মেসেজ ব্রোকার এখানে মেসেজ স্টোর করে।

Real-world use cases of message brokers

Integrating microservices
যখন একটি সিস্টেম তৈরি করতে মাইক্রোসার্ভিস আর্কিটেকচার ব্যবহার করা হয়, তখন ডেভেলপমেন্ট শেষে একাধিক মাইক্রোসার্ভিস থাকতে পারে। সমস্যা হল একে অপরের সাথে কমিউনিকেশন।

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

Image description

Rest API’s
বর্তমানে প্রায়শই আমরা একটি REST API ব্যাকএন্ড সহ ওয়েব ফ্রন্টএন্ড বা মোবাইল অ্যাপ্লিকেশন ডেভেলপমেন্ট করি। ক্লায়েন্ট এবং সার্ভার আর্কিটেকচার যোগাযোগের জন্য HTTP প্রোটোকল ব্যবহার করে।

কিন্তু যদি রিকোয়েস্ট থেকে ডেটা দীর্ঘ সময়ের জন্য প্রসেসের প্রয়োজন হয় তাহলে কী হবে। 10 মিনিটের মত হলে। যদি একটি সময় সাপেক্ষ হিসাব করতে হয়?

এছাড়াও, সেই সময়ে ইউজারের যদি সংযোগের সমস্যা হয় তবে কী হবে। রিস্পপন্সটি ইউজার কখনই নাও পেতে পারে। একটি মেসেজ ব্রোকার এখানে ব্যবহার করা যেতে পারে যাতে মেসেজ সরবরাহ নিশ্চিত করা যায়।

Mobile Applications
মনে করুন আপনি একটি মোবাইল অ্যাপে বিজ্ঞপ্তি পাঠাতে চান। কিন্তু কিছু ইউজার অনলাইন না হলে কি হবে। একটি মেসেজ ব্রোকার ব্যবহার করে, আপনি নিশ্চিত করতে পারেন যে তারা অনলাইনে এলে মেসেজটি পাবে।

Image description

Different messaging models/distribution patterns
যদিও বেশ কিছু মেসেজ ব্রোকার মডেল আছে আমরা এখানে প্রধান 02 মেসেজিং প্যাটার্ন নিয়ে আলোচনা করব।
Point-to-Point.

Image description

  • মেসেজের কিউতে মেসেজের সেন্ডার (প্রডিউসার) এবং রিসিভার (কঞ্জুমার) এর সাথে ওয়ান টু ওয়ান সম্পর্ক রয়েছে।
  • কিউতে থাকা প্রতিটি মেসেজ শুধুমাত্র একজন রিসিভারের কাছে পাঠানো হয় এবং শুধুমাত্র একবার রীসিভ হয়।
  • ফাইনান্সিয়াল ট্রাঞ্জেকশানের জন্য এফিশিএন্ট যেহেতু পেমেন্ট শুধুমাত্র একবার করা প্রয়োজন৷

Publish-Subscribe.

Image description

  • এই মেসেজ মডেলটি "পাব/সাব" নামেও পরিচিত৷
  • এই মডেলে, মেসেজের কিউগুলির মেসেজ সেন্ডার এবং রিসিভারের সাথে এক থেকে একাধিক সম্পর্ক রয়েছে৷ এছাড়াও, সেন্ডার পাবলিসার হিসাবে পরিচিত এবং রিসিভার সাবস্ক্রাইবার হিসাবে পরিচিত।
  • এই মডেল অনুসারে, একজন সেন্ডার একটি টপিকে মেসেজ পাবলিশ করে। এই মেসেজগুলি সমস্ত কঞ্জুমারের মধ্যে ডিস্ট্রিবিউট করা হয় যারা টপিকটিতে সাবস্ক্রাইব করেসে৷
  • এই মডেলটি এমন একটি সিস্টেমের জন্য ব্যবহার করা যেতে পারে যেখানে ডেটা ক্রমাগত বিভিন্ন পক্ষের মধ্যে ভাগ করা উচিত। যেমন: একটি এয়ারলাইন সিস্টেম তার অবতরণ সময় এবং অবস্থান সম্পর্কে ক্রমাগত আপডেট শেয়ার করা উচিত। এই আপডেটগুলি বিভিন্ন পক্ষের মধ্যে শেয়ার করা উচিত যেমন গ্রাউন্ড ক্রু (ল্যান্ডিংয়ের জন্য প্রস্তুত করা), নিয়ন্ত্রণ কেন্দ্র (ফ্লাইট পরিচালনা করার জন্য), জনসাধারণ ইত্যাদি।

মেসেজ ব্রোকার ব্যবহার করার সুবিধা কি কি?

  • মেসেজ ডেলিভারি গ্যারান্টি — কঞ্জুমার অফলাইনে থাকলেও অনলাইনে আসলে মেসেজটি ডেলিভার করা হবে।
  • অ্যাসিঙ্ক্রোনাস প্রচেসসিং এর সাথে সিস্টেমের পারফরমেন্স বৃদ্ধি পায় — দীর্ঘ সময় নেয় এমন প্রচেসগুলি আলাদাভাবে প্রচেস করা যেতে পারে এবং তাহলে অ্যাপ্লিকেশনের মূল থ্রেড প্রভাবিত হবে না।
  • একে অপরের সাথে যোগাযোগের জন্য অ্যাপ্লিকেশন, এমনকি যদি সেগুলি বিভিন্ন প্রোগ্রামিং ভাষায় প্রয়োগ করা হয় — (যেমন: SOAP, REST API, IoT ডিভাইস ইত্যাদি)।

মেসেজ ব্রোকার ব্যবহার করার কিছু অসুবিধা কি কি?

  • লার্নিং কার্ভ — এখানে বেশ কিছু মেসেজিং ব্রোকার এবং ডিজাইন প্যাটার্ন রয়েছে যা আপনি ব্যবহার করতে পারেন। আপনার পার্থক্য জানতে হবে এবং কোনটি ব্যবহার করতে হবে।
  • ডিবাগিং — সিস্টেমের জটিলতার সাথে, ডিবাগিং কঠিন হতে পারে।
  • কমপ্লেক্সিটি — একটি মেসেজ ব্রোকার থাকা অবশ্যই সিস্টেম আর্কিটেকচারে সম্পূর্ণ নতুন উপাদান যোগ করে।

সর্বাধিক জনপ্রিয় মেসেজ ব্রোকার:
কিছু বিখ্যাত মেসেজ ব্রোকার হল Apache Kafka, RabbitMQ এবং Amazon SNS।

Heroku

Amplify your impact where it matters most — building exceptional apps.

Leave the infrastructure headaches to us, while you focus on pushing boundaries, realizing your vision, and making a lasting impression on your users.

Get Started

Top comments (0)

5 Playwright CLI Flags That Will Transform Your Testing Workflow

  • 0:56 --last-failed
  • 2:34 --only-changed
  • 4:27 --repeat-each
  • 5:15 --forbid-only
  • 5:51 --ui --headed --workers 1

Learn how these powerful command-line options can save you time, strengthen your test suite, and streamline your Playwright testing experience. Click on any timestamp above to jump directly to that section in the tutorial!

👋 Kindness is contagious

If you found this post useful, consider leaving a ❤️ or a nice comment!

Got it