কম্পিউটার

বার্তা সারি ব্যবহার করে আইপিসি


যখন আমাদের ইতিমধ্যেই ভাগ করা মেমরি আছে তখন কেন আমাদের বার্তা সারি দরকার? এটি একাধিক কারণে হতে পারে, আসুন আমরা এটিকে সরলীকরণের জন্য একাধিক পয়েন্টে বিভক্ত করার চেষ্টা করি -

  • যেমন বোঝা যায়, একবার কোনো প্রক্রিয়ার মাধ্যমে বার্তাটি প্রাপ্ত হলে এটি আর কোনো প্রক্রিয়ার জন্য উপলব্ধ হবে না। যেখানে ভাগ করা মেমরিতে, ডেটা অ্যাক্সেস করার জন্য একাধিক প্রক্রিয়ার জন্য উপলব্ধ।

  • আমরা যদি ছোট বার্তা ফরম্যাটের সাথে যোগাযোগ করতে চাই।

  • শেয়ার করা মেমরি ডেটা সিঙ্ক্রোনাইজেশনের মাধ্যমে সুরক্ষিত করা প্রয়োজন যখন একাধিক প্রক্রিয়া একই সময়ে যোগাযোগ করে।

  • শেয়ার্ড মেমরি ব্যবহার করে লেখা এবং পড়ার ফ্রিকোয়েন্সি বেশি, তাহলে কার্যকারিতা বাস্তবায়ন করা খুব জটিল হবে। এই ধরনের ক্ষেত্রে ব্যবহারের ক্ষেত্রে মূল্য নেই।

  • কি হবে যদি সমস্ত প্রক্রিয়ার শেয়ার করা মেমরি অ্যাক্সেস করার প্রয়োজন না হয় কিন্তু খুব কম প্রসেস শুধুমাত্র এটির প্রয়োজন হয়, তাহলে বার্তা সারি দিয়ে বাস্তবায়ন করা ভাল হবে৷

  • আমরা যদি বিভিন্ন ডাটা প্যাকেটের সাথে যোগাযোগ করতে চাই, বলুন যে প্রসেস এ বি প্রসেস করতে মেসেজ টাইপ 1 পাঠাচ্ছে, সি প্রসেস করতে মেসেজ টাইপ 10 এবং ডি প্রসেস করার জন্য মেসেজ টাইপ 20 পাঠাচ্ছে। এই ক্ষেত্রে, মেসেজ সারি দিয়ে বাস্তবায়ন করা আরও সহজ। প্রদত্ত বার্তাটি 1, 10, 20 হিসাবে সহজ করার জন্য, এটি 0 বা +ve বা –ve হতে পারে যা নীচে আলোচনা করা হয়েছে৷

  • অবশ্যই, বার্তা সারির ক্রম হল FIFO (ফার্স্ট ইন ফার্স্ট আউট)। সারিতে ঢোকানো প্রথম বার্তাটি পুনরুদ্ধার করা প্রথম।

শেয়ার্ড মেমরি বা মেসেজ সারি ব্যবহার করা নির্ভর করে অ্যাপ্লিকেশনটির প্রয়োজনীয়তার উপর এবং এটি কতটা কার্যকরভাবে ব্যবহার করা যেতে পারে৷

বার্তা সারি ব্যবহার করে যোগাযোগ নিম্নলিখিত উপায়ে ঘটতে পারে -

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

বিভিন্ন ডেটা প্যাকেট সহ একটি প্রক্রিয়া দ্বারা ভাগ করা মেমরিতে লেখা এবং একাধিক প্রক্রিয়ার মাধ্যমে এটি থেকে পড়া, অর্থাত্ বার্তার ধরন অনুযায়ী৷

বার্তা সারি ব্যবহার করে আইপিসি

বার্তা সারি সম্পর্কে কিছু তথ্য দেখার পরে, এখন সময় এসেছে সিস্টেম কল (সিস্টেম V) যা বার্তা সারি সমর্থন করে তা পরীক্ষা করার৷

বার্তা সারি ব্যবহার করে যোগাযোগ সঞ্চালন করতে, নিম্নলিখিত ধাপগুলি হল −

ধাপ 1 − একটি বার্তা সারি তৈরি করুন বা ইতিমধ্যে বিদ্যমান একটি বার্তা সারিতে সংযোগ করুন (msgget())

ধাপ 2 - বার্তা সারিতে লিখুন (msgsnd())

ধাপ 3 - বার্তা সারি থেকে পড়ুন (msgrcv())

পদক্ষেপ 4৷ − বার্তা সারিতে (msgctl())

নিয়ন্ত্রণ অপারেশন সম্পাদন করুন

এখানে আমরা দুটি প্রক্রিয়া তৈরি করব। একজন লিখতে পারে আরেকজন পড়তে পারে। আসুন দেখি কিভাবে পাঠক এবং লেখক প্রক্রিয়াগুলি ভাগ করা মেমরি ব্যবহার করে কাজ করছে৷

উদাহরণ কোড

#include <stdio.h>
#include <sys/ipc.h>
#include <sys/msg.h>
// structure for message queue
struct msg_buffer {
   long msg_type;
   char msg[100];
} message;
main() {
   key_t my_key;
   int msg_id;
   my_key = ftok("progfile", 65); //create unique key
   msg_id = msgget(my_key, 0666 | IPC_CREAT); //create message queue and return id
   message.msg_type = 1;
   printf("Write Message : ");
   fgets(message.msg, 100, stdin);
   msgsnd(msg_id, &message, sizeof(message), 0); //send message
   printf("Sent message is : %s \n", message.msg);
}

উদাহরণ কোড

#include <stdio.h>
#include <sys/ipc.h>
#include <sys/msg.h>
// Define message queue structure
struct msg_buffer {
   long msg_type;
   char msg[100];
} message;
main() {
   key_t my_key;
   int msg_id;
   my_key = ftok("progfile", 65); //create unique key
   msg_id = msgget(my_key, 0666 | IPC_CREAT); //create message queue and return id
   msgrcv(msg_id, &message, sizeof(message), 1, 0); //used to receive message
   // display the message
   printf("Received Message is : %s \n", message.msg);
   msgctl(msg_id, IPC_RMID, NULL); //destroy the message queue
   return 0;
}
ধ্বংস করুন

আউটপুট

বার্তা সারি ব্যবহার করে আইপিসি


  1. সি-তে লিঙ্ক করা তালিকা ব্যবহার করে অগ্রাধিকার সারি

  2. C++ সারি ব্যবহার করে বিএসটি-তে একটি পথ বিপরীত করুন

  3. C++ এ দ্বিগুণ লিঙ্কযুক্ত তালিকা ব্যবহার করে অগ্রাধিকার সারি

  4. Truecaller ব্যবহার করে বার্তাগুলি কীভাবে নির্ধারণ করবেন