Java RMI (Remote Method Invocation) ব্যবহার করে একই RMI সার্ভারে একাধিক ক্লায়েন্ট সংযুক্ত হতে পারে। RMI এর ডিজাইন এমনভাবে করা হয়েছে যে এটি মাল্টি-থ্রেডেড সার্ভারে কাজ করে, যা একই সময়ে একাধিক ক্লায়েন্ট থেকে অনুরোধ গ্রহণ এবং প্রক্রিয়া করতে সক্ষম।
RMI Server এ Multiple Clients হ্যান্ডল করার উপায়
- Thread Management in RMI:
RMI সার্ভার প্রতিটি ক্লায়েন্ট সংযোগের জন্য একটি নতুন থ্রেড তৈরি করে। এতে একাধিক ক্লায়েন্ট একসাথে সার্ভারে অনুরোধ পাঠাতে পারে, এবং সার্ভার প্রতিটি অনুরোধ পৃথকভাবে প্রক্রিয়া করতে পারে। - Synchronized Methods ব্যবহার:
রিমোট অবজেক্ট শেয়ার করা হলে, ডেটা কনসিস্টেন্সি নিশ্চিত করতে synchronized মেথড বা ব্লক ব্যবহার করতে হবে। - State Management:
RMI সার্ভার যদি স্টেটফুল হয় (অর্থাৎ, এটি অবজেক্টের স্থায়ী অবস্থা সংরক্ষণ করে), তাহলে কনকারেন্সি সমস্যা এড়াতে প্রপার লকিং মেকানিজম ব্যবহার করতে হবে।
উদাহরণ: Multiple Clients হ্যান্ডল করা
Step 1: Remote Interface তৈরি করা
import java.rmi.Remote;
import java.rmi.RemoteException;
// Remote Interface
public interface ChatService extends Remote {
String sendMessage(String clientName, String message) throws RemoteException;
}
Step 2: Remote Object Implementation
import java.rmi.server.UnicastRemoteObject;
import java.rmi.RemoteException;
import java.util.concurrent.locks.ReentrantLock;
// Remote Object Implementation
public class ChatServiceImpl extends UnicastRemoteObject implements ChatService {
private static final long serialVersionUID = 1L;
private final ReentrantLock lock = new ReentrantLock();
public ChatServiceImpl() throws RemoteException {
super();
}
@Override
public String sendMessage(String clientName, String message) throws RemoteException {
lock.lock(); // Ensuring thread safety
try {
System.out.println("Message from " + clientName + ": " + message);
return "Message received from " + clientName + ": " + message;
} finally {
lock.unlock();
}
}
}
Step 3: RMI Server
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
public class RMIServer {
public static void main(String[] args) {
try {
ChatService chatService = new ChatServiceImpl();
Registry registry = LocateRegistry.createRegistry(1099); // Default RMI port
registry.rebind("ChatService", chatService);
System.out.println("Chat Service is running and ready to accept multiple clients...");
} catch (Exception e) {
e.printStackTrace();
}
}
}
Step 4: RMI Client
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
public class RMIClient {
public static void main(String[] args) {
try {
// Locate the RMI Registry
Registry registry = LocateRegistry.getRegistry("localhost", 1099);
// Lookup the remote object
ChatService chatService = (ChatService) registry.lookup("ChatService");
// Send messages to the server
String response = chatService.sendMessage("Client1", "Hello, this is Client 1!");
System.out.println("Server Response: " + response);
response = chatService.sendMessage("Client1", "How are you?");
System.out.println("Server Response: " + response);
} catch (Exception e) {
e.printStackTrace();
}
}
}
Testing with Multiple Clients
- Run the RMI Server
প্রথমে সার্ভারটি চালু করুন, যাতে এটি ক্লায়েন্টের সংযোগ গ্রহণ করতে প্রস্তুত থাকে। - Run Multiple Clients Simultaneously
একাধিক ক্লায়েন্ট চালু করে বিভিন্ন মেসেজ পাঠান। প্রতিটি ক্লায়েন্ট তার নিজস্ব থ্রেডে কাজ করবে এবং সার্ভারের সাথে যোগাযোগ করবে।
Thread Safety নিশ্চিত করার জন্য Synchronization Tips
- ReentrantLock ব্যবহার:
ডেটার কনসিস্টেন্সি নিশ্চিত করতে এবং কনকারেন্সি সমস্যা এড়াতে ReentrantLock ব্যবহার করুন। Synchronized Method:
সহজ প্রয়োগের জন্য মেথডেsynchronizedকীওয়ার্ড যোগ করুন।public synchronized String sendMessage(String clientName, String message) { // Critical section }- Atomic Variables:
যদি শুধুমাত্র কাউন্টার বা ফ্ল্যাগ আপডেট করতে হয়, তাহলেAtomicIntegerবাAtomicBooleanব্যবহার করুন।
RMI Server স্বাভাবিকভাবেই মাল্টি-থ্রেডেড হওয়ায় একাধিক ক্লায়েন্ট হ্যান্ডল করার ক্ষমতা রাখে। তবে, ডেটার কনসিস্টেন্সি এবং নিরাপত্তা নিশ্চিত করার জন্য synchronization বা locking mechanisms ব্যবহার করা গুরুত্বপূর্ণ। সঠিকভাবে এক্সসেপশন হ্যান্ডলিং এবং থ্রেড ম্যানেজমেন্ট করলে RMI সার্ভার একাধিক ক্লায়েন্টের সাথে সফলভাবে কাজ করতে সক্ষম হয়।
Read more