Using ActiveCache, applications can easily access Coherence data caches. ActiveCache provides a @Resource
annotation that allows a Coherence NamedCache
cache object to be identified and dynamically injected into a servlet or EJB. As an alternative to resource injection, applications using ActiveCache can use a component-based JNDI tree to look up the NamedCache
.
Developing Applications to Use ActiveCache: Main Steps
The following steps summarize the procedure for using ActiveCache with applications running on WebLogic Server.
-
Choose the cluster topology on which your applications will run. See Choose the ActiveCache Deployment Topology.
-
Specify the configuration for the Coherence caches that your applications will use. See Create and Configure a Data Cache.
-
Add code in your Web application to access the Coherence caches. You can use either JNDI lookup or resource injection to access a Coherence
NamedCache
cache object. See Access the Data Cache from your Application. -
Store the cache configuration file with the application. Where you store the file depends on how you want the caches to be visible to the deployed applications. See Locate the Cache Configuration File.
-
Determine how the server will access the cache configuration file when it starts. See Access the Cache Configuration on Server Startup.
-
Coherence clusters are classloader-scoped. Where you deploy
coherence.jar
in the classloader hierarchy determines how cluster membership is handled. See Package Applications and Configure Coherence Cluster Scope. -
Adjust preconfigured cluster values for your deployed applications, if necessary. You can use WLST or the WebLogic Server Administration Console to configure some cluster-related values. See Create and Configure Coherence Clusters.
-
Start the stand-alone Coherence cache servers. See Start a Cache Server.
-
Use one of the several methods to start WebLogic Server. See Start WebLogic Server.
-
Monitor the run-time status of Coherence clusters from the WebLogic Server Administration Console. See Monitor Coherence Cluster Properties.
Choose the ActiveCache Deployment Topology
Clusters are used to harness multiple computers to store and manage data, resources, and services, usually for reliability and scalability purposes. Coherence clusters store and manage an application's objects and data. All of the data that is inserted into Coherence data caches is accessible by all the servers in the application's Coherence cluster that share the same cache configuration.
ActiveCache can be employed for several different combinations of application and data tiers, or cluster topologies. Different cluster topologies can be formed by mixing WebLogic Server instances and stand-alone Coherence cache servers, here defined as Coherence data servers running on JVM instances dedicated to maintaining data.
-
In the In-Process topology, all WebLogic Server instances (employing ActiveCache) in the cluster are storage-enabled. In this case, storage-enabled means that these servers will provide cache storage and back-up storage; you do not have to create a separate data tier. The applications and the data caches are collocated; each server instance can serve requests and cache data.
This topology is supported mainly for development and testing. By storing the session data in-process with the application server, this topology is very easy to get up and running quickly for development and testing. This topology is not recommended for production use.
-
In the Out-of-Process topology, you use stand-alone Coherence cache servers to host the data. Configure the WebLogic Server instances to be storage-disabled; they are used to serve requests. This topology creates a true, separate data tier, and further reduces overhead for the WebLogic Server instances that are processing requests.
-
The WebLogic Out-Of-Process topology is a slight variation on the Out-of-Process topology. In this topology, storage-enabled WebLogic Server instances replace the stand-alone Coherence cache servers. You have a mixture of storage-enabled and storage-disabled WebLogic Server instances. In this topology requests and data are also segregated to their own servers; thus, latency for processing requests is reduced.
Note:
For more information on the In-Process and Out-of-Process deployment topologies, see Deployment Topologies in the User's Guide for Oracle Coherence*Web.Create and Configure a Data Cache
ActiveCache can be configured to use any of the cache types supported by Oracle Coherence. For an in-depth discussion on Coherence caches and their configuration, see Create and Use Coherence Caches in the Developer's Guide for Oracle Coherence.
Access the Data Cache from your Application
Applications that run on WebLogic Server 10.3.3 or later, can use ActiveCache to access a data cache. The data cache is represented by the Coherence NamedCache
cache object. This object is designed to hold resources that are shared among members of a Coherence cluster. These resources are managed in memory, and are typically composed of data that is also stored persistently in a database, or data that has been assembled or calculated. Thus, these resources are referred to as cached.
Your application can obtain a NamedCache
either by resource injection or by lookup in a component-scoped JNDI resource tree. The lookup technique can be used in EJBs, servlets, or JSPs. The resource injection technique can be used only by servlets or EJBs.
Note:
It is not recommended that you store remote EJB references in Coherence named caches, nor should you store them in Coherence*Web-backed HTTP sessions.To Obtain the NamedCache by Resource Injection
A @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 Coherence cache configuration file, coherence-cache-config.xml
.
Example 3-1 illustrates a resource injection of the NamedCache
myCache
.
Example 3-1 Obtaining a NamedCache by Resource 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 reference the NamedCache
.
To use a component-scoped JNDI lookup, define a resource-ref
of type com.tangosol.net.NamedCache
in either the web.xml
or ejb-jar.xml
file. Example 3-2 illustrates a <resource-ref>
stanza that identifies myCache
as the NamedCache
.
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.Locate the Cache Configuration File
The location where you store the cache configuration file determines the cache scope; that is, the visibility of the caches to deployed applications. The cache scope defines a Coherence node. A Coherence node can be a single server process (WebLogic Server instance (running Coherence) or stand-alone Coherence cache server), WebLogic Server application (EAR), or application module (Web application). There can be many data caches within a single Coherence node.
There are three options for cache visibility:
-
Application server-scoped—all deployed applications in a container become part of one Coherence node. Caches will be visible globally to all applications deployed on the server.
-
EAR-scoped—all deployed applications within each EAR become part of one Coherence node. Caches will be visible to all modules in the EAR. For example, this could be a recommended deployment if all of the modules must share the same cache.
-
WAR-scoped—each deployed Web application becomes its own Coherence node. Caches will be visible to the individual modules only. For example, this could be a recommended deployment for a stand-alone WAR deployment or stand-alone EJB deployment.
Note:
The cache configuration must be consistent for both WebLogic Server instances and stand-alone Coherence cache servers.Table 3-1 Cache Configuration File Location Based on Cache Scoping
For this cache scoping... | Store the cache configuration file in... | Comments |
---|---|---|
Application server-scope |
|
For more information, see "Access the Cache Configuration on Server Startup". |
Application-scoped cache for an EAR file |
|
Caches defined in Caches defined at the EAR level will be visible to the individual applications within the EAR only, but they must have unique service names across all the EARs in the application. Also, if you define caches both at the EAR level and at the module level, then the cache, scheme, and service names must be unique across the EAR-level cache configuration and the module cache configuration. |
Web-component-scoped cache in an EAR, or a stand-alone WAR deployment |
|
Caches defined at module level will be visible to the individual modules only, but they must have unique service names across all the modules in the application. Also, if you define caches both at the EAR level and at the module level, then the cache, scheme, and service names must be unique across the EAR-level cache configuration and the module cache configuration. |
Stand-alone EJB deployment |
|
An EJB module in an EAR cannot have module-scoped caches—they can only be application-scoped. |
Access the Cache Configuration on Server Startup
The server must be able to access the cache configuration file on startup. There are two ways to do this:
-
Place the cache configuration file in the server classpath, or
-
Declare the cache configuration file location in the server startup command with the
tangosol.coherence.cacheconfig
system property. For more information on this property, see the Developer's Guide for Oracle Coherence.Example 3-3 illustrates the
tangosol.coherence.cacheconfig
system property in a sample cache server startup command.Example 3-3 Declaring the Cache Configuration File in a Server Startup Command
java -server -Xms512m -Xmx512m -cp <Coherence installation dir>/lib/coherence.jar -Dtangosol.coherence.management.remote=true -Dtangosol.coherence.cacheconfig=WEB-INF/classes/coherence-cache-config.xml -Dtangosol.coherence.session.localstorage=true com.tangosol.net.DefaultCacheServer
If you are working with two (or more) applications, it is possible that they could have two (or more) different cache configurations. In this case, the cache configuration on the Coherence cache server must contain the union of these configurations. This allows the applications to be supported in the same cache cluster. Note that this is valid only for stand-alone cache servers.
Package Applications and Configure Coherence Cluster Scope
Coherence clusters are a group of Coherence nodes that share a group address which allows them to communicate. Coherence clusters are classloader-scoped according to where you place the coherence.jar
file in the classloader hierarchy. Coherence clusters can be:
-
application server-scoped—the entire JVM acts as a single Coherence cluster.
-
EAR-scoped—each application can be a Coherence cluster.
-
WAR-scoped—each Web module within an application can be a Coherence cluster.
The packing and configuration options for these three scoping scenarios are described in the following sections:
Configuring Application Server-Scoped Coherence Clusters
With this configuration, all deployed applications on WebLogic Server instances that are directly accessing Coherence caches become part of one Coherence cluster. Caches will be visible to all applications deployed on the server. This configuration produces the smallest number of Coherence nodes in the cluster (one for each WebLogic Server instance).
Since the Coherence library is deployed in the server's classpath, only one copy of the Coherence classes will be loaded into the JVM, thus minimizing resource utilization. However, since all applications are using the same Coherence cluster configuration, all applications will be affected if one application misbehaves.
To Use Coherence Data Caches with Application Server-Scoped Coherence Clusters
-
Edit your WebLogic Server system classpath to include
coherence.jar
andWL_HOME
/common/deployable-libraries/active-cache.jar
in the system classpath. Theactive-cache.jar
should be referenced only from thedeployable-libraries
folder in the system classpath and should not be copied to any other location. -
(Optional) If you want to configure Coherence cluster properties, create a
CoherenceClusterSystemResourceMBean
and reference it in theServerMBean
. You can use the WebLogic Server Administration Console or WLST to create and reference the MBean. SeecreateServerScopedCoherenceSystemResource
in Example 3-9.
Configuring EAR-Scoped Coherence Clusters
With this configuration, all deployed applications within each EAR become part of one Coherence cluster. Caches will be visible to all modules in the EAR. For example, this could be a recommended deployment if all the modules must share the same Coherence node. It can also be a recommended configuration if you plan on deploying only one EAR to an application server.
This configuration produces the next smallest number of Coherence nodes in the cluster (one for each deployed EAR). Since the Coherence library is deployed in the application's classpath, only one copy of the Coherence classes is loaded for each EAR.
Since all Web applications in the EAR share the same cluster configuration, all Web applications in the EAR will be affected if one of them misbehaves. EAR-scoped Coherence clusters reduce the deployment effort as no changes to the application server classpath are required.
To Use Coherence Caches with EAR-Scoped Coherence Clusters
-
Use either of the following methods to deploy the
coherence.jar
andactive-cache.jar
files as shared libraries to all of the target servers where the application will be deployed.-
Use the WebLogic Server Administration Console to deploy
coherence.jar
andactive-cache.jar
as shared libraries. See "Install a Java EE Library" in the Oracle Fusion Middleware Oracle WebLogic Server Administration Console Help.As an alternative to the Administration Console, you can deploy the JAR files on the command line. The following are sample deployment commands:
java weblogic.Deployer -username <> -password <> -adminurl <> -deploy coherence.jar -name coherence -library -targets <> java weblogic.Deployer -username <> -password <> -adminurl <> -deploy active-cache.jar -name active-cache -library -targets <>
-
Copy
coherence.jar
andactive-cache.jar
to the EARAPP-INF/lib
folder of the application. However, the preferred way is to deploy them as shared libraries.
-
-
Refer to the
coherence.jar
andactive-cache.jar
files as libraries. Example 3-4 illustrates a sampleweblogic-application.xml
configuration file. -
(Optional) If you want to configure Coherence cluster properties, create a
CoherenceClusterSystemResourceMBean
and reference it as acoherence-cluster-ref
element inweblogic-application.xml
file. This element allows the applications to enroll in the Coherence cluster as specified by theCoherenceClusterSystemResourceMBean
attributes.Example 3-5 illustrates a sample configuration. The
myCoherenceCluster
MBean in the example is of typeCoherenceClusterSystemResourceMBean
.
To Define a Filtering Classloader for Application-Scoped Coherence Clusters
If coherence.jar
is placed in the application server classpath, you can still configure an EAR-scoped cluster by defining a filtering classloader. This is described in the following steps:
-
Place
coherence.jar
in the application classpath. -
Configure a filtering classloader in the EAR file.
The filtering classloader is defined in the
<prefer-application-packages>
stanza of theweblogic-application.xml
file. Example 3-6 illustrates a sample filtering classloader configuration. Thepackage-name
elements indicate the package names of the classes in thecoherence.jar
andactive-cache.jar
.Example 3-6 Configuring a Filtering Classloader
<weblogic-application> ... <prefer-application-packages> <package-name>com.tangosol.*</package-name> <package-name>weblogic.coherence.service.*</package-name> <package-name>com.oracle.coherence.common.*</package-name> </prefer-application-packages> ... </weblogic-application>
Configuring WAR-Scoped Coherence Clusters
With this configuration, or if you want only one application to use Coherence caches, each deployed Web application becomes its own Coherence cluster. Caches will be visible to the individual modules only. For example, this could be a recommended deployment for a stand-alone WAR deployment or stand-alone EJB deployment.
If you are deploying multiple WAR files, note that this configuration produces the largest number of Coherence nodes in the cluster—one for each deployed WAR file that uses coherence.jar
. It also results in the largest resource utilization of the three configurations—one copy of the Coherence classes are loaded for each deployed WAR. On the other hand, since each deployed Web application is its own cluster, Web applications are completely isolated from other potentially misbehaving Web applications.
Note:
A Web module within an EAR can have a module-scoped Coherence node but an EJB module within an EAR can only have an application-scoped Coherence node.To Use Coherence Caches with WAR-Scoped Clusters
-
Use the WebLogic Server Administration Console to deploy
coherence.jar
andactive-cache.jar
as shared libraries to all of the target servers where the application will be deployed. See "Install a Java EE Library" in the Oracle Fusion Middleware Oracle WebLogic Server Administration Console Help.As an alternative to the Administration Console, you can also deploy the JAR files on the command line. The following are sample deployment commands:
java weblogic.Deployer -username <> -password <> -adminurl <> -deploy coherence.jar -name coherence -library -targets <> java weblogic.Deployer -username <> -password <> -adminurl <> -deploy active-cache.jar -name active-cache -library -targets <>
-
Import
coherence.jar
andactive-cache.jar
as optional packages in themanifest.mf
file of each module that will be using Coherence.As an alternative to using the manifest file, copy
coherence.jar
andactive-cache.jar
to each WAR file'sWEB-INF/lib
directory.Example 3-7 illustrates the contents of a sample
manifest.mf
file. -
(Optional) If you want to configure Coherence cluster properties, create a
CoherenceClusterSystemResourceMBean
and reference it as acoherence-cluster-ref
element inweblogic.xml
orweblogic-ejb-jar.xml
file.Example 3-8 illustrates a sample configuration for WAR-scoped clusters in the
weblogic.xml
file. ThemyCoherenceCluster
MBean is of typeCoherenceClusterSystemResourceMBean
.
Create and Configure Coherence Clusters
Using WLST or the Administration Console, you can create and configure a Coherence cluster, and select WebLogic Server instances or clusters on which the cluster configuration will be accessible.
The createCoherenceClusterMBean.py
WLST script shown in Example 3-9 configures three Coherence clusters, including a server-scoped configuration that gets deployed to the Administration Server (myserver
).
Use the following sample command to invoke WLST and run the script:
java -Dadmin.username=weblogic -Dadmin.password=welcome1 -Dadmin.host=localhost -Dadmin.port=7001 -Dtangosol-override="c:/temp/tangosol-coherence-override.xml" weblogic.WLST c:/temp/createCoherenceClusterMBean.py
Example 3-9 createCoherenceClusterMBean.py
from java.util import * from javax.management import * from java.lang import * import javax.management.Attribute """ This script configures three Coherence Cluster System Resource MBeans and deploys them to the admin server """ def createCoherenceSystemResource(wlsTargetNames, coherenceClusterSourceName): name = coherenceClusterSourceName # start creation print 'Creating CoherenceClusterSystemResource with name '+ name cohSR = create(name,"CoherenceClusterSystemResource") cohBean = cohSR.getCoherenceClusterResource() cohCluster = cohBean.getCoherenceClusterParams() cohCluster.setUnicastListenAddress("localhost") cohCluster.setUnicastListenPort(7001) cohCluster.setUnicastPortAutoAdjust(true) # you can set up the multicast port or define WKAs cohCluster.setMulticastListenAddress("231.1.1.1") cohCluster.setMulticastListenPort(8001) cohCluster.setTimeToLive(5) for wlsTargetName in wlsTargetNames: cd("Servers/"+wlsTargetName) target = cmo cohSR.addTarget(target) cd("../..") def createServerScopedCoherenceSystemResource(wlsTargetNames, coherenceClusterSourceName): name = coherenceClusterSourceName # start creation print 'Creating CoherenceClusterSystemResource with name '+ name cohSR = create(name,"CoherenceClusterSystemResource") cohBean = cohSR.getCoherenceClusterResource() cohCluster = cohBean.getCoherenceClusterParams() cohCluster.setUnicastListenAddress("localhost") cohCluster.setUnicastListenPort(7002) cohCluster.setUnicastPortAutoAdjust(true) # you can set up the multicast port or define WKAs cohWKAs = cohCluster.getCoherenceClusterWellKnownAddresses() cohWKA = cohWKAs.createCoherenceClusterWellKnownAddress("wka1") cohWKA.setName("wka1") cohWKA.setListenAddress("localhost") cohWKA.setListenPort(9001) for wlsTargetName in wlsTargetNames: cd("Servers/"+wlsTargetName) target = cmo cohSR.addTarget(target) print cmo serverBean = cmo serverBean.setCoherenceClusterSystemResource(cohSR) cd("../..") def createCustomCoherenceSystemResource(wlsTargetNames, coherenceClusterSourceName, tangosolOverrideFile): name = coherenceClusterSourceName # start creation cohSR = getMBean("/CoherenceClusterSystemResources/"+name) if cohSR == None: print 'Creating CoherenceClusterSystemResource with name '+ name cohSR = create(name,"CoherenceClusterSystemResource") cohSR.importCustomClusterConfigurationFile(tangosolOverrideFile) for wlsTargetName in wlsTargetNames: cd("Servers/"+wlsTargetName) target = cmo cohSR.addTarget(target) cd("../..") props = System.getProperties() ADMIN_NAME = props.getProperty("admin.username") ADMIN_PASSWORD = props.getProperty("admin.password") ADMIN_HOST = props.getProperty("admin.host") ADMIN_PORT = props.getProperty("admin.port") ADMIN_URL = "t3://"+ADMIN_HOST+":"+ADMIN_PORT TANGOSOL_OVERRIDE = props.getProperty("tangosol-override") TARGETS = [ 'myserver' ] print "Starting the script ..." try : connect(ADMIN_NAME, ADMIN_PASSWORD, ADMIN_URL) edit() startEdit() createCoherenceSystemResource(TARGETS, 'cohSystemResource') createServerScopedCoherenceSystemResource(TARGETS, 'serverScopedCohSystemResource') createCustomCoherenceSystemResource(TARGETS, 'customCohSystemResource',TANGOSOL_OVERRIDE) save() activate(block="true") disconnect() print 'Done configuring the Coherence Cluster System Resources' except: dumpStack() undo('true','y')
For Administration Console procedures, see "Configure Coherence" in the Oracle Fusion Middleware Oracle WebLogic Server Administration Console Help.
Cluster-related values are stored in a descriptor file in the WebLogic Server configuration repository:
DOMAIN_HOME
/config/coherence/
CoherenceClusterSystemResourceName
/
CoherenceClusterSystemResourceName
-
####
-coherence.xml
, where DOMAIN_HOME
is the location in which you installed your WebLogic Server domain, such as d:/oracle/MW_HOME/user_projects/domains/
domain_name
.
For example, C:\Oracle\Middleware\user_projects\domains\base_domain\config\coherence\cohSystemResource\cohSystemResource-0759-coherence.xml
.
Alternatively, you can configure properties that are not specified for the cluster by configuring them in a custom configuration file, for example, tangosol-coherence-override.xml
, shown in Example 3-10.
Example 3-10 tangosol-coherence-override.xml
<?xml version='1.0'?> <!-- This operational configuration override file is for use with Coherence in a development mode. --> <coherence xml-override="/tangosol-coherence-override.xml"> <cluster-config> <multicast-listener> <time-to-live system-property="tangosol.coherence.ttl">4</time-to-live> <join-timeout-milliseconds>3000</join-timeout-milliseconds> </multicast-listener> <packet-publisher> <packet-delivery> <timeout-milliseconds>30000</timeout-milliseconds> </packet-delivery> </packet-publisher> </cluster-config> <logging-config> <severity-level system-property="tangosol.coherence.log.level">5</severity-level> <character-limit system-property="tangosol.coherence.log.limit">0</character-limit> </logging-config> </coherence>
Use WLST to import the custom cluster configuration file (also shown in Example 3-9, see createCustomCoherenceSystemResource
) or the WebLogic Server Administration Console. See "Import a custom cluster configuration" in the Oracle Fusion Middleware Oracle WebLogic Server Administration Console Help.
Note:
If you specify cluster-related properties by importing a custom configuration file, the properties specified in the file must not be the same properties that were specified using WLST or the WebLogic Server Administration Console.Start a Cache Server
Stand-alone Coherence cache servers are dedicated JVMs responsible for storing and managing all cached data. The senior node (which is the first node) in a Coherence data cluster can take several seconds to start; the start up time required by subsequent nodes is minimal. Thus, to optimize performance, you should always start a Coherence cache server before starting WebLogic Server instances. This will ensure that there is minimal (measured in milliseconds) startup time for applications using ActiveCache. Any additional Web applications that use ActiveCache are guaranteed not to be the senior data member, so they will have minimal impact on WebLogic Server startup.
Note:
Whether you start the cache servers first or the WebLogic Server instances first, depends on the cluster topology you are employing.-
If you are using In-Process topology (all storage-enabled WebLogic Server instances employing ActiveCache), then it does not matter which WebLogic Server instances you start first.
-
If you are using Out-of-Process topology (storage-disabled WebLogic server instances and stand-alone cache servers), then start the cache servers first, followed by the WebLogic Server instances.
-
If you are using WebLogic Out-of-Process topology, your topology is a mix of storage-enabled and storage-disabled WebLogic Server instances. Start the storage-enabled instances first, followed by the storage-disabled instances.
Starting Cache Servers Using Node Manager
As of WebLogic Server 10.3.4, you can use the WebLogic Server Administration Server, via the Administration Console or WLST, and java-based Node Manager to manage and monitor the life cycle of stand-alone Coherence cache servers.
Node Manager is a WebLogic Server utility that lets you start, stop, and automatically restart servers remotely. Node Manager must run on each computer that hosts the Coherence server instances that you want to control with Node Manager.
Prerequisite steps for using Node Manager to start cache servers are:
-
Configure Node Manager to start servers.
See "General Node Manager Configuration" in the Oracle Fusion Middleware Node Manager Administrator's Guide for Oracle WebLogic Server.
-
Start Node Manager.
You can start Node Manager manually at a command prompt or with a script. See "Starting Node Manager" in the Oracle Fusion Middleware Node Manager Administrator's Guide for Oracle WebLogic Server.
To use WLST to start Node Manager:
c:\>java weblogic.WLST wls:/offline> startNodeManager()
For more information about using WLST with Node Manager, see "Node Manager Commands" in Oracle Fusion Middleware WebLogic Scripting Tool Command Reference.
On Windows, you can use a shortcut on the Start menu to start Node Manager (WebLogic Server > Tools > Node Manager).
Coherence cache server log files and cache server-specific Node Manager information files are located under DOMAIN_HOME
/
servers_coherence
/
COHserver_name
/, where DOMAIN_HOME
is the location in which you installed your WebLogic Server domain, such as d:/oracle/MW_HOME/user_projects/domains/
domain_name
, and COHserver_name
is the name of the Coherence cache server.
Starting Cache Servers from the Administration Console
To use the Administration Console to start a Coherence cache server, see "Start Coherence Servers from the Administration Console" in the Oracle Fusion Middleware Oracle WebLogic Server Administration Console Help.
Starting Cache Servers with WLST
The startCoh.py
WLST script shown in Example 3-11 starts a stand-alone Coherence server, COH_server1
.
Use the following sample command to invoke WLST and run the script:
java weblogic.WLST d:/temp/startCoh.py
Example 3-11 startCoh.py
props = System.getProperties() ADMIN_NAME = props.getProperty("admin.username") if ADMIN_NAME == None: ADMIN_NAME = 'weblogic' ADMIN_PASSWORD = props.getProperty("admin.password") if ADMIN_PASSWORD == None : ADMIN_PASSWORD = 'welcome1' ADMIN_HOST = props.getProperty("admin.host") if ADMIN_HOST == None : ADMIN_HOST = 'localhost' ADMIN_PORT = props.getProperty("admin.port") if ADMIN_PORT == None : ADMIN_PORT = '7001' ADMIN_URL = "t3://" + ADMIN_HOST + ":" + ADMIN_PORT COH_SERVER = props.getProperty("server") if COH_SERVER == None : COH_SERVER = 'COH_server1' connect(ADMIN_NAME, ADMIN_PASSWORD, ADMIN_URL) domainRuntime() lifecycle = getMBean('/CoherenceServerLifeCycleRuntimes/' + COH_SERVER) seconds = 5 print("starting: " + COH_SERVER); print("before state:" + lifecycle.getState()) lifecycle.start() print("after state:" + lifecycle.getState()) java.lang.Thread.sleep(seconds * 1000) print("after state:" + lifecycle.getState()) disconnect()
You can use the stopCoh.py
WLST script, shown in Example 3-12, to shut down the same Coherence cache server.
Example 3-12 stopCoh.py
props = System.getProperties() ADMIN_NAME = props.getProperty("admin.username") if ADMIN_NAME == None: ADMIN_NAME = 'weblogic' ADMIN_PASSWORD = props.getProperty("admin.password") if ADMIN_PASSWORD == None : ADMIN_PASSWORD = 'welcome1' ADMIN_HOST = props.getProperty("admin.host") if ADMIN_HOST == None : ADMIN_HOST = 'localhost' ADMIN_PORT = props.getProperty("admin.port") if ADMIN_PORT == None : ADMIN_PORT = '7001' ADMIN_URL = "t3://" + ADMIN_HOST + ":" + ADMIN_PORT COH_SERVER = props.getProperty("server") if COH_SERVER == None : COH_SERVER = 'COH_server1' connect(ADMIN_NAME, ADMIN_PASSWORD, ADMIN_URL) domainRuntime() lifecycle = getMBean('/CoherenceServerLifeCycleRuntimes/' + COH_SERVER) seconds = 5 print("forceShutdown: " + COH_SERVER); lifecycle.forceShutdown() print("after state:" + lifecycle.getState()) disconnect()
Starting Cache Servers Using a Startup Script
Alternatively, to start Coherence cache servers without using the WebLogic Server Administration Server, use the following steps:
-
Create a script for starting a Coherence cache server. The following is a very simple example of a script that starts a storage-enabled cache server to use with ActiveCache. This example assumes that you are using a Sun JVM. See JVM Tuning in the Developer's Guide for Oracle Coherence for more information.
java -server -Xms512m -Xmx512m -cp <Coherence installation dir>/lib/coherence.jar -Dtangosol.coherence.management.remote=true -Dtangosol.coherence.cacheconfig=WEB-INF/classes/cache_configuration_file -Dtangosol.coherence.session.localstorage=true com.tangosol.net.DefaultCacheServer
In this example,
cache_configuration_file
refers to the cache configuration in thecoherence-cache-config.xml
file. The cache configuration defined for the cache server must be the same as the configuration defined for the application servers which run on the same Coherence cluster. -
Start one or more Coherence cache servers using the script described in the previous step.
Restarting Cache Servers Using Node Manager
Coherence cache servers write life cycle information (status) to DOMAIN_HOME
/
servers_coherence
/
COHserver_name
/data/nodemanager/
COHserver_name
.state
. Node Manager monitors this file and other files in that directory to detect whether the cache server is running or not, and depending on its status (a clean shutdown generates a different final state than a crash or a startup failure), whether to re-start it.
In addition, if you restart the Node Manager, it also takes into consideration the value of the CrashRecoveryEnabled
property, which you can specify in the weblogic.nodemanager.NodeManager
startup command or define in the nodemanager.properties
file, located under WL_HOME
/common/nodemanager
, where WL_HOME
is the location in which you installed WebLogic Server. For more information, see "Node Manager and System Crash Recovery" and "Reviewing nodemanager.properties" in the Oracle Fusion Middleware Node Manager Administrator's Guide for Oracle WebLogic Server.
Note:
If the Node Manager is not running (if it goes down or is not yet started), cache servers will report their state asunknown
. In addition, cache servers will report their state as unknown
if the Node Manager has never been used to start the server, for example, upon initial creation. This is because cache server life cycle status is only determined by the Node Manager retrieving the information from the DOMAIN_HOME
/
servers_coherence
/
COHserver_name
/data/nodemanager/
COHserver_name
.state
file.Start WebLogic Server
WebLogic Server provides several ways to start and stop server instances. The method that you choose depends on whether you prefer using the Administration Console or a command-line interface, and on whether you are using Node Manager to manage the server's life cycle. For detailed information, see "Starting and Stopping Servers" in Oracle Fusion Middleware Managing Server Startup and Shutdown for Oracle WebLogic Server. For a quick reference, see "Starting and Stopping Servers: Quick Reference."
By default, a WebLogic Server instance employing ActiveCache starts in storage-disabled mode. To start the WebLogic Server instance in storage-enabled mode, include the command-line property -Dtangosol.coherence.session.localstorage=true
in the server startup command.
For more information, see "Using the weblogic.Server Command Line to Start a Server Instance" in the Oracle Fusion Middleware Command Reference for Oracle WebLogic Server.
Monitor Coherence Cluster Properties
The WebLogic Server Administration Console displays run-time monitoring information for Coherence clusters associated with a particular application or module, such as cluster size, members, and version. For more information, see "Monitoring Coherence Clusters" in the Oracle Fusion Middleware Oracle WebLogic Server Administration Console Help.