Remote Method Invocation

Download as docx, pdf, or txt
Download as docx, pdf, or txt
You are on page 1of 12

Remote Method Invocation (RMI)

The Remote Method Invocation (RMI) is an API that provides a mechanism to


create distributed application in java. The RMI allows an object to invoke methods
on an object running in another JVM.
The RMI provides remote communication between the applications using two
objects stub and skeleton.

Stub and skeleton


RMI uses stub and skeleton object for communication with the remote object.
A remote object is an object whose method can be invoked from another JVM.

stub
The stub is an object, acts as a gateway for the client side. All the outgoing
requests are routed through it. It resides at the client side and represents the
remote object. When the caller invokes method on the stub object, it does the
following tasks:
1. It initiates a connection with remote Virtual Machine (JVM),
2. It writes and transmits (marshals) the parameters to the remote Virtual
Machine (JVM),
3. It waits for the result
4. It reads (unmarshals) the return value or exception, and
5. It finally, returns the value to the caller.

skeleton
The skeleton is an object, acts as a gateway for the server side object. All the
incoming requests are routed through it. When the skeleton receives the incoming
request, it does the following tasks:
1. It reads the parameter for the remote method
2. It invokes the method on the actual remote object, and
3. It writes and transmits (marshals) the result to the caller.

In the Java 2 SDK, an stub protocol was introduced that eliminates the need for
skeletons.

Steps to write the RMI program


The is given the 6 steps to write the RMI program.
1. Create the remote interface
2. Provide the implementation of the remote interface
3. Compile the implementation class and create the stub and skeleton objects
using the rmic tool
4. Start the registry service by rmiregistry tool
5. Create and start the remote application
6. Create and start the client application

Example of creating simple RMI application


In this example, we have followed all the 6 steps to create and run the rmi application. The
client application need only two files, remote interface and client application. In the rmi
application, both client and server interacts with the remote interface. The client application
invokes methods on the proxy object, RMI sends the request to the remote JVM. The return
value is sent back to the proxy object and then to the client application.

1) create the remote interface


For creating the remote interface, extend the Remote interface and declare the
RemoteException with all the methods of the remote interface. Here, we are creating a
remote interface that extends the Remote interface. There is only one method named add()
and it declares RemoteException.
1.
2.
3.
4.
5.

import java.rmi.*;
public interface Adder extends Remote{
public int add(int x,int y)throws RemoteException;
}

2) Provide the implementation of the remote interface


Now provide the implementation of the remote interface. For providing the implementation
of the Remote interface, we need to

Either extend the UnicastRemoteObject class,


or use the exportObject() method of the UnicastRemoteObject class

In case, you extend the UnicastRemoteObject class, you must define a constructor that
declares RemoteException.

1. import java.rmi.*;

2. import java.rmi.server.*;
3.
4. public class AdderRemote extends UnicastRemoteObject implements Adder{
5.
6. AdderRemote()throws RemoteException{
7. super();
8. }
9.
10. public int add(int x,int y){return x+y;}
11.
12. }

3) create the stub and skeleton objects using the rmic tool.
Next step is to create stub and skeleton objects using the rmi compiler. The rmic tool
invokes the RMI compiler and creates stub and skeleton objects.
1. rmic AdderRemote

4) Start the registry service by the rmiregistry tool


Now start the registry service by using the rmiregistry tool. If you don't specify the port
number, it uses a default port number. In this example, we are using the port number
5000.
1. rmiregistry 5000

5) Create and run the server application


Now rmi services need to be hosted in a server process. The Naming class provides methods
to get and store the remote object. The Naming class provides 5 methods.
1. public static java.rmi.Remote lookup(java.lang.String)
it returns the reference of the remote object.
2. public static void rebind(java.lang.String, java.rmi.Remote)
it binds the remote object to the new name.
In this example, we are binding the remote object by the name sonoo.
1. import java.rmi.*;
2. import java.rmi.registry.*;
3.
4. public class MyServer{
5.
6. public static void main(String args[]){
7. try{
8.
9. Adder stub=new AdderRemote();
10. Naming.rebind("rmi://localhost:5000/sonoo",stub);
11.
12. }catch(Exception e){System.out.println(e);}
13. }
14.
15. }

6) Create and run the client application


At the client we are getting the stub object by the lookup() method of the Naming class and
invoking the method on this object. In this example, we are running the server and client
applications, in the same machine so we are using localhost. If you want to access the
remote object from another machine, change the localhost to the host name (or IP address)
where the remote object is located.

1. import java.rmi.*;

2.
3. public class MyClient{
4.
5. public static void main(String args[]){
6. try{
7.

8. Adder stub=(Adder)Naming.lookup("rmi://localhost:5000/sonoo");
9. System.out.println(stub.add(34,4));
10.
11. }catch(Exception e){}
12. }
13.
14. }

download this example of rmi


1. For running this rmi example,

2.
3. 1) compile all the java files
4.
5. javac *.java
6.
7. 2)create stub and skeleton object by rmic tool
8.
9. rmic AdderRemote
10.
11. 3)start rmi registry in one command prompt
12.
13. rmiregistry 5000
14.
15. 4)start the server in another command prompt
16.
17. java MyServer
18.
19. 5)start the client application in another command prompt
20.
21. java MyClient

Output of this RMI example

Meaningful example of RMI application with database


Consider a scenario, there are two applications running in different machines. Let's say
MachineA and MachineB, machineA is located in United States and MachineB in India.
MachineB want to get list of all the customers of MachineA application.
Let's develop the RMI application by following the steps.

1) Create the table


First of all, we need to create the table in the database. Here, we are using Oracle10
database.

2) Create Customer class and Remote interface


File: Customer.java

1. package com.javatpoint;

2. public class Customer implements java.io.Serializable{


3.
private int acc_no;
4.
private String firstname,lastname,email;
5.
private float amount;
6. //getters and setters
7. }

Note: Customer class must be Serializable.


File: Bank.java

1. package com.javatpoint;
2.
3.
4.
5.
6.

import java.rmi.*;
import java.util.*;
interface Bank extends Remote{
public List<Customer> getCustomers()throws RemoteException;
}

3) Create the class that provides the implementation of Remote interface


File: BankImpl.java

1. package com.javatpoint;

2. import java.rmi.*;
3. import java.rmi.server.*;
4. import java.sql.*;
5. import java.util.*;
6. class BankImpl extends UnicastRemoteObject implements Bank{
7. BankImpl()throws RemoteException{}
8.
9. public List<Customer> getCustomers(){
10. List<Customer> list=new ArrayList<Customer>();
11. try{
12. Class.forName("oracle.jdbc.driver.OracleDriver");
13. Connection con=DriverManager.getConnection("jdbc:oracle:thin:@localhost:1521:xe","syst
em","oracle");
14. PreparedStatement ps=con.prepareStatement("select * from customer400");
15. ResultSet rs=ps.executeQuery();
16.
17. while(rs.next()){
18. Customer c=new Customer();
19. c.setAcc_no(rs.getInt(1));
20. c.setFirstname(rs.getString(2));
21. c.setLastname(rs.getString(3));
22. c.setEmail(rs.getString(4));
23. c.setAmount(rs.getFloat(5));
24. list.add(c);
25. }
26.
27. con.close();
28. }catch(Exception e){System.out.println(e);}
29. return list;
30. }//end of getCustomers()
31. }

4) Compile the class rmic tool and start the registry service by
rmiregistry tool

5) Create and run the Server


File: MyServer.java

1. package com.javatpoint;
2.
3.
4.
5.
6.
7.

import java.rmi.*;
public class MyServer{
public static void main(String args[])throws Exception{
Remote r=new BankImpl();
Naming.rebind("rmi://localhost:6666/javatpoint",r);
}}

6) Create and run the Client


File: MyClient.java

1. package com.javatpoint;

2. import java.util.*;
3. import java.rmi.*;
4. public class MyClient{
5. public static void main(String args[])throws Exception{
6. Bank b=(Bank)Naming.lookup("rmi://localhost:6666/javatpoint");
7.
8. List<Customer> list=b.getCustomers();
9. for(Customer c:list){
10. System.out.println(c.getAcc_no()+" "+c.getFirstname()+" "+c.getLastname()
11. +" "+c.getEmail()+" "+c.getAmount());
12. }
13.
14. }}

You might also like