2 Creating Coherence Applications for WebLogic Server
This chapter includes the following sections:
- Packaging Coherence Applications
 Coherence applications use a specific directory structure. You can deploy a Coherence application as a collection of files within this directory structure, known as exploded directory format, or as an archived file called a Grid ARchive (GAR) with a.garextension.
- Creating a Coherence Application Deployment Descriptor
 The presence of the deployment descriptor indicates a valid GAR. A GAR file must contain a Coherence application deployment descriptor (cohererence-application.xml) located in theMETA-INFdirectory.
- Using JNDI to Override Configuration
 Coherence provides the ability to override any XML element value in a configuration file using JNDI properties.
- Defining a Data Cache
 Data caches are defined in acoherence-cache-config.xmlfile that is packaged in a GAR file.
- Accessing a Data Cache
 Applications use the CoherenceNamedCacheAPI to interact with a Coherence cache.
- Using the Coherence API
 Coherence provides a full-featured API for interacting with a cache and for performing data grid operations.
- Using a Coherence Application Lifecycle Listener
 The Coherence Application Lifecycle listener allows custom processing to occur before and after the creation and destruction of Coherence caches and clustered services.
- Using Coherence for Session Management
 Web applications can chose to use Coherence for storing and replicating session state.
- Creating Extend Clients in WebLogic Server
 Client applications can chose to use Coherence*Extend to interact with Coherence caches without becoming members of a Coherence cluster.
- Using a JCache Cache in WebLogic Server
 Applications that are deployed to a managed Coherence container can use the JCache API and JCache provider that is implemented by Coherence.
Packaging Coherence Applications
Coherence applications use a specific directory structure. You can deploy a Coherence application as a collection of files within this directory structure, known as exploded directory format, or as an archived file called a Grid ARchive (GAR) with a .gar extension.
                  
A GAR module includes the artifacts that comprise a Coherence application. The /META-INF directory contains the deployment descriptor for the Coherence application (cohererence-application.xml). The presence of the deployment descriptor indicates a valid GAR. An additional subdirectory, the /lib directory, is used for storing dependency JAR files. Compiled Java classes that make up a Coherence application (entry processors, aggregators, filters, and so on) are placed in the root directory in the appropriate Java package structure.
                  
A GAR module can also contain a cache configuration file (coherence-cache-config.xml) and a Portable Object Format (POF) serialization configuration file (pof-config.xml). The location of these files is defined within the Coherence application deployment descriptor. Typically, the files are placed in the /META-INF directory; however, they can be located anywhere in the GAR relative to the root or even at a URL-accessible network location.
                  
Note:
- 
                           If the configuration files are not found at runtime, then the default configuration files that are included in the coherence.jar, which is located in the system classpath, are used.
- 
                           If the configuration files are located in the root directory of the GAR, then they must not use the default file names; otherwise, the configuration files that are included in the coherence.jarfile are found first and the configuration files in the GAR are never loaded.
The entire directory, once staged, is bundled into a GAR file using the jar command. GAR files are deployed as standalone archives to managed Coherence servers that are configured to store cached data.
                  
Client applications that rely on the caches and resources in a GAR module must be packaged within an EAR that includes the dependent GAR. An EAR cannot contain multiple GAR modules. Multiple GAR modules must be merged into a single GAR. That is, a GAR must contain one application deployment descriptor, one cache configuration file, and one POF configuration file.
- Directory Structure Example
- Packaging a Grid Archive In an Enterprise Application
- Creating a Coherence Project from a Maven Archetype
 You can create a new Coherence project using the Coherence Maven archetype.
Parent topic: Creating Coherence Applications for WebLogic Server
Directory Structure Example
The following is an example of a Coherence application directory structure, in which myCohApp/ is the staging directory:
                     
Example 2-1 Coherence Application Directory Structure
MyCohApp/
  lib/
  META-INF/
    coherence-application.xml
    coherence-cache-config.xml
    pof-config.xml
  com/myco/
    MyClass.class
Parent topic: Packaging Coherence Applications
Packaging a Grid Archive In an Enterprise Application
A GAR must be packaged in an EAR to be referenced by other JavaEE modules. See Developing Applications for Oracle WebLogic Server for details on creating an EAR. The following is an example of a Coherence application that is packaged within an EAR:
Example 2-2 Coherence Application Packaged in an EAR
MyEAR/
  META-INF/
    application.xml
    weblogic-application.xml
  MyWAR.war
  MyEJB.jar
  MyGAR.gar
Edit the META-INF/weblogic-application.xml descriptor and include a reference to the GAR using the <module> element. The reference is required so that the GAR is deployed when the EAR is deployed. For example:
                        
