Remoting JDO objects using RMI

Gopalan Suresh Raj

Note
To work with any of these samples, you will need the following:
.........................................JDK 1.2 or higher (I use JDK 1.3.1)
.........................................PE:JTM - The Productivity Environment for JavaTM (from HYWY Software Corporation)

 

Note: This article assumes that the reader has already created simple bank project using PE:J and JDO.

The Transfer Money Object Interaction Diagram is as shown below:

The Transfer Money logic is as follows:

  1. The IIOP Client (IIOPClient.java) obtains a reference to the TellerRemote (TellerRemote.java) remote object from Teller Server (TellerServer.java).

  2. The IIOP Client (IIOPClient.java) invokes the transferMoney() method of the TellerRemote (TellerRemote.java) object.

  3. The TellerRemote (TellerRemote.java) invokes the TransferMoney() method on the JDO Client (Teller.java).

  4. The JDO Client (Teller.java) obtains a configured PersistenceManagerFactory from the JDOAdapter.

  5. The JDO Client (Teller.java)  uses the configured PMF to get a PersistenceManager.

  6. The JDO Client (Teller.java)  uses the Persistence Manager to obtain a Transaction object.

  7. The JDO Client (Teller.java) begins a new Transaction using the Transaction object.

  8. The JDO Client (Teller.java) invokes the credit method on the Checking object.

  9. The JDO Client (Teller.java) then invokes the debit method on the Savings object.

  10. The JDO Client (Teller.java) then commits the transaction by invoking the method in the Transaction object.

  11. The JDO Client (Teller.java) then closes the Persistence Manager.

  12. The JDO Client (Teller.java) then closes the JDOAdapter.

 

 

com/hywy/samples/remote/TellerRemoteImpl.java
1:
2:
3:
4:
5:
6:
7:
8:
9:
10:
11:
12:
13:
14:
15:
16:
17:
18:
19:
20:
21:
22:
23:
24:
25:
26:
27:
28:
29:
30:
31:
32:
33:
34:
35:
36:
37:
38:
39:
40:
41:
42:
43:
44:
45:
46:
47:
48:
49:
50:
51:
52:
53:
54:
55:
56:
57:
58:
59:
60:
61:
62:
63:
64:
65:
66:
67:
68:
69:
70:
71:
72:
73:
74:
75:
76:
77:
78:
79:
80:
81:
82:
83:
84:
85:
86:
87:
88:
89:
90:
91:
92:
93:
94:
95:
96:
97:
98:
99:
100:
101:
102:
103:
104:
105:
106:
107:
108:
109:
110:
111:
112:
113:
114:
115:
116:
117:
118:
119:
120:
121:
122:
123:
124:
125:
126:
127:
128:
129:
130:
131:
132:
/**
  * The following example illustrates an RMI-IIOP Server
  *
  * author: Gopalan Suresh Raj
  * Copyright (c), 2002. All Rights Reserved.
  * URL: https://gsraj.tripod.com/
  * email: gopalan@gmx.net
  */

///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// To Compile
// cd C:\run\projects\bank\enhanced
// C:\java\jdk1.3\bin\rmic -classpath . -iiop -idl com.hywy.samples.remote.TellerRemoteImpl
// copy C:\run\projects\bank\enhanced\com\hywy\samples\remote\_TellerRemote_Stub.class C:\run\projects\bank\enhanced\com\hywy\samples\remote\client\
// copy C:\run\projects\bank\enhanced\com\hywy\samples\remote\_TellerRemoteImpl_Tie.class C:\run\projects\bank\enhanced\com\hywy\samples\remote\client\
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
package com.hywy.samples.remote;

import java.util.ArrayList;
import java.util.Iterator;
import java.rmi.RemoteException;

import javax.rmi.PortableRemoteObject;

import com.hywy.samples.bank.Teller;

/**
* This component looks up the price of a given Stock Symbol
*
* @author Gopalan Suresh Raj
*/

public class TellerRemoteImpl extends PortableRemoteObject
  implements TellerRemote {

  /** The Teller reference */
  private Teller teller_;

  /**
   * Public No argument constructor
   */

  public TellerRemoteImpl() throws RemoteException {
    // Invoke the superclass to export this object
    super();
    this.teller_ = new Teller();
  }

  /**
   * Create Checking or Savings Account
   */

  public void createAccount(String customerNames,
                            int startingBalance,
                            boolean isCheckingAccount) throws RemoteException {
    try {
      this.teller_.createAccount(customerNames, startingBalance, isCheckingAccount);
    }
    catch(Exception exception) {
      throw new RemoteException(exception.toString());
    }
  }

  /**
   * Delete and close the account
   */

  public void deleteAccount(long accountNumber) throws RemoteException {
    try {
      this.teller_.deleteAccount(accountNumber);
    }
    catch(Exception exception) {
      throw new RemoteException(exception.toString());
    }
  }

  /**
   * Transfer Money
   */

  public boolean transferMoney(long fromAccountNumber,
                               long toAccountNumber,
                               int amount) throws RemoteException {
    boolean result = false;
    try {
      result = this.teller_.transferMoney(fromAccountNumber, toAccountNumber, amount);
    }
    catch(Exception exception) {
      throw new RemoteException(exception.toString());
    }
    return result;
  }

  /**
   * List out all Checking accounts found
   */

  public ArrayList listAllCheckingAccounts() throws RemoteException {
    String THIS = "listAllCheckingAccounts() - ";
    ArrayList list = null;
    Iterator iterator = null;
    try {
      list = this.teller_.listAllCheckingAccounts();
    }
    catch(Exception exception) {
      throw new RemoteException(exception.toString());
    }
    if(list != null) {
      iterator = list.iterator();
      while(iterator.hasNext()) {
        System.out.println(THIS+iterator.next().toString());
      }
    }
    return list;
  }

  /**
   * List out all Savings accounts found
   */

  public ArrayList listAllSavingsAccounts() throws RemoteException {
    String THIS = "listAllSavingsAccounts() - ";
    ArrayList list = null;
    Iterator iterator = null;
    try {
      list = this.teller_.listAllSavingsAccounts();
    }
    catch(Exception exception) {
      throw new RemoteException(exception.toString());
    }
    if(list != null) {
      iterator = list.iterator();
      while(iterator.hasNext()) {
        System.out.println(THIS+iterator.next().toString());
      }
    }
    return list;
  }

}

 

click here to go to
My JDO HomePage...

click here to go to
My Advanced Java Tutorial Page...

About the Author...
Gopalan Suresh Raj is a Software Architect, Developer and an active Author. He has co-authored a number of books including "Professional JMS", "Enterprise Java Computing-Applications and Architecture" and "The Awesome Power of JavaBeans". His expertise spans enterprise component architectures and distributed object computing. Visit him at his Web Cornucopia© site (https://gsraj.tripod.com/) or mail him at gopalan@gmx.net.

Go to the Component Engineering Cornucopia page

This site was developed and is maintained by Gopalan Suresh Raj

This page has been visited times since February 26,2002.

Last Updated : Feb 26, 2002

If you have any questions, comments, or problems regarding this site, please write to me I would love to hear from you.


Copyright (c) 1997-2002, Gopalan Suresh Raj - All rights reserved. Terms of use.

All products and companies mentioned at this site are trademarks of their respective owners.