180 likes | 316 Views
Nanbor Wang and Roopa Pundaleeka { nanbor , roopa }@txcorp.com Tech-X Corporation Boulder, CO. Update on CORBA Support for Babel RMI . CCA Meeting, April 19, 2007. Funded by DOE OASCR SBIR Grant #DE-FG02-04ER84099. Overview. Brief review of the project
E N D
Nanbor Wang and Roopa Pundaleeka{nanbor,roopa}@txcorp.comTech-X CorporationBoulder, CO Update on CORBA Support for Babel RMI CCA Meeting, April 19, 2007 Funded by DOE OASCR SBIR Grant #DE-FG02-04ER84099
Nanbor Wang and Roopa Pundaleeka Overview • Brief review of the project • New development since the last CCA meeting • Future work
Nanbor Wang and Roopa Pundaleeka BABEL RMI CLIENT BABEL RMI SERVER Simple Protocol BABEL RMI CLIENT BABEL RMI SERVER TAO TaoIIOP Protocol Babel RMI Support • Babel generates mapping for remote invocations, and uses Simple Protocol • Babel has the capability to allow users to take advantage of various remoting technologies through third party RMI libraries • We are developing a CORBA protocol library for Babel RMI using TAO (version 1.5.1 or later) • TAO is the C++ based CORBA middleware framework • This protocol is essentially a bridge between Babel and TAO
Nanbor Wang and Roopa Pundaleeka Adding CORBA protocol for Babel RMI Goal Develop CORBA protocol for Babel RMI for communication between Babel clients and servants Also allowing interoperability between existing CORBA and Babel objects Direct mapping approach Requires support of certain Babel types; complex numbers, multidimensional arrays and exceptions All special type mappings defined under namespace taoiiop_rmi Still exchange messages in CORBA format Allow development of new SIDL-compatible CORBA objects
Nanbor Wang and Roopa Pundaleeka Client-side Operation Invocations CORBA uses Common Data Representation (CDR) – a binary serialization format, for transferring messages An Operation_Details object encapsulates all information related to invocations in TAO – outgoing CDR and incoming CDR streams Need to extend TAO’s Operation_Details to expose internal CDR data members to extract the results Create TAO Argument list in pack methods for ‘in’ and ‘inout’ parameters TAO argument list no longer requires the return type as the first argument
Nanbor Wang and Roopa Pundaleeka Client-side Operation Invocations in TAO Encapsulates invocation requests and replies in CDR streams TAO client makes the method invocation on the TAO stubs Used for transferring messages TAO Stubs: Create argument list based on the signature Create an instance of the TAO Invocation Adapter Call invoke on the TAO Invocation Adapter Makes the remote method invocation
Nanbor Wang and Roopa Pundaleeka Client-side Operation Invocations in TaoIIOP Interface Babel stubs call pack on TaoIIOP Invocation object for every ‘in’ and ‘inout’ arguments, and then triggers the remote invocation TaoIIOP Invocation: Creates TAO argument list when pack is called Creates TaoIIOPInvocation adapter, which inherits from TAO Invocation Adapter • Invocation Adapter creates an instance of TaoIIOP_Operation_Details, which in turn creates the Input CDR and marshals all the input arguments • Makes the remote method invocation
Nanbor Wang and Roopa Pundaleeka Server-side Request Handling A default TAO servant handles all Babel invocations Need to extend TAO’s PortableServer class to expose the Input (for reading input parameters) and Output (to set the results) CDRs SIDL Call and Response objects get a reference to the Input and Output CDRs respectively Requests are demultiplexed to target Babel objects based on the instance/object ID
Nanbor Wang and Roopa Pundaleeka Server-side Request Handling in TAO TAO PortableServer gets the request from the client ORB TAO PortableServer dispatches the call to the appropriate skels • dispatch method has a reference to the TAO_ServerRequest object, which has the method signature, InputCDR and OutputCDR • The skeleton finds the implementation object and executes the call • Updates the TAO Arg List with the return values
Nanbor Wang and Roopa Pundaleeka Server-side Request Handling in TaoIIOP Interface • Default TAO object (TaoIIOPObject) extends TAO PortableServer::ServantBase, and implements the ‘dispatch’ method, which gets the Input and Output CDRs in ServerReq obj. • The dispatch method creates the sidl::rmi::Response, which stores the CDR • Gets a reference to the target SIDL object from the InstanceRegistry • Executes the target method • Pack methods are called on the response object for return, inout and out parameters • The results are directly packed into the CDR
Nanbor Wang and Roopa Pundaleeka New Development since last CCA Meeting Exception handling One-way method invocation Non-blocking/ Asynchronous Method Invocation (AMI)
Nanbor Wang and Roopa Pundaleeka Implementation of Exception Handling • TaoObject IDL interface defines a CORBA user exception called ServerException exception ServerException { string info; }; • The server side implementation throws CORBA exceptions, which are caught by the client side TaoIIOP interface and converted to taoiiop::rmi::GenNetworkException, which can be caught by the Babel clients. Example: catch (CORBA::Exception &ex) { taoiiop::rmi::GenNetworkException e = taoiiop::rmi::GenNetworkException::_create (); e.setNote (ex._info ().c_str ()); e.add (__FILE__, __LINE__, “method_name”); throw (e); }
Nanbor Wang and Roopa Pundaleeka Implementation of One-way Calls • It was a simple modification to the existing Two-way invocations • We had already extended TAO’s invocation adapter to invoke synchronous two-way method calls: • By default, the Invocation_Adapter makes a two-way call • Just changed the default to be one-way: // one-way call taoiiop::rmi::Invocation_Adapter _tao_call (taoiiop, _the_tao_operation_signature, arg_length, nameNid.c_str (), nameNid.length (), NULL, ::TAO::TAO_ONEWAY_INVOCATION);
Nanbor Wang and Roopa Pundaleeka Support for Non-blocking Calls in Babel • Babel generates interfaces for Polling model. Simple protocol implements Polling model • Each AMI operation returns a Poller object (sidl::rmi::Ticket) • When the client is ready to get the return values, it can use the poller to check the status of the request by polling or just decide to block until the reply is obtained from the server • Has special get/recv methods to obtain the results from the response object
Nanbor Wang and Roopa Pundaleeka Implementation of Non-blocking Calls in TAO • TAO implements the CORBA AMI Call-back Model • Client passes an object reference of a reply_dispatcher which has a callback method as a parameter, along with ‘in’ and ‘inout’ parameters • The stubs create an instance of TAO::Asynch_Invocation_Adapter, which stores the reply_dispatcher locally on the client ORB, and makes the remote call • When the server replies, the client ORB receives the response, and dispatches it to the appropriate callback operation on the reply_dispatcher provided by the client • TAO does not support polling model. No return values sent to the clients
Nanbor Wang and Roopa Pundaleeka Mapping Babel Non-blocking (Polling) to TAO AMI (Callback) • TaoIIOP extends TAO’s Asynch Invocation class to create a default Asynch_Reply_Dispatcher, which will be used for every AMI call • The TaoIIOP::rmi::Asynch_Invocation_Adapter stores the dispatcher in the client ORB to receive callback • When the reply arrives, the callback is invoked on the default reply dispatcher • The callback method stores the CDR object in the Response object to be used by the clients • Polling is not supported
Nanbor Wang and Roopa Pundaleeka Summary of CORBA protocol for Babel RMI • Tasks implemented: • Both client and server side interfaces • Interoperability with regular CORBA server • All basic types, complex numbers, strings, and arrays • Exception support • One-way and Non-blocking calls • Tasks to do: • Opaque and serializable support • Benchmark performance for comparing multiple protocols • Regression tests: some tests are in place, but need some work to be able to use them with both TaoIIOP and Simple protocols • Will package TaoIIOP and make it available on the web soon. Please email nanbor@txcorp.com or roopa@txcorp.com for more information
Nanbor Wang and Roopa Pundaleeka References • https://collaborate.txcorp.com/collaborate/distributed-technologies/distributed-components/distributed-components-home • A. Arulanthu, C. O’Ryan, D. Schmidt, M. Kircher and J. Parsons, “The Design and Performance of a Scalable ORB Architecture for CORBA Asynchronous Messaging” • A. Arulanthu, C. O’Ryan, D. Schmidt, M. Kircher and A. Gokhale, “Applying C++, Patterns and Components to Develop an IDL Compiler for CORBA AMI Callbacks”