<?xml version="1.0"?>
<weblogic-application xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="http://xmlns.oracle.com/weblogic/weblogic-application
   http://xmlns.oracle.com/weblogic/weblogic-application/1.6/
   weblogic-application.xsd"
   xmlns="http://xmlns.oracle.com/weblogic/weblogic-application">
   <module>
      <name>MyGAR</name>
      <type>GAR</type>
      <path>MyGAR.gar</path>
   </module>
</weblogic-application>Parent topic: Packaging Coherence Applications
Creating a Coherence Project from a Maven Archetype
You can create a new Coherence project using the Coherence Maven archetype.
Parent topic: Packaging Coherence Applications
Creating a Coherence Application Deployment Descriptor
The presence of the deployment descriptor indicates a valid GAR. A GAR file must contain a Coherence application deployment descriptor (cohererence-application.xml) located in the META-INF directory.
                  
For a detailed reference of all the available elements in the descriptor, see coherence-application.xml Deployment Descriptor Elements. The following is an example of a Coherence deployment descriptor that declares a cache configuration file and a POF configuration file that is located in the META-INF directory of the GAR.
                  
<?xml version="1.0"?> <coherence-application xmlns="http://xmlns.oracle.com/coherence/coherence-application"> <cache-configuration-ref>META-INF/coherence-cache-config.xml </cache-configuration-ref> <pof-configuration-ref>META-INF/pof-config.xml</pof-configuration-ref> </coherence-application>
Parent topic: Creating Coherence Applications for WebLogic Server
Using JNDI to Override Configuration
Coherence provides the ability to override any XML element value in a configuration file using JNDI properties.
The use of JNDI properties allows a single version of a configuration file to be used for deployment and then altered as required at runtime.
To define a JNDI property, add an override-property attribute to an XML element with a value set to a JNDI context. The following example defines a JNDI property with a cache-config/MyGar context for the <cache-configuration-ref> element in a coherence-application.xml deployment descriptor. The JNDI property is used at runtime to override the cache configuration reference and specify a different cache configuration file. The JNDI context of cache-config is a well known context used and registered by a managed Coherence server.
                  
<?xml version="1.0"?>
<coherence-application
   xmlns="http://xmlns.oracle.com/coherence/coherence-application">
   <cache-configuration-ref override-property="cache-config/MyGar">
      META-INF/coherence-cache-config.xml</cache-configuration-ref>
   <pof-configuration-ref>META-INF/pof-config.xml</pof-configuration-ref>
</coherence-application>
Parent topic: Creating Coherence Applications for WebLogic Server
Defining a Data Cache
coherence-cache-config.xml file that is packaged in a GAR file.See Developing Applications with Oracle Coherence for details on Coherence caches and their configuration.
The following example creates a distributed cache named myCache. As
         an alternative, a cache mapping may be defined with the asterisk (*)
         wildcard, which allows an application to use the distributed cache by specifying any
         name.
                  
<?xml version="1.0" encoding="windows-1252"?>
<cache-config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xmlns="http://xmlns.oracle.com/coherence/coherence-cache-config"
   xsi:schemaLocation="http://xmlns.oracle.com/coherence/coherence-cache-config
   coherence-cache-config.xsd">
 
   <caching-scheme-mapping>
      <cache-mapping>
         <cache-name>myCache</cache-name>
         <scheme-name>distributed</scheme-name>
      </cache-mapping>
   </caching-scheme-mapping>
   
   <caching-schemes>
      <distributed-scheme>
         <scheme-name>distributed</scheme-name>
         <service-name>DistributedService</service-name>
         <backing-map-scheme>
           <local-scheme/>
         </backing-map-scheme>
         <autostart>true</autostart>
      </distributed-scheme>
   </caching-schemes>
</cache-config>Coherence does not support the use of a replicated cache scheme if a GAR module is used in multiple EAR modules (packaged either individually or as a shared GAR) on a managed Coherence server. Additionally, the replicated cache type is deprecated. View, Near, or Distributed/Partitioned Cache types should be used instead. The read and write performance and memory usage characteristics described in Table 12-1 Summary of Cache Types and Characteristics can be used to determine which cache type to use.
Parent topic: Creating Coherence Applications for WebLogic Server
Accessing a Data Cache
NamedCache API to interact with a Coherence cache.The Coherence cache holds resources that are shared among members of a Coherence cluster. An application can obtain a NamedCache object either by dependency injection or by using a JNDI lookup.
                  
To Obtain a Cache by Dependency Injection
An @Resource annotation can be used in a servlet or an EJB to dynamically inject the NamedCache. This annotation cannot be used in a JSP. The name of the cache used in the annotation must be defined in the application's coherence-cache-config.xml file.
                     
Example 2-3 illustrates using dependency injection to get a cache named myCache. See Developing Applications for Oracle WebLogic Server for details on JavaEE annotations and dependency injection.
                     
