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
133
134
135
136
137
|
Calculator RMI Reference Sample
===============================
This sample illustrates the use of Tuscany RMI Binding to call reference
services that are hosted as Java RMI services.
The README in the samples directory (the directory above this) provides
general instructions about building and running samples. Take a look there
first.
If you just want to run it to see what happens open a command prompt, first
navigate to the calculator-rmi-service sample and do:
ant run
OR if you don't have ant, on Windows do
java -cp ..\..\lib\tuscany-sca-manifest.jar;target\sample-calculator-rmi-service.jar calculator.CalculatorServer
and on *nix do
java -cp ../../lib/tuscany-sca-manifest.jar:target/sample-calculator-rmi-service.jar calculator.CalculatorServer
Now you have the server running you need to open another command prompt, navigate
to this sample directory and do:
ant run
OR if you don't have ant, on Windows do
java -cp ..\..\lib\tuscany-sca-manifest.jar;target\sample-calculator-rmi-reference.jar calculator.CalculatorClient
and on *nix do
java -cp ../../lib/tuscany-sca-manifest.jar:target/sample-calculator-rmi-reference.jar calculator.CalculatorClient
Sample Overview
---------------
This sample extends the calculator sample by replacing the local wired
connections with RMI bindings. Instead of local add, subtract, multiply and
divide components a CalculatorServiceRmiImpl.java object now provides the
add, subtract, multiple and divide interface and is hosted as an RMI server.
References specified in the .composite file include an RMI binding which targets
this RMI server.
This sample adds a number of classes to the basic calculator sample:
calculator-rmi-reference/
src/
main/
java/
calculator/
CalculatorService.java - as calculator sample
AddService.java - as calculator sample
SubtractService.java - as calculator sample
MultipleService.java - as calculator sample
DivideService.java - as calculator sample
CalculatorClient.java - as calculator sample
CalculatorServiceRmiImpl- implements the RMI server interface
that provides the target for the
RMI bindings in the composite
CalculatorServer.java - starts the Calculator Application
as a Java RMI Server. Running this class
keeps the Java RMI Server up an running
until the 'Enter Key' is pressed on the
console.
resources/
CalculatorRMIReference.composite - the SCA assembly for this sample
calculator-rmi-reference.png - a pictorial representation of the
.composite file
build.xml - the Ant build file for the client
pom.xml - the Maven build file
Note. As this test creates and uses local network connections you may need to
configure you firewall, if you are running one, to allow the test to run
successfully.
Building And Running The Sample Using Ant
-----------------------------------------
With the binary distribution the sample can be built and run using Ant. Two
build files are used to support client and server functions.
The server provides an RMI server that the acts as a target for the SCA RMI
bindings. Start a new console and use the following commands.
cd calculator-rmi-service
ant compile
ant run
This will run up the server and display the following.
run:
[java] Calculator RMI Service bound to RMI Registry at port 8099...
[java] ...Press Enter to Exit...
The client is very similar to the calculator sample. It starts the SCA runtime
and calls each of the calculator operations. In doing this the RMI bindings
make calls out the the RMI server you started in the previous step. Start
a new console and use the following commands.
cd calculator-rmi-reference
ant compile
ant run
You should see the following output from the run target.
run:
[java] 3 + 2=5.0
[java] 3 - 2=1.0
[java] 3 * 2=6.0
[java] 3 / 2=1.5
If you now return to the console window running the server and press enter the
server should stop.
Building And Running The Sample Using Maven
-------------------------------------------
With either the binary or source distributions the sample can be built and run
using Maven as follows.
cd calculator-rmi-reference
mvn
You should see the following output from the test phase.
-------------------------------------------------------
T E S T S
-------------------------------------------------------
Running calculator.CalculatorRMIReferenceTestCase
Tests run: 1, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 5.308 sec
Results :
Tests run: 1, Failures: 0, Errors: 0, Skipped: 0
This shows that the Junit test cases have run successfully.
|