All Downloads are FREE. Search and download functionalities are using the official Maven repository.

jakarta.jms.ServerSession Maven / Gradle / Ivy

Go to download

This artifact provides a single jar that contains all classes required to use remote EJB and JMS, including all dependencies. It is intended for use by those not using maven, maven users should just import the EJB and JMS BOM's instead (shaded JAR's cause lots of problems with maven, as it is very easy to inadvertently end up with different versions on classes on the class path).

There is a newer version: 34.0.0.Final
Show newest version
/*
 * Copyright (c) 1997, 2020 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0, which is available at
 * http://www.eclipse.org/legal/epl-2.0.
 *
 * This Source Code may also be made available under the following Secondary
 * Licenses when the conditions for such availability set forth in the
 * Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
 * version 2 with the GNU Classpath Exception, which is available at
 * https://www.gnu.org/software/classpath/license.html.
 *
 * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
 */

package jakarta.jms;

/**
 * A {@code ServerSession} object is an application server object that is used by a server to associate a thread with a
 * Jakarta Messaging session (optional).
 *
 * 

* A {@code ServerSession} implements two methods: * *

    *
  • {@code getSession} - returns the {@code ServerSession}'s Jakarta Messaging session. *
  • {@code start} - starts the execution of the {@code ServerSession} thread and results in the execution of the JMS * session's {@code run} method. *
* *

* A {@code ConnectionConsumer} implemented by a Jakarta Messaging provider uses a {@code ServerSession} to process one or more * messages that have arrived. It does this by getting a {@code ServerSession} from the {@code ConnectionConsumer}'s * {@code ServerSessionPool}; getting the {@code ServerSession}'s Jakarta Messaging session; loading it with the messages; and then * starting the {@code ServerSession}. * *

* In most cases the {@code ServerSession} will register some object it provides as the {@code ServerSession}'s thread * run object. The {@code ServerSession}'s {@code start} method will call the thread's {@code start} method, which will * start the new thread, and from it, call the {@code run} method of the {@code ServerSession}'s run object. This object * will do some housekeeping and then call the {@code Session}'s {@code run} method. When {@code run} returns, the * {@code ServerSession}'s run object can return the {@code ServerSession} to the {@code ServerSessionPool}, and the * cycle starts again. * *

* Note that the Jakarta Messaging API does not architect how the {@code ConnectionConsumer} loads the {@code Session} with messages. * Since both the {@code ConnectionConsumer} and {@code Session} are implemented by the same Jakarta Messaging provider, they can * accomplish the load using a private mechanism. * * @see jakarta.jms.ServerSessionPool * @see jakarta.jms.ConnectionConsumer * * @version Jakarta Messaging 2.0 * @since JMS 1.0 */ public interface ServerSession { /** * Return the {@code ServerSession}'s {@code Session}. This must be a {@code Session} created by the same * {@code Connection} that will be dispatching messages to it. The provider will assign one or more messages to the * {@code Session} and then call {@code start} on the {@code ServerSession}. * * @return the server session's session * * @exception JMSException if the Jakarta Messaging provider fails to get the associated session for this {@code ServerSession} due to * some internal error. **/ Session getSession() throws JMSException; /** * Cause the {@code Session}'s {@code run} method to be called to process messages that were just assigned to it. * * @exception JMSException if the Jakarta Messaging provider fails to start the server session to process messages due to some * internal error. */ void start() throws JMSException; }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy