Document 3159078
Download
Report
Transcript Document 3159078
CORBA and Java
by Alex
Chaffee
[email protected]
http://www.jguru.com/
Java
online resources
http://www.purpletech.com/
Java
training and consulting
Copyright © 1998 Purple Technology, Inc
Abstract
CORBA loves Java! CORBA provides a platform-independent,
language-independent way to write applications that can invoke
objects that live across the room or across the planet. Java is an
object-oriented language that's ideal for writing the clients and
servers living on the Object Bus. In this session, we examine the
ways they interoperate programmatically, as we walk you stepby-step from a CORBA IDL, to a server and client both written in
Java, running on top of a 100%-Java ORB. We also discuss the
relationship between CORBA and RMI, and discuss some of the
real-world issues involved in deploying a CORBA-based
application. Recommended: some knowledge of CORBA, ability
to read Java source code.
Copyright © 1998 Purple Technology, Inc
Introduction
Purple
Technology
http://www.purpletech.com
Java
Alex
Training and Consulting
Chaffee
Creator
of Gamelan
Cool Java Dude
Copyright © 1998 Purple Technology, Inc
Part I: CORBA Overview
Copyright © 1998 Purple Technology, Inc.
What is CORBA?
Common
Object Request Broker
Architecture
Communication infrastructure for
distributed objects
Allows a heterogeneous, distributed
collection of objects to collaborate
transparently
Copyright © 1998 Purple Technology, Inc
What is CORBA good for?
Developing
distributed applications
Locating remote objects on a network
Sending messages to those objects
Common interface for transactions,
security, etc.
CORBA
Services (more later)
Copyright © 1998 Purple Technology, Inc
Why Distributed
Applications?
Data
is distributed
Administrative
and ownership reasons
Heterogeneous systems
Shared by multiple applications
Scalability
Copyright © 1998 Purple Technology, Inc
Why Distributed
Applications?
Computation
is distributed
Scalability:
multiprocessing
Take computation to data
Heterogeneous architectures
Users
are distributed
Multiple
users interacting and
communicating via distributed applications
Copyright © 1998 Purple Technology, Inc
Distributed Object Systems
All
entities are modeled as objects
Systems support location transparency
Interfaces, not implementations, define
objects
Good distributed object systems are
open, federated systems
Copyright © 1998 Purple Technology, Inc
What is the OMG?
Designers
of CORBA
Consortium of 700+ companies
Not
including Microsoft
Members:
platform
vendors
database
software
tool developers
corporate
software
vendors
developers
application vendors
Copyright © 1998 Purple Technology, Inc
It’s Just A Spec
Has
never been fully implemented
Probably never will be
Industry moves quickly and spec has to
keep up
Interoperability
vs. portability
Pass-by-value
Copyright © 1998 Purple Technology, Inc
Basic CORBA Architecture
Server
Client
response
request
ORB
ORB
“Object Bus”
Copyright © 1998 Purple Technology, Inc
CORBA Objects
Examples
Service
Client
Component
Business
object
CORBA objects approach universal
accessibility
Any
Language
Any Host on network
Any Platform
Copyright © 1998 Purple Technology, Inc
CORBA Elements
1.
ORB
2. CORBA Services
3. CORBA Facilities
4. Application Objects
Copyright © 1998 Purple Technology, Inc
ORB
Object
Request Broker
“Object
Handles
Bus”
all communication among
objects
Each host (machine) has its own ORB
ORBs know how to talk to each other
ORB also provides basic services to
client
Copyright © 1998 Purple Technology, Inc
ORB Responsibilities
Find
the object implementation for the
request
Prepare the object implementation to
receive the request
Communicate the data making up the
request
Retrieve results of request
Copyright © 1998 Purple Technology, Inc
Network of ORBs
There’s
an ORB on the server too
ORB receives request
Copyright © 1998 Purple Technology, Inc
IIOP
Internet
Inter-Orb Protocol
Network or “wire” protocol
Works across TCP/IP (the Internet
protocol)
Copyright © 1998 Purple Technology, Inc
ORB Features
Method
invocations
Static
and Dynamic
Remote objects or CORBA services
High-level
language bindings
Use
your favorite language; ORB
translates
Self-describing
Provides
services
metadata for all objects and
Copyright © 1998 Purple Technology, Inc
ORB Features
Local
or remote
Same
API wherever target object lives
Preserves
context
Distributed
security and transactions
Coexistence
Just
with legacy code
provide a wrapper object
Copyright © 1998 Purple Technology, Inc
What is an ORB really?
Not
a separate process
Library code that executes in-process
Listens to TCP ports for connections
One
port per local object
Opens
N
TCP sockets to other objects
ports per remote machine
Copyright © 1998 Purple Technology, Inc
IDL
Interface
Definition Language
Defines protocol to access objects
Like a contract
Well-specified
Language-independent
Copyright © 1998 Purple Technology, Inc
IDL Example
module Calc {
interface Adder {
long add(in long x, in long y);
}
}
Defines
an object called Adder with a
method called add
Copyright © 1998 Purple Technology, Inc
Stubs and Skeletons
Stub
lives
on client
pretends to be remote object
Skeleton
lives
on server
receives requests from stub
talks to true remote object
delivers response to stub
Copyright © 1997 Alex Chaffee
Stubs and Skeletons (Fig.)
Client Host Machine
Server Host Machine
Client
Object
Remote
Object
Stub
Skeleton
ORB
IIOP
ORB
Copyright © 1997 Alex Chaffee
Client vs. Server
in
CORBA, a client is a client relative to
a particular object
i.e. an object with a reference to a
“server” object
A client may also act as a server
If
it has an IDL and stubs and skeletons
Technically,
a CORBA server contains
one or more CORBA objects
Copyright © 1998 Purple Technology, Inc
Different Meanings of
“Server”
Host
machine
Program running on host machine
CORBA object running inside program
has
IDL, stub, skeleton
Sometimes called a Servant
Copyright © 1998 Purple Technology, Inc
Stubs and Skeletons ->
Platform Independence
Client
code has no knowledge of the
implementation of the object or which ORB
is used to access the implementation.
Copyright © 1998 Purple Technology, Inc
CORBA Services
APIs
for low-level, common tasks
Life Cycle Service
creating,
copying, moving, removing
objects
Naming
Service
Register
objects with a name
Look up objects by name
Copyright © 1998 Purple Technology, Inc
CORBA Services
Concurrency
Obtain
Control Service
and release exclusive locks
Transaction
Service
Two-phase
commit coordination
Supports nested transactions
Persistence
Service
Storing
objects in a variety of databases
RDBMS, OODBMS, file systems
Copyright © 1998 Purple Technology, Inc
CORBA Services
Security
Service
Authentication, ACLs,
Event
encryption, etc.
Service
Uncoupled
notifications
Copyright © 1998 Purple Technology, Inc
CORBA Services
Relationship
Externalization
Query
Licensing
Properties
Time
Trader
Collection
… and so on…
See
what I mean about it never being
Copyright © 1998 Purple Technology, Inc
implemented?
CORBA Facilities
Frameworks
for specialized applications
Distributed Document Component
Facility
OpenDoc
In
progress:
Agents
Business
Objects
Internationalization
Copyright © 1998 Purple Technology, Inc
N-Tier Design with CORBA
Storage “Tier”
ORB
DB
ORB
ORB
ORB
DB
Data Object
ORB
ORB
ORB
ORB
Client Tier
TP Monitor
ORB
Business Object
Tier
(after diagram in Orfali et al.)
Service “Tier”
Copyright © 1998 Purple Technology, Inc
Three Tiers
User
Interface Tier
Business Logic Tier
Data Storage Tier
Can use CORBA objects in each tier
Copyright © 1998 Purple Technology, Inc
Part II: Java IDL - Using
CORBA from Java
Copyright © 1998 Purple Technology, Inc.
Java CORBA Products
The
Java 2 ORB
VisiBroker for Java
OrbixWeb
Netscape Communicator
Various free or shareware ORBs
Copyright © 1998 Purple Technology, Inc
Java IDL
Should
be named “Java CORBA”
More
than just IDL
Full (?) implementation of CORBA in 100%
Java
Three
Parts
ORB
Naming
Service
idltojava compiler
Ships
with JDK 1.2
Copyright © 1998 Purple Technology, Inc
Transparent API
JavaIDL
turns IDL into direct method
calls
Easy to program
Clients have no knowledge of
implementation
Highly portable
Copyright © 1998 Purple Technology, Inc
The Java ORB
100%
Java
Generic
Allows Java IDL applications to run
either as stand-alone Java applications,
or as applets within Java-enabled
browsers
Uses IIOP
Copyright © 1998 Purple Technology, Inc
Other Java ORBs
Visigenic
(Inprise) VisiBroker
Netscape
Communicator
Oracle Web Server 3.0
Free download
Iona
OrbixWeb
Copyright © 1998 Purple Technology, Inc
IDL to Java Mapping
Defined
by OMG
Translates IDL concepts into Java
language constructs
Everything is accessible by writing
normal-looking Java code
Copyright © 1998 Purple Technology, Inc
IDL to Java Type Mapping
IDL Type
boolean
char / wchar
octet
short / unsigned short
long / unsigned long
long long / unsigned long long
float
double
string / wstring
Java Type
boolean
char
byte
short
int
long
float
double
String
Copyright © 1998 Purple Technology, Inc
IDL vs. Java vs. C++
concepts
IDL
module
Java
package
C++
namespace
interface
interface abstract
class
operation
method
member
function
attribute
pair of
methods
pair of
functions
Copyright © 1998 Purple Technology, Inc
IDL Modules
Map
to Java packages
Unfortunately, it has the root level name
of the module
Clutters up your package hierarchy
e.g. module Calc ->
package
Calc
interface Calc.Adder
not package
ORG.omg.CORBA.modules.Calc
Copyright © 1998 Purple Technology, Inc
IDL Interfaces
Map
to Java interfaces
Copyright © 1998 Purple Technology, Inc
IDL Operations
Map
to Java methods
Copyright © 1998 Purple Technology, Inc
IDL Attributes
Map
to pair of functions
IDL
string
name;
Java
public
void name(String val);
public String name();
Yes,
it looks stupid. Sorry.
Copyright © 1998 Purple Technology, Inc
idltojava
Development
tool
Automatically generates java stubs,
skeletons, helpers, holders, ...
Generates stubs for specific remote
interfaces
Copyright © 1998 Purple Technology, Inc
Stubs
Java
objects call stub methods
Stubs communicate with CORBA
objects
and
vice versa
Transparent
integration
Copyright © 1998 Purple Technology, Inc
Skeletons
ORB
passes request to skeleton (like a
stub)
Skeleton calls local implementation
Copyright © 1998 Purple Technology, Inc
Remote Interfaces and
Stubs
IDL Interface
implements
implements
extends
Client
Stub
Skeleton
Remote Object
(Server)
Copyright © 1997 Alex Chaffee
Show Me The Source Code
OK,
here it comes...
Copyright © 1998 Purple Technology, Inc
idltojava input
Calc.idl
module Calc {
interface Adder {
long add(in long x, in long y);
}
}
Copyright © 1998 Purple Technology, Inc
idltojava output
idltojava
Calc.idl
Adder.java (a Java interface that
maps the IDL interface)
_AdderStub.java (a client stub)
_AdderImplBase.java (a server
skeleton)
AdderHelper.java (a helper class)
AdderHolder.java (a holder class)
Must
compile these files and put them in
your CLASSPATH
Copyright © 1998 Purple Technology, Inc
Adder.java
Created
for you by idltojava
package Calc;
public interface Adder
extends
org.omg.CORBA.Object {
int add(int x, int y);
}
Copyright © 1998 Purple Technology, Inc
Implementing a server
Extend
base class
Implement
Provide
Create
all methods declared in IDL
a main method
an ORB instance
Create a server instance
Inform the ORB about the instance
Acquire a Naming Context
Register the instance in that Naming
Context under some name Copyright © 1998 Purple Technology, Inc
AdderServer.java
class AdderServer extends _AdderImplBase
{
public int add( int x, int y ) {
System.out.println(x + " + " + y + "
= " + (x+y));
return x + y;
}
Copyright © 1998 Purple Technology, Inc
AdderServer.java (cont.)
public static void main(String args[]) {
// create and initialize the ORB
ORB orb = ORB.init(args, null);
// create server and register it with
the ORB
AdderServer adderRef = new
AdderServer();
orb.connect(adderRef);
Copyright © 1998 Purple Technology, Inc
AdderServer.java (cont.)
// get the root naming context
org.omg.CORBA.Object objRef =
orb.resolve_initial_references("NameSer
vice");
NamingContext ncRef =
NamingContextHelper.narrow(objRef);
// bind the Object Reference in Naming
NameComponent nc = new
NameComponent("Adder", "");
NameComponent path[] = {nc};
ncRef.rebind(path, adderRef);
Copyright © 1998 Purple Technology, Inc
Implementing a client
Create
an ORB
Get a reference to the Naming Context
Look up the correct name in that
Naming Context
Receive an object reference to that
object
Actually,
Invoke
to its Stub
methods on the reference
Copyright © 1998 Purple Technology, Inc
AdderClient.java
Copyright © 1998 Purple Technology, Inc
Object Reference
Two
Meanings
1. An
abstract concept referring to a
specific object living on a specific host,
attached to a specific ORB
2. A local Java reference to an object that
relays messages to that object
Obtained
from
new
keyword
a Factory Object
the Naming Service
Copyright © 1998 Purple Technology, Inc
Naming Service
tnameserv
t
is for “transient”
Maps
name to object reference
An implementation of the CORBA
Object Service (COS) name service
to run the Naming Service
UNIX:
tnameserv &
Win32:
start /m tnameserv
Copyright © 1998 Purple Technology, Inc
Fire it up
start
/m tnameserv
start java AdderServer
java AdderClient
2 + 2 = ?
Copyright © 1998 Purple Technology, Inc
CORBA Flow
Client Virtual Machine
Server Virtual Machine
Client
Remote
Object
Skeleton
Stub
Server
“Fred”
Name Server Virtual Machine
Copyright © 1997 Alex Chaffee
CORBA Flow
1. Server Creates Remote Object
Client Virtual Machine
2. Server Registers Remote Object
Client
Server Virtual Machine
Remote
Object
1
Skeleton
Stub
Server
2
“Fred”
Name Server Virtual Machine
Copyright © 1997 Alex Chaffee
CORBA Flow
Client Virtual Machine
3. Client requests object fromRemote
Name Server
4. Name Server returns remote
reference
Object
(and stub gets created)
Client
Skeleton
Stub
3
Server Virtual Machine
Server
4
“Fred”
Name Server Virtual Machine
Copyright © 1997 Alex Chaffee
RMI Flow
Client Virtual Machine
Server Virtual Machine
Client
Remote
Object
5
7
6
Stub
Skeleton
Server
5. Client invokes stub method
6. Stub talks to skeleton
7. Skeleton invokes remote object
“Fred”
method
Name Server Virtual Machine
Copyright © 1997 Alex Chaffee
Pseudo-objects
The
ORB is a pseudo-object
It works just like a remote object, only
it’s local
Copyright © 1998 Purple Technology, Inc
The Basic Object Adapter
(BOA)
Another
pseudo-object
Helps register objects with the ORB
Functions
Maintain
Implementation Repository
Generate and interpret object references
Activate and deactivate implementation
objects
Invoke methods via skeletons
Copyright © 1998 Purple Technology, Inc
Why do you need both an
ORB and a BOA?
I’m
not really sure
Allows vendors to optimize or enhance
functionality
register
many objects en masse
cache object state elsewhere
E.g.
Object database
Copyright © 1998 Purple Technology, Inc
Using the BOA
Slightly
different procedure for
initializing objects
Hides name service from you
Ask
the BOA to register the object
Ask the Helper object to bind the object
Once
the object is created, interface is
identical
Just
call methods using normal Java
syntax
Copyright © 1998 Purple Technology, Inc
BOA Object Activation
Shared
server
Multiple
objects, one server
Normal procedure
Multithreaded (handled by CORBA
implementation)
Unshared
New
server
process for each object
Copyright © 1998 Purple Technology, Inc
BOA Object Activation
(cont.)
Server-per-method
Batch
processing
Persistent
Shared
server
server, but object not created by
ORB
Copyright © 1998 Purple Technology, Inc
BOA Object Activation
Scenario
Server
obj
creates object instance
= new MyObject();
Server
registers object with BOA
boa.create(interface_name,
implementation_name, reference_data)
VisiBroker does this for you in superclass
constructor
Copyright © 1998 Purple Technology, Inc
BOA Object Activation
Scenario (cont.)
Server
tells BOA the object is ready
boa.obj_is_ready(obj)
Server
tells BOA that all objects are
ready
boa.impl_is_ready()
Objects
shut down
boa.deactivate_obj(this)
Server
shuts down
boa.deactivate_impl()
Copyright © 1998 Purple Technology, Inc
Threads in JavaIDL
Remote
invocations happen on a
separate thread
Must make sure your remote objects
are thread-safe
Copyright © 1998 Purple Technology, Inc
Callbacks
Pass
in a reference to some CORBA
object
The server object can invoke methods
on that reference
ORB automatically generates a stub on
the server side
The server has become the client, and
vice versa
Copyright © 1998 Purple Technology, Inc
Obtaining Object
References
From
the ORB
orb.resolve_initial_references(“NameServic
e”)
From
a Naming Context
From a Stringified reference
From another object
From a parameter to your remote
method
Copyright © 1998 Purple Technology, Inc
Helper Objects
How
CORBA does casting
narrow method changes the type of an
object reference
// get the root naming context
org.omg.CORBA.Object objRef =
orb.resolve_initial_references("NameSer
vice");
NamingContext ncRef =
NamingContextHelper.narrow(objRef);
Copyright © 1998 Purple Technology, Inc
Naming Contexts
Directory
structure for CORBA
Naming Component = file
Naming Context = directory
Can add a Context as a Component
like
subdirectories
Can
add a Context on a different name
server
like
symbolic links
Copyright © 1998 Purple Technology, Inc
Stringification
Stringified
reference is ORBindependent
Object to string
org.omg.CORBA.Object obj = ...
String str = orb.object_to_string(obj);
String to object
org.omg.CORBA.Object obj =
orb.string_to_object(str);
Copyright © 1998 Purple Technology, Inc
Visigenic: Caffeine
Java
to IDL compiler
Copyright © 1998 Purple Technology, Inc
Symantec: Visual Café 3.0
Enterprise Suite
Java
to IDL compiler
Automatic client adapter bean
generation
Makes
a JavaBean that’s a proxy to a
CORBA object
Distributed
debugging
Follow
call chain, examine variables, et al.
Across many VMs, many hosts, many OSs
Copyright © 1998 Purple Technology, Inc
Part III: Example
Application
Copyright © 1998 Purple Technology, Inc
Publish-Subscribe System
Channel:
an avenue for real-time data
exchange
Consumers can subscribe to arbitrary
data channels
Producers can publish data on channels
Invokes
callback method on consumer
Copyright © 1998 Purple Technology, Inc
Object Model
PSServer
Channel
creates
getChannel(String channelName)
channel if it doesn’t already exist
Channel
void
subscribe(Subscriber sub)
void publish(Object data)
Subscriber
void
dataArrived(Object data)
Copyright © 1998 Purple Technology, Inc
Flow: Subscriber-side
Client
acquires PSServer reference
Client acquires channel from PSServer
Client creates subscriber locally,
passing reference to channel
Subscriber registers self with channel
channel.subscribe(this)
Client
waits for callback to its
dataArrived method
Copyright © 1998 Purple Technology, Inc
Flow: Publisher-side
Client
acquires PSServer reference
Client acquires channel from PSServer
Client creates publisher locally, passing
reference to channel
Publisher acquires data
From
a database
From a data feed
Publisher
calls channel.publish(data)
Copyright © 1998 Purple Technology, Inc
Example Application: Stock
data
Channel
name = stock symbol name
Source code available
Copyright © 1998 Purple Technology, Inc
Design issues
Name
space for channels
TIBCO
et al. use hierarchical directory
structure
Caching
prior messages
Subscribe
should spawn a thread that
sends previous N messages
Copyright © 1998 Purple Technology, Inc
Design issues
Maintain
local cache of data sent
Don’t
want to go back across the network
every time you draw a graph
Create local version of class
Copyright © 1998 Purple Technology, Inc
Part IV: Advanced Topics
Copyright © 1998 Purple Technology, Inc
Exceptions
CORBA exceptions are mapped to Java
exceptions
System Exceptions
They’re
subclasses of RuntimeException, so the
compiler won’t complain if you forget to catch
them
Minor codes
additional information
vendor-specific :-(
Completion
Status
Copyright © 1998 Purple Technology, Inc
Exceptions (cont.)
User Exceptions
Generated
by idltojava
Subclasses of Exception (declared)
Copyright © 1998 Purple Technology, Inc
Dynamic Invocation Interface
(DII)
CORBA is fully self-aware
Methods for acquiring
List
of all services
List of known objects
Interfaces of known objects
Etc.
Well-documented
elsewhere
Copyright © 1998 Purple Technology, Inc
Interface Repositories
JavaIDL
clients do not typically need or
use an Interface Repository
All of the needed type information is
available in the stubs or is resolved by
an object's server
JavaIDL supports access to Interface
Repository information made available
by other CORBA object
implementations.
Copyright © 1998 Purple Technology, Inc
Implementation Repository
contains
information that allows the
ORB to locate and activate
implementations of objects
also store additional information
associated with implementations of
ORB objects.
Debugging
information
Administrative control
Resource allocation
Security
Copyright © 1998 Purple Technology, Inc
Value Objects
CORBA 3.0
Blobs
Avoids
network latency of pass-byreference objects
Copyright © 1998 Purple Technology, Inc
RMI over IIOP
In
Development
Uses IIOP as transport protocol
Uses Value Objects to pass Java
serialized objects
Copyright © 1998 Purple Technology, Inc
CORBA via RMI
Possible
using middleware server
RMI from client to middleware
IIOP from middleware to other servers
Can use Servlet as middleware
Copyright © 1998 Purple Technology, Inc
CORBA and EJB
Transport
EJB
uses RMI interface, RMI uses IIOP
CORBA 3.0
promises object
compatibility with EJB
Not
quite sure what that means
Some
All
EJB Servers contain an ORB
EJB Objects are also CORBA objects
Copyright © 1998 Purple Technology, Inc
CORBA and EJB (Cont.)
All
EJB Servers use CORBA
Transactions (via JTS)
That
means that any client can make a
distributed transaction that includes both
CORBA and EJB Objects
Not
an either-or decision
You
can have both EJB and CORBA
working together in a single system
Copyright © 1998 Purple Technology, Inc
Java Transactions
Java
Transaction Service (JTS)
A standard
Java mapping of the OMG
Object Transaction Service (OTS)
packages
org.omg.CosTransaction and
org.omg.CosTSPortability
Java
Transaction API (JTA)
High-level
transaction management
specification
package
javax.transaction
Copyright © 1998 Purple Technology, Inc
Object Transaction Service
(OTS)
Distributed
Part
transaction specification
of CORBA, but also standalone
Transactions
can span
multiple
queries
multiple
objects
multiple
servers
multiple
databases
multiple
vendors’ products
Copyright © 1998 Purple Technology, Inc
OTS Features
Distributed
Flat
transactions
or nested transactions
Two-phase
Vendor
commit
interoperability (?)
Copyright © 1998 Purple Technology, Inc
OTS Object Model
Transactional
Can
Object
participate in a transaction
Recoverable
Object
Actually
performs commit or rollback on its
own data
Resource
A system
or server that can commit or
rollback data stored inside it
E.g.
a database server
Copyright © 1998 Purple Technology, Inc
OTS Object Model (Cont.)
Current
Reference/wrapper
to currently active transaction
Control / Coordinator / Terminator
Registers
objects
Performs
distributed commit/rollback
Synchronization
An
object that gets informed of the progress of the
ongoing transaction
Implements
callback methods
Copyright © 1998 Purple Technology, Inc
Part V: CORBA/Java Case
Studies
Copyright © 1998 Purple Technology, Inc.
CORBA Case Study
Kaiser
Permanente Northern California
KAHUNA a/k/a WebChart
http://www.javaworld.com/jw-111998/jw-11-kaiser.html?101698txt
Copyright © 1998 Purple Technology, Inc
Problem: Specific
Medical
records, patient histories,
clinical schedules, lab results, and
medical images all stored in disparate
databases
Many
patients per doctor, many doctors
per patient
Need
immediate access to all
information
Copyright © 1998 Purple Technology, Inc
Problem: General
getting
data
from
a multitude of sources
in a multitude of media
putting
into
data
a single system
distributing
data
to
a wide variety of desktops
throughout a very large company
Copyright © 1998 Purple Technology, Inc
Solution: Java/CORBA
“Not
only did Java/CORBA solve all
these problems, but Java/CORBA
development is cheap, fast, scalable
and works over the Internet.”
Copyright © 1998 Purple Technology, Inc
WebChart Architecture
Copyright © 1998 Purple Technology, Inc
This is your brain on Java.
Any questions?
Copyright © 1998 Purple Technology, Inc
Conclusion
Copyright © 1998 Purple Technology, Inc.
Where to Get More
Information
Orfali
& Harkey, Client/Server Programming with
Java and CORBA (Wiley)
Orfali, Harkey & Edwards, Instant CORBA (Wiley)
Copyright © 1998 Purple Technology, Inc
More Info: Links
This
http://www.purpletech.com/
JDK
Presentation
1.2 CORBA documentation
http://java.sun.com/products/jdk/1.2/docs/guide/idl/
Glerum,
WebChart serves up Kaiser patients,
JavaWorld
http://www.javaworld.com/jw-11-1998/jw-11kaiser.html?101698txt
Copyright © 1998 Purple Technology, Inc
More Info: Links
Object
Management Group - http://www.omg.org
Java Transactions
http://java.sun.com/products/jta/
http://java.sun.com/products/jts/
ftp://www.omg.org/pub/docs/formal/97-12-17.pdf
Copyright © 1998 Purple Technology, Inc