Example 2-3 Obtaining a Cache Resource by Dependency Injection
... @Resource(mappedName="MyCache") com.tangosol.net.NamedCache nc; ...
To Obtain the NamedCache by JNDI Lookup
A component-scoped JNDI tree can be used in EJBs, servlets, or JSPs to get a NamedCache reference. 
                     
To use a JNDI lookup, define a resource-ref of type com.tangosol.net.NamedCache in either the web.xml or ejb-jar.xml file. Example 2-4 illustrates a <resource-ref> element that identifies myCache as the NamedCache. See Developing JNDI Applications for Oracle WebLogic Server for details on using JNDI in Oracle WebLogic Server.
                     
Note:
The <res-auth> and <res-sharing-scope> elements do not appear in the example. The <res-auth> element is ignored because currently no resource sign-on is performed to access data caches. The <res-sharing-scope> element is ignored because data caches are sharable by default and this behavior cannot be overridden.
                        
Example 2-4 Defining a NamedCache as resource-ref for JNDI Lookup
... <resource-ref> <res-ref-name>coherence/myCache</res-ref-name> <res-type>com.tangosol.net.NamedCache</res-type> <mapped-name>MyCache</mapped-name> </resource-ref> ...
The following example performs a JNDI lookup to get a NamedCache reference that is defined in Example 2-4:
                     
try {
   Context ctx = new InitialContext();
   cache = (NamedCache) ctx.lookup("java:comp/env/coherence/myCache");
   cache.put(key, value);
}
catch (NamingException ne)
Parent topic: Creating Coherence Applications for WebLogic Server
Using the Coherence API
Some of the features of the Coherence API include:
- 
                        basic get,put, andputAlloperations
- 
                        querying a cache 
- 
                        processing data in a cache using entry processors and aggregators 
- 
                        event notifications 
See Developing Applications with Oracle Coherence for details on using the API to develop applications. See Java API Reference for Oracle Coherence for a reference of the Coherence API.
Using POF for Serialization
Objects that are placed in a cache must be serializable. The Portable Object Format (also referred to as POF) is a language agnostic binary format. POF is designed to be efficient in both space and time and is the recommended serialization option in Coherence. See Developing Applications with Oracle Coherence for details on using POF in your applications.
Parent topic: Creating Coherence Applications for WebLogic Server
Using a Coherence Application Lifecycle Listener
The Coherence Application Lifecycle listener allows custom processing to occur before and after the creation and destruction of Coherence caches and clustered services.
Coherence applications support the use of an application lifecycle listener. The
         listener class must implement the
            com.tangosol.application.LifecycleListener interface. See the Java API Reference for Oracle
            Coherence for details on the interface. 
                  
Override the following methods provided in the LifecycleListener interface and add any required functionality:
                  
- 
                        preStart(Context)– called before the application is activated
- 
                        postStart(Context)– called after the application is started
- 
                        preStop(Context)– called before the application stops its services
- 
                        postStop(Context)– called after the application is stopped
To use an application lifecycle listener class, declare the fully qualified name of the class within the <application-lifecycle-listener> element in the coherence-application.xml deployment descriptor and include the class in the /lib directory of the GAR. The following is an example of declaring an application lifecycle listener class that is named MyAppLifecycleListener. 
                  
<?xml version="1.0"?> <coherence-application xmlns="http://xmlns.oracle.com/coherence/coherence-application"> <cache-configuration-ref>META-INF/coherence-cache-config.xml </cache-configuration-ref> <pof-configuration-ref>META-INF/pof-config.xml</pof-configuration-ref> <application-lifecycle-listener><class-name>package.MyAppLifecycleListener</class-name> </application-lifecycle-listener> </coherence-application>
Parent topic: Creating Coherence Applications for WebLogic Server
Using Coherence for Session Management
The session management features of Coherence are implemented by the Coherence*Web component. See Administering HTTP Session Management with Oracle Coherence*Web for details on setting up, configuring, and using Coherence*Web in WebLogic Server.
Parent topic: Creating Coherence Applications for WebLogic Server
Creating Extend Clients in WebLogic Server
Client applications connect to managed Coherence proxy servers and are unaware that cache and invocation service requests are being executed remotely. Remote clients may be deployed within a WebLogic Server domain or may be external to WebLogic Server. See Administering Clusters for Oracle WebLogic Server for details on setting up a Coherence proxy server tier in WebLogic Server to allow remote connections. See Developing Remote Clients for Oracle Coherence in for details on creating Coherence*Extend client applications.
Parent topic: Creating Coherence Applications for WebLogic Server
Using a JCache Cache in WebLogic Server
See Developing Applications with Oracle Coherence for details on using JCache with Coherence.
Parent topic: Creating Coherence Applications for WebLogic Server
