public interface WorkManager
WorkManagers are created by the server administrator. The vendor specific systems management console allows the administrator to create one or more WorkManagers and associate a JNDI name with each one. The administrator may specify implementation specific information such as min/max Works for each WorkManager. An application that requires a WorkManager should declare a resource-ref in the EJB or webapp that needs the WorkManager. The vendor descriptor editor or Java EE IDE can be used to bind this resource-ref to a physical WorkManager at deploy or development time. An EJB or servlet can then get a reference to a WorkManager by looking up the resource-ref name in JNDI and then casting it. For example, if the resource-ref was called wm/WorkManager:
<resource-ref> <res-ref-name>wm/WorkManager</res-ref-name> <res-type>commonj.work.WorkManager</res-type> <res-auth>Container</res-auth> <res-sharing-scope>Shareable</res-sharing-scope> </resource-ref>The Java code to look this up would look like:
   InitialContext ic = new InitialContext();
   WorkManager wm = (WorkManager)ic.lookup("java:comp/env/wm/WorkManager");
 
 The res-auth and res-sharing scopes are ignored in this version of the specification.
 The EJB or servlet can then use the WorkManager as it needs to.When a Work is scheduled, the declared context that is present on the thread (the Java EE context) will be saved and propagated to the asynchronous methods that are executed. This Java EE context at minimum will contain the java:comp namespace and ClassLoader of the scheduler unless specified otherwise. Other Java EE contexts such as security or a transactional context may be optionally added by the application server vendor. Global transactions are always available using the java:comp/UserTransaction JNDI name and are used in the same fashion as they are used in servlets and bean-managed transaction Enterprise Java Beans.
A WorkManager can also be a pinned WorkManager. This is a WorkManager obtained using the RemoteWorkItem.getWorkManager method. This allows subsequent scheduleWorks to be send to the same remote WorkManager as the one that is associated with the RemoteWorkItem. Pinned WorkManagers are only supported on vendor implementations that support remote Works. However, applications that follow the programming model will work on all implementations however serializable Works will be executed within the local JVM only on those implementations.
 
 If the scheduled Work is a daemon Work, then the life-cycle of that Work is tied to 
 the application that scheduled it.  If the application is stopped, the Work.release() method
 will be called.
Work, 
RemoteWorkItem| Modifier and Type | Field and Description | 
|---|---|
| static long | IMMEDIATEThis constant can be used as a timeout for the waitForXXX methods. | 
| static long | INDEFINITEThis constant can be used as a timeout for either the waitForXXX methods. | 
| Modifier and Type | Method and Description | 
|---|---|
| WorkItem | schedule(Work work)Dispatches a Work asynchronously. | 
| WorkItem | schedule(Work work,
        WorkListener wl)Dispatches a Work asynchronously. | 
| boolean | waitForAll(Collection workItems,
          long timeout_ms)Wait for all WorkItems in the collection to finish successfully or otherwise. | 
| Collection | waitForAny(Collection workItems,
          long timeout_ms)Wait for any of the WorkItems in the collection to finish. | 
static final long IMMEDIATE
static final long INDEFINITE
WorkItem schedule(Work work) throws WorkException, IllegalArgumentException
At-most-once semantics are provided. If the server fails then the Work will not be executed on restart.
 If this WorkManager is a pinned one, i.e. one obtained using RemoteWorkItem.getPinnedWorkManager() and that JVM that it
 represents has failed then a WorkRejectedException will be thrown even if the remote JVM restarts. The pinned WorkManager
 must be refreshed by using a normal WorkManager and then acquiring a new pinned WorkManager.
work - the Work to execute.If - queuing this up results in an exception then a
 WorkException is thrown.IllegalArgumentException - thrown if work is a javax.ejb.EnterpriseBean.WorkExceptionWorkItem schedule(Work work, WorkListener wl) throws WorkException, IllegalArgumentException
At-most-once semantics are provided. If the server fails then the Work will not be executed on restart.
The WorkListener methods are called using the Java EE context of the caller as the Work progresses through processing.
 If this WorkManager is a pinned one, i.e. one obtained using RemoteWorkItem.getPinnedWorkManager() and that JVM that it
 represents has failed then a WorkRejectedException will be thrown even if the remote JVM restarts. The pinned WorkManager
 must be refreshed by using a normal WorkManager and then acquiring a new pinned WorkManager.
work - the Work to execute.wl - can be null or a WorkListener which is used to inform
 the application of the progress of a Work.WorkException - If queuing this up results in an exception then a
 WorkException is thrown.IllegalArgumentException - thrown if work is a javax.ejb.EnterpriseBean.boolean waitForAll(Collection workItems, long timeout_ms) throws InterruptedException, IllegalArgumentException
The WorkItems collection should not be altered once submitted until the method returns.
workItems - the Collection of WorkItem objects to wait for.timeout_ms - the timout in milliseconds. If this is 0 then this method returns immediately.InterruptedException - thrown if the wait is interrupted.IllegalArgumentException - thrown if workItems is null, any of the objects in the collection are 
 not WorkItems or the timeout_ms is negative.Collection waitForAny(Collection workItems, long timeout_ms) throws InterruptedException, IllegalArgumentException
The WorkItems collection should not be altered once submitted until the method returns.
workItems - the Collection of WorkItem objects to wait for.timeout_ms - the timeout in ms. If this is 0 then the method returns immediately, i.e. does not block.InterruptedException - thrown if the wait is interrupted.IllegalArgumentException - thrown if workItems is null, any of the objects in the collection are 
 not WorkItems or the timeout_ms is negative.