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

com.tangosol.net.Session Maven / Gradle / Ivy

There is a newer version: 24.09
Show newest version
/*
 * Copyright (c) 2000, 2020, Oracle and/or its affiliates.
 *
 * Licensed under the Universal Permissive License v 1.0 as shown at
 * http://oss.oracle.com/licenses/upl.
 */
package com.tangosol.net;

import com.tangosol.net.cache.TypeAssertion;
import com.tangosol.net.topic.NamedTopic;

/**
 * A thread-safe mechanism to request Coherence-based resources, like
 * {@link NamedCache}s, from a deployed module.
 * 

* Resources provided by a {@link Session} are scoped to the {@link Session}. * When a {@link Session} is closed, all resources are closed. * Once closed, references to resources are no longer valid. Any * attempt to use a closed {@link Session} or closed resource may throw an * IllegalStateException. *

* The effect of closing a resource is specific to the type of resource. * For example, resources provided by a {@link Session} may represent * shared (ie: clustered) data-structures and services. In such circumstances, * closing these resources only closes the {@link Session}-based representation, * not the underlying shared infrastructure, which may remain active for other * {@link Session}s. Future requests of a {@link Session} for previously closed * resources of this kind will likely yield a new reference to logically the * same underlying resource. To destroy such resources, instead of close, * resource-specific methods should be used. *

* Applications making use of {@link Session}s are expected to maintain their * own references to {@link Session}s. Coherence provides no mechanism to * identify and obtain previously created {@link Session}s. Furthermore, * applications are expected to correctly close {@link Session}s when they are * no longer required. * * @see SessionProvider * * @author bo 2015.07.27 */ public interface Session extends AutoCloseable { // ----- Session methods ------------------------------------------------ /** * Acquire a {@link NamedCache} using the specified {@link com.tangosol.net.NamedCache.Option}s, * for example a {@link TypeAssertion}. * * @param sName the name of the {@link NamedCache} * @param options the {@link com.tangosol.net.NamedCache.Option}s * * @param the type of keys for the {@link NamedCache} * @param the type of values for the {@link NamedCache} * * @return a {@link NamedCache} */ NamedCache getCache(String sName, NamedCache.Option... options); /** * Acquire a {@link NamedTopic} using the * specified {@link ValueTypeAssertion}. * * @param sName the name of the {@link NamedTopic} * * @param the type of elements for the {@link NamedTopic} * * @return a {@link NamedCache} * * @since Coherence 14.1.1 */ NamedTopic getTopic(String sName, NamedTopic.Option... options); // ----- Option interface ----------------------------------------------- /** * An immutable option for creating and configuring {@link Session}s. */ interface Option { } // ----- helper methods ------------------------------------------------- /** * Create a {@link Session} based on the current calling * context and provided {@link Option}s, using the default (auto-detected) * {@link SessionProvider}, * * @param options the {@link Option}s for the {@link Session} * * @return a {@link Session} * * @throws IllegalArgumentException * when a {@link Session} or {@link SessionProvider} can't be * acquired using the specified {@link Option}s * * @throws IllegalStateException * when a {@link SessionProvider} can't be auto-detected * * @see SessionProvider#createSession(Option...) */ static Session create(Option... options) throws IllegalArgumentException, IllegalStateException { return SessionProvider.get().createSession(options); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy