Complete OMG CORBA Implementation |
|
Full support for CORBA 2.3 specifications |
|
Portable Object Adapter (POA), which provides for sophisticated management of server object lifetimes, and allows server source code portability across ORB products |
|
Objects By Value (OBV), for passing of arbitrary complex objects and graphs of objects by value across processes, machines, and languages |
|
Valuetypes, the OMG-specified mechanism for encoding and passing objects by value which allows interoperability of OBV across ORB products |
|
RMI over IIOP and the Java-to-IDL reverse mapping allows Java developers to write CORBA applications without having to learn IDL and other CORBA features, and allows existing RMI applications to be migrated to VisiBroker’s high-performance CORBA runtime. |
|
A very high-performance robust implementation of IIOP, which has become the de-facto industry standard IIOP protocol implementation against which other IIOP implementations are judged |
|
GIOP 1.2 for enhanced interoperability. Fragmentation for enhanced performance by enabling large requests to be interleaved seamlessly with smaller ones. |
|
Quality of Service (QoS) APIs, for configuring or modifying the behavior of the ORB runtime & services, to allow developers to make engineering trade-offs |
|
ORB Property Management, a uniform scheme for managing the numerous configurable aspects of VisiBroker |
|
Support for Multi-homed Hosts, to allow effortless deployment of VisiBroker applications on machines with multiple network cards, such as firewall machines, or high-end servers |
|
Interface Repository (IR) for storing descriptions of CORBA Object Interfaces, and other Type information for runtime discovery by clients |
|
Implementation Repository and the Object Activation Daemon (oad), which allows the activation of both CORBA objects and servers on demand, according to multiple configuration policies |
|
OMG standard IDL-to-Java mapping, crucial for source portability of your Java-CORBA applications across ORB products |
|
OMG standard IDL-to-C++ mapping, crucial for source portability of your C++-CORBA applications across ORB products |
|
idl2java compiler, for implementing IDL interfaces in Java, and invoking CORBA objects with IDL interfaces, from Java. |
|
idl2cpp compiler, for implementing IDL interfaces in C++, and invoking CORBA objects with IDL interfaces, from C++. |
|
java2idl compiler for creating IDL from Java code, thereby, allowing you to re-implement Java objects in another language. |
|
java2iiop compiler for creating IIOP-compliant stubs and skeletons directly from Java interfaces, which eliminates the need to learn & write IDL |
|
Support for both Inheritance and Delegation (TIE) mechanisms, to allow developers flexibility in designing server object models and hierarchies |
|
Portable stubs and skeletons, to allow developers to substitute a different ORB runtime into an application developed with VisiBroker |
|
Seamless propagation of System Exceptions and User Exceptions across machines, operating systems, and languages |
|
Integration with industry-standard naming and directory services via support for the CORBA Naming Service, and LDAP |
|
A smart ORB runtime that chooses most efficient marshalling and communication strategy as appropriate |
|
Hooks (Object Wrappers, Interceptors) provided for low-level customization and hand-coding of networking parameters, location algorithms, marshalling algorithms, etc. |
|
Support for static, dynamic, synchronous and asynchronous invocations |
|
Support for various levels of logging for Java applications, for debugging and management |
|
VisiBroker for Java |
|
Implemented in 100% Pure Java, to make CORBA available wherever Java is available |
|
Ability to automatically download the required ORB classes to a thin client, allows Java-CORBA applets to be written and deployed without having to install anything else on thin clients |
|
VisiBroker for C++ |
|
ANSI C++ compliant interfaces for maximum source portability |
|
Support for code generation using either namespaces or nested classes to allow developers maximum flexibility in their use of these C++ features |
|
Uses native operating system threads internally and provides the same threading models to developers on all platforms |
|
Single-threaded model available, in addition to Thread-per-session and Thread-per-request with Thread Pool. |
|
Single-threaded library also available for applications that are known to be single-threaded and wish to avoid the overhead of locking and synchronization primitives |
|
Same-machine Optimizations during method invocations, to boost performance for targets that are on the local machine (e.g., optionally using NT shared memory on NT, or Unix domain sockets on Unix) |
|
Configurable send/receive/connect timeouts for user-configurable fault-tolerance |
|
Uses portable abstraction layers, to ease porting to multiple platforms, by Inprise, OEMs, and ISVs |
|
IDL to Java & IDL to C++ Compilers |
|
Allow building of CORBA 2.3 compliant servers and clients with full Valuetypes support |
|
Support for generation of POA interfaces on server side, to allow server programmers to code to new POA APIs |
|
Support for generation of older BOA interfaces
on server side, with the
-boa compiler option, to ease migration of BOA-based code |
|
Accurate and verbose error messages for fast development |
|
Fast IDL compilation (order of magnitude faster than previous versions) |
|
Ability to also compile generated Java stubs and skeletons during the IDL compilation process |
|
Both idl2java and idl2cpp are implemented completely in Java |
|
RMI over IIOP |
|
Supports the CORBA 2.3 Java-to-IDL Mapping |
|
Supports RMI interfaces for client interfaces and server implementations |
|
Pure Java 2 implementation (no native code) |
|
Backwards Compatibility and Interoperability |
|
BOA APIs preserved, and now layered atop the new POA APIs, to provide source code compatibility for VisiBroker 3.x applications |
|
Runtime Interoperability between VisiBroker for Java 4.x and VisiBroker for C++ 4.x |
|
Runtime Interoperability between VisiBroker 4.x and VisiBroker 3.3 and later |
|
Support for General Inter-ORB Protocol (GIOP) versions 1.0, 1.1, and 1.2, with 1.2 being the default, and automatic fallback to previous versions based on peer capabilities |
|
SmartAgent (OSAgent Daemon) |
|
A VisiBroker value-add that provides a dynamic distributed naming & directory service with support for fault-tolerance and load-balancing |
|
Ability to be used both as a lightweight naming service by itself and/or as bootstrapping for automatically discovering CORBA services such as the CORBA Naming Service |
|
Simplified API that eliminates the complexity of discovering objects |
|
Support for automatic discovery of the nearest Smart Agent by VisiBroker server processes |
|
Support for automatic discovery of the nearest Smart Agent by VisiBroker client processes |
|
Ability for Smart Agents to discover other Smart Agents in the network |
|
Ability to control whether and when UDP broadcasts are used to automatically discover Smart Agents |
|
Support for networks of Smart Agents to span subnets |
|
High Availability & Fault Tolerance, to allow a CORBA client using an object A on machine M to transparently fail over to using a replica, object B on machine N, without requiring any coding by the application programmer |
|
Round-robin load balancing built-in |
|
ORB hooks (bind interceptors) and programming examples for adding other load-balancing algorithms |
|
Support for standard CORBA object migration, which allows clients to automatically discover that an object has moved from machine M to machine N, without requiring special coding by the application programmer |
|
Support for the use of Smart Agents in Internet or other Wide Area Network (WAN) scenarios when used in conjunction with the GateKeeper |
|
Ability for an administrator to turn off the failover feature for a client, but leave other Smart Agent related behaviors intact |
|
Ability to disable and completely remove the Smart Agent from your deployed application. (The Smart Agent can be intelligently leveraged by all other parts of VisiBroker, but is not required to be present). |
|
Ability to create multiple parallel “virtual domains” of CORBA clients, objects, and servers on the same set of machines (e.g., development vs. QA), by using different Smart Agent port numbers |
|
Location Service, an IDL-based interface which can be used to discover the information contained in a network of distributed Smart Agents, such as the location of all the agents, and the types, names, and location of all objects known to the Smart Agent(s) |
|
Server-Per-Method Policy: A server process is started for each method that is invoked. |
|
Ability to run as an NT Service |
|
Object Activation Daemon (OAD) |
|
Automatically launches servers when needed by clients |
|
Shared-Server Policy: The OAD only activates one server implementation which is shared by multiple clients. |
|
Unshared-Server Policy: Only one client of a given implementation will be bound to the activated server. Separate servers are activated for each additional client. |
|
Support for automatic starting of both POA and BOA based servers |
|
Both command-line and programmatic interfaces available for administering the OAD |
|
Ability to run as an NT Service |
|
Interface Repository (IR) |
|
Full support for new CORBA 2.3 Interface Repository interfaces |
|
Ability to run as a daemon for interaction-free operation |
|
Ability to selectively populate the Interface Repository |
|
Ability to incrementally populate the Interface Repository |
|
Ability to be started up on demand |
|
Ability to run multiple replicas of the Interface Repository, and load balance across them |
|
Ability to fail-over from one Interface Repository to another |
|
Ability to run as an NT Service |
|
Portable Object Adaptor (POA) |
|
Full support for CORBA 2.3 specification |
|
Backward compatibility for VisiBroker 3.x applications with a BOA based on POA |
|
Support for all specified POA policies, such as Thread policy, Lifespan policy, Object ID Uniqueness policy, ID Assignment policy, Servant Retention policy, Request Processing policy, Implicit Activation policy, etc. |
|
Support additional VisiBroker-specific policies, such as Bind Support policy |
|
ServantLocators and ServantActivators allow fine-grained control over how objects are activated and deactivated |
|
Servant Timeouts, to automatically deactivate objects that are idle |
|
Ability for user to create multiple IOR profiles, so that the same object might be accessed in different ways by different clients (e.g., over SSL or not) |
|
Ability for user to create multiple agent registration policies to control which objects get published to the Smart Agent |
|
Ability to programmatically specify which transport layer to use, on a per-POA basis |
|
Objects By Value (OBV) |
|
OMG-specified extension of the basic CORBA type system, to include Valuetypes (local programming objects) , and pass them by value as parameters to requests. |
|
Dynamic Invocations and Data Types |
|
Client-side Dynamic Invocation Interface (DII) to enable clients to dynamically build operation requests for any object interface that is stored in the Interface Repository. Allows you to write clients such as object browsers, administration tools, testing tools, or very dynamic end-user applications that must operate on an unlimited range of object types that cannot be known in advance by the client |
|
Server-side Dynamic Server Invocation (DSI) to enable servers to dynamically create object implementations at runtime based on client requests, or to allow them to arrange custom handling of requests (such as forwarding to another server) without compile-time knowledge of the types involved in each request |
|
Robust support for CORBA Any and Dynamic Any (DynAny) types, for building powerful client and server applications that can create and interpret arbitrary complex data types at runtime |
|
Interceptors |
|
Interceptors allow advanced application programmers to add custom code to the ORB runtime, which is executed during object creation and destruction, method invocation, etc. |
|
InterceptorManager APIs for managing the registration of interceptors |
|
Service Initializers allow Interceptors to be dynamically loaded into client and server processes, in both VisiBroker for Java and VisiBroker for C++, without changing or even recompiling client or server code |
|
Debugging interceptors that allow breakpoints to be set in remote servers from a central console |
|
Logging interceptors provided as programming examples |
|
Client-Side Interceptors: |
|
-- BindInterceptors for inserting user code before and after binds, which allows users to customize object lookup algorithms, naming service fail-over strategies, load balancing algorithms, etc. |
|
-- ClientRequestInterceptors for inserting user code at various points during a request marshalling and invocation, which in combination with ServerRequestInterceptors allow users to perform custom transformations of requests and responses, such as encryption/decryption, compression/decompression, adding/removing parameters, propagating application contexts, etc., all without changing remote interfaces and client and server application code. |
|
Server-Side Interceptors: |
|
-- POALifeCycleInterceptor for inserting user code at POA creation/destruction |
|
-- ActiveObjectLifeCycleInterceptor for inserting user code at Object activation /deactivation |
|
-- IORCreationInterceptor for manipulating a newly created IOR. |
|
-- ServerRequestInterceptor for inserting code at various points during a request execution and reply marshalling… see ClientRequestInterceptors above. |
|
Object Wrappers |
|
Object wrappers enable you to define methods that are invoked when a client application invokes a method on a bound object or when a server application receives a operation request. Unlike interceptors, which are invoked at the ORB level, object wrappers are invoked before an operation request has been marshaled. |
|
Typed-Object-Wrappers to mimic the interface of the object that is being wrapped |
|
Untyped Object Wrappers to provide the same generic interface to intercept invocations to the object(s) being wrapped |
|
Service Initializers allow Object Wrappers to be dynamically loaded into client and server processes, in both VisiBroker for Java and VisiBroker for C++, without changing or even recompiling client or server code |
|
VisiBroker Event Service |
|
Complete Implementation of the CORBA Event Service specification |
|
Support for creation of multiple event channels, in the same event channel server process, or in multiple processes on multiple machines |
|
Support for instantiating event channels in their own server, or in a client or server of your own |
|
Ability to customize how events are handled (e.g., persistence) using interceptors and object wrappers |
|
Support for Push Suppliers, which allows the writing of proactive suppliers, which actively push events into an event channel |
|
Support for Pull Suppliers, which allows the writing of passive suppliers, which register with an event channel but provide events to the channel only when the channel requests them |
|
Support for Push Consumers, which allows the writing of passive consumers, which register with an event channel and are delivered events as soon as they’re pushed into the channel |
|
Support for Pull Consumers, which allows the writing of active consumers, which proactively pull events from an event channel and can block for events to become available |
|
VisiBroker Naming Service |
|
Support for OMG-standard CORBA Naming Service APIs |
|
Support for the Interoperable Naming Service (INS) Specification, which allows the VisiBroker Naming Service to be integrated into any CORBA application with ease |
|
Support for JNDI APIs, using the CosNaming Provider for JNDI from Sun, to allow RMI- or EJB-style clients to look up objects in the same naming services being used by CORBA clients & servers |
|
Support for using an industry standard LDAP server as your directory service (see Pluggable Storage, below), and inherit enterprise-level scalability, replication, and fault-tolerance offered by commercial LDAP servers, such as the Netscape Directory Server |
|
Multiple naming servers can be started for the same naming data store for replication, performance and scalability |
|
URL Naming |
|
Allows the use of any web server as a naming server, so that a highend naming service need not be deployed for small web-based applications |
|
Servers can associate URLs with CORBA object references, instead of or in addition to publishing the object reference in other naming services |
|
Clients can look up CORBA object references using URLs instead of using more complicated naming service APIs |
|
Allows the use of web server’s access control features to control access to a URL Naming hierarchy |
|
VisiBroker for C++ clients and servers can also use URL Naming by using any HTTP Client libraries |
|
Pluggable Storage in the VisiBroker Naming Service |
|
Several different kinds of storage can be “plugged in” underneath the Naming Service |
|
In-Memory Storage, to be used when it is reasonable to keep all naming data in memory, and does not need to be persistent |
|
JNDI Storage, to allow naming data to be written to any directory service for which there exists a JNDI provider, e.g., LDAP, NDS, Active Directory, etc. |
|
JDBC Storage to allow naming data to be written to any database for which there exists a JDBC driver, e.g., Oracle, Sybase, MS SQL Server, DB2, JDataStore, InterBase |
|
Optimized JDBC Adaptor with caching facility, to bring the performance of using a JDBC data store for naming data, close to the performance of using an In-Memory storage. |
|
DataExpress Adaptor, for fast access to the Inprise’s JDataStore |
|
Federation in the VisiBroker Naming Service |
|
Support for federation, to allow multiple naming servers to be deployed, with naming hierarchies spanning multiple servers, which can increase performance and scalability, and allow decentralized administration |
|
Command-line options for federation of naming servers, for easily federating multiple naming servers |
|
Clustering in the VisiBroker Naming Service |
|
Ability to associate a single object name with multiple object references, which allows the Naming Service to load-balance over the set, when a client attempts to look up that name |
|
Requires no changes to client code performing lookups of object references |
|
Multiple clusters can be created in the Naming Service, to allow multiple unrelated services to use the clustering feature |
|
Criterion for load-balancing is specified for each cluster, to allow different clusters to use different load-balancing criteria |
|
APIs to create clusters, and add, remove and iterate through their members, for complete programmatic control over clusters |
|
APIs to retrieve all the clusters that exist in the Naming Service, to allow clients, servers and admin tools to determine which service clusters exist |
|
Load-Balancing in the VisiBroker Naming Service |
|
Dynamic Load-Balancing is performed automatically, both by the Smart Agent (see Smart Agent) and by the VisiBroker CORBA Naming Service |
|
Customizable Load-Balancing Algorithms, can be plugged into the Naming Service using the Criterion Manager APIs |
|
Load balancing at the CORBA object level can be combined with load balancing at the DNS, web server, or servlet engine level |
|
Fault-Tolerance and Fail-Over in the VisiBroker Naming Service |
|
Failover of the Naming Service, avoids a single point of failure at the Naming Service by allowing administrators to identify master and slave naming servers |
|
Transparent failover by clients from a failed master Naming Server to a slave Naming Server, with no special coding required by application programmer, to avoid single point of failure at the Naming Service |
|
Transparent failover by clients from a failed member of cluster to another member of that cluster, with no special coding required by the application programmer, to tolerate a failure in the server object |
|
Built-in Scalability |
|
Ability to replicate objects in multiple processes on multiple machines |
|
Server-side support for multi-threading to allow servers to serve multiple clients simultaneously and make maximum use of available resources |
|
Client-side support for multi-threading to allow multiple threads in a client process to make simultaneous invocations to the same server, using a single connection, without blocking or deadlocking |
|
Thread Pooling built-in, to manage server resources in a scalable fashion |
|
Connection Pooling built-in, to manage TCP/IP connections in a scaleable fashion |
|
Same-process Optimizations during method invocations, to boost performance for targets that are in the local process (e.g., substituting remote object references with local pointers/references) |
|
Server-Threading Models |
|
Thread-Per-Session: One server-side thread is spawned per client connection – regardless of the number of object instances accessed by the client within the server. |
|
Thread-Per-Request with Thread-Pool: A dynamically-sized pool of threads is available to handle client requests. Upon request completion, the thread returns to the pool for the next client request. |
|
Ability to specify minimum and maximum number of threads per server process, to bound resource consumption |
|
Automatic growth of thread pool from minimum size to maximum size as the load on the server increases |
|
Thread idle-timeouts for automatic shrinking of the thread pool to minimum size as load on the server decreases |
|
Pluggable threading models to allow OEM customers to add custom threading models |
|
Connection Management |
|
Connection Management enables Servers to recycle existing connections for maximum performance, scalability, and throughput. |
|
Ability for a server programmer or administrator to specify the maximum number of client connections that can be open at any point in time |
|
Ability for a client programmer or administrator to specify the maximum number of server connections that can be open at any point in time |
|
Connection idle-timeouts to allow clients and servers to shut down TCP/IP connections that are not being used |
|
Connection recycling, in which the server-side ORB runtime automatically shuts down the Least Recently Used connection to allow a new client to connect to the server, without exceeding the maximum number of allowed connections |
|
Automatic reestablishment of a previously-terminated connection between a client and a server when it is needed again, without disrupting the client-server session |
|
Pluggable transport layers to allow OEM customers to add custom transport layers |
|
Pluggable connection management models to allow OEM customers to add custom connection management algorithms |
|
VisiBroker GateKeeper |
|
The GateKeeper is a high-performance IIOP Proxy based on CORBA Firewall specifications |
|
Configurable stateless/stateful connection management for flexibility in managing server resources |
|
Support for deploying GateKeeper functionality as a Servlet, which allows GateKeeper functionality to be tightly integrated with your enterprise web server or servlet engine, and simplified administration and management |
|
Ability to handle asynchronous IIOP in addition to synchronous IIOP |
|
Clustering, to allow transparently load balance across multiple GateKeepers |
|
Fault tolerance, to allow defining master and slave GateKeepers and transparently fail-over across them |
|
Support for all popular firewall products and configurations, from simple dual-homed machines and software based firewalls, to sophisticated configurations with multiple levels of routers, demilitarized zones (DMZs) and bastion hosts |
|
Support for Network Address Translation (NAT) devices, which substitute one IP address for another for security purposes, and cause havoc in other ORBs |
|
Support for Dual-Homed Gateway machines which are often used to run software-based firewalls |
|
GateKeeper Chaining, useful not only for navigating multiple levels of firewalls but also for concentrating connections from large numbers of clients |
|
Support for HTTP Proxy Servers, which allows clients behind proxy servers to interact with the GateKeeper without problems |
|
Support for SOCKS, which allows Java clients running behind SOCKS proxy servers to make IIOP invocations |
|
Support for HTTP Tunneling, which allows clients to tunnel IIOP over HTTP, to ease deployment |
|
Seamless integration with web servers and servlet engines |
|
Applet Support: |
|
-- Lightweight HTTP server built-in, for serving applets or serving HTML on small-scale |
|
-- Support for making IIOP callback to applets, in the presence of firewalls |
|
-- Support for forwarding an Applet’s requests for communication with a Smart Agent, to the Smart Agent network on the server-side, to avoid UDP communication on the Internet and WANs |
|
Visual Administration Tools |
|
Visual GUI tools for simplified administration |
|
Visual control of servers and their properties using the VisiBroker Console |
|
Discover and browse all running Smart Agents and their hosts |
|
Discover and browse the names and types of all CORBA objects known to all Smart Agents |
|
Discover all running Implementation Repositories and browse their contents |
|
Discover all running Interface Repositories and browse their contents |
|
Discover all running Naming Services and browse their contents |
|
Support for browsing & editing any naming service supporting JNDI |
|
Discover all running GateKeepers and configure their properties |
|
ORB Property Management |
|
Ability to configure all ORB properties using a uniform naming convention via the command line |
|
Ability to configure all ORB properties using a uniform naming convention via a centralized properties file |
|
Ability to configure all ORB properties using a uniform naming convention via programmatic APIs |
|
ServerManager Interface |
|
Ability to communicate directly with the ORB runtime of a running VisiBroker client or server, and configure various ORB properties without shutting down the client or server, in 24x7 situations |
|
Quality of Service (QoS) |
|
Full support for policy management and QoS in the runtime |
|
Support for additional VisiBroker-specific policies |
|
Platform Availability |
|
Microsoft Windows |
|
Sun Solaris |
|
Redhat Linux |
|
HP-UX |
|
IBM AIX |
|
IBM OS/390 Mainframe |
|
Separately Available Options for VisiBroker 4
Complete range of CORBA Services (from Prism Technologies) |
|
|
|
OpenFusion Trading Service |
|
||
OpenFusion Notification Service |
|
||
OpenFusion LifeCycle Service |
|
||
OpenFusion Property Service |
|
||
OpenFusion Collection Service |
|
||
OpenFusion Concurrency Service |
|
||
OpenFusion Relationship Service |
|
||
OpenFusion Time Service |
|
||
Secure GateKeeper (requires Inprise Security Service) |
|
|
|
Support for IIOP-over-SSL, which layers IIOP traffic over SSL, thus automatically encrypting all CORBA traffic between a given client and server, without requiring coding changes |
|
||
Support for choosing IIOP-over-SLL or unencrypted IIOP, from the GateKeeper to each server, on a server-by-server basis |
|
||
Support for HTTPS Tunneling, which allows thin clients to tunnel IIOP over HTTPS – by taking advantage of the HTTPS implementation already available in all popular web browsers, this feature makes possible secure CORBA clients with zero-installation and dramatically eases deployment of secure CORBA applications |
|
||
Supports IIOP/SSL Callbacks, to allow servers to make secure CORBA invocations to clients |
|
||
Credential Forwarding, the ability to forward client credentials to servers, so that servers can authenticate clients themselves |
|
||
Authentication of clients on behalf of servers to allow the GateKeeper to immediately reject intruders |
|