RMI Nedir Uzaktan Metot Çağrımı (RMI – Remote Method Invocation)
RMI nedir ?
Bir cihaz üzerinde çalışan Java nesnelerinin, başka bir cihaz üzerinde çalışan diğer Java nesnesinin metodunu çağırmasını sağlar. Bu önemli özellik dağıtık uygulamalar geliştirilmesine izin verir. Günümüzde SOAP, REST vb Web servislerinin gelişmesiyle RMI gibi benzer teknolojilerin kullanımı Web servisleri yönüne kaymaktadır.
RMI Sunucu, İstemci mimarisi üzerine kurulu olup, arabirimler ve serileştirme ile uzak metot çağrımı başarıya ulaşır.

RMI’ uygulamak genellikle 4 adım kullanılır
1- Sunucu tarafından sağlanan uzak arabirim
2- Uzak Arabirimi uygulayan uzak sınıf
3- Sunucu cihazın ana programı
4- İstemci cihaz tarafı
Buradaki örnek sunucu tarafında List arabirimini uygulayan bir List nesnesini istemci tarafına uzak metot çağırımı ile Gerçekleştireceğiz. Yani sunucu tarafında oluşturduğumuz bir listeyi istemciye göndericeğiz.
Adım 1- Sunucu tarafından sağlanan uzak arabirimi gerçekleştirmek. Tüm uzak arabirimler Remote Arabirimini genişletmek zorundadır Remote üye tanımlamaz, tüm uzak metotlar bir RemoteException fırlatabilir.
/** * ServerIntf.java * @author Hüseyin Bora */ import java.rmi.*; import java.util.*; public interface ServerIntf extends Remote { public List getList()throws RemoteException; }
Adım 2 – ServerIntf uzak arabirimi uygulayıp uzak nesnelere uygunluğu sağlayan UnicastRemoteObject sınıfını genişletmek zorundadır.
/** * ServerImpl.java * @author Hüseyin Bora */ import java.rmi.*; import java.rmi.server.*; import java.util.*; public class ServerImpl extends UnicastRemoteObject implements ServerIntf{ public ServerImpl()throws RemoteException{ } public List getList() throws RemoteException { ArrayList al = new ArrayList(); for(int i= 1 ; i<10; i++) al.add(i); return al; }}
Adım 3- Sunucu ana programının yazılması ana program şu adımları takip eder.
1- ServerImpl nesnesi oluşturmak.
2- RMI kayıdını güncellemek.
Kayıt işlemi Naming sınıfının rebind() metodu kullanılarak gerçekleştirilir. Bu metot bir adı bir nesne referansı ile ilişkilendirir.ilk parametre sunucuyu , ikinci parametre nesne referansını alır.
/** * Main.java * @author Hüseyin Bora */ import java.rmi.*; import java.net.*; public class Main{ public static void main(String[] args) { try { ServerImpl serverobject = new ServerImpl(); Naming.rebind("Main", serverobject); } catch (Exception ex) { ex.printStackTrace(); } }
Adım 4- İstemci tarafının gerçekleştirilmesi istemci tarafı rmi protokolünü kullanır Naming sınıfının lookup() metodunu çağırır bu metot bir rmi URL’si alır ve uzak nesneye bir referans döndürür.
/** * Client.java * @author Bora */ import java.rmi.*; import java.util.*; public class Client { public static void main(String[] args) { try { String rmiUrl = "rmi://localhost/Main"; ServerIntf remote = (ServerIntf) Naming.lookup(rmiUrl); ArrayList al = (ArrayList) remote.getList(); Iterator it = al.iterator(); while (it.hasNext()) System.out.println(it.next().toString()); } catch (Exception ex) { ex.printStackTrace(); } } }
RMI uygulamasının çalıştırması
Adımlar
1- Javac kullanarak Java kaynak dosyalarının derlenmesi.
2- Rmic kullanarak İkame ve iskelet kodları üretmek. Java2 iskelet kodlara gerek duymaz. rmic ile ikame kod üretecekseniz classpath’te geçerli dizinin ekli olması gereklidir.
3- Rmiregistr servisini yürütmek : komut satırından : start rmiregistry
4- Uygulamayı yürütmek : istemci cihazda bulunacak class dosyaları Client.class Oluşturulmuşsa ServerImpl_Stub.class ve ServerIntf.class sunucu tarafında bulunacak dosyalar : Main.class , ServerIntf.class , ServerImpl.class oluşturmuşsa iskelet kod ServerImpl_Skel.class.
Uygulamanın istemci cihaz izerinde çalıştığında 1-9 arası sayıları ekrana yazacaktır.