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

io.vertx.core.shareddata.SharedData Maven / Gradle / Ivy

There is a newer version: 5.0.0.CR1
Show newest version
/*
 * Copyright (c) 2011-2019 Contributors to the Eclipse Foundation
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License 2.0 which is available at
 * http://www.eclipse.org/legal/epl-2.0, or the Apache License, Version 2.0
 * which is available at https://www.apache.org/licenses/LICENSE-2.0.
 *
 * SPDX-License-Identifier: EPL-2.0 OR Apache-2.0
 */

package io.vertx.core.shareddata;

import io.vertx.codegen.annotations.VertxGen;
import io.vertx.core.AsyncResult;
import io.vertx.core.Future;
import io.vertx.core.Handler;

/**
 * Shared data allows you to share data safely between different parts of your application in a safe way.
 * 

* Shared data provides: *

    *
  • synchronous shared maps (local)
  • *
  • asynchronous maps (local or cluster-wide)
  • *
  • asynchronous locks (local or cluster-wide)
  • *
  • asynchronous counters (local or cluster-wide)
  • *
*

*

* WARNING: In clustered mode, asynchronous maps/locks/counters rely on distributed data structures provided by the cluster manager. * Beware that the latency relative to asynchronous maps/locks/counters operations can be much higher in clustered than in local mode. *

* Please see the documentation for more information. * * @author Tim Fox */ @VertxGen public interface SharedData { /** * Get the cluster wide map with the specified name. The map is accessible to all nodes in the cluster and data * put into the map from any node is visible to to any other node. * * @param name the name of the map * @param resultHandler the map will be returned asynchronously in this handler * @throws IllegalStateException if the parent {@link io.vertx.core.Vertx} instance is not clustered */ void getClusterWideMap(String name, Handler>> resultHandler); /** * Same as {@link #getClusterWideMap(String, Handler)} but returns a {@code Future} of the asynchronous result */ Future> getClusterWideMap(String name); /** * Get the {@link AsyncMap} with the specified name. When clustered, the map is accessible to all nodes in the cluster * and data put into the map from any node is visible to to any other node. *

* WARNING: In clustered mode, asynchronous shared maps rely on distributed data structures provided by the cluster manager. * Beware that the latency relative to asynchronous shared maps operations can be much higher in clustered than in local mode. *

* * @param name the name of the map * @param resultHandler the map will be returned asynchronously in this handler */ void getAsyncMap(String name, Handler>> resultHandler); /** * Same as {@link #getAsyncMap(String, Handler)} but returns a {@code Future} of the asynchronous result */ Future> getAsyncMap(String name); /** * Get the {@link AsyncMap} with the specified name. *

* When clustered, the map is NOT accessible to all nodes in the cluster. * Only the instance which created the map can put and retrieve data from this map. * * @param name the name of the map * @param resultHandler the map will be returned asynchronously in this handler */ void getLocalAsyncMap(String name, Handler>> resultHandler); /** * Same as {@link #getLocalAsyncMap(String, Handler)} but returns a {@code Future} of the asynchronous result */ Future> getLocalAsyncMap(String name); /** * Get an asynchronous lock with the specified name. The lock will be passed to the handler when it is available. *

* In general lock acquision is unordered, so that sequential attempts to acquire a lock, * even from a single thread, can happen in non-sequential order. *

* * @param name the name of the lock * @param resultHandler the handler */ void getLock(String name, Handler> resultHandler); /** * Same as {@link #getLock(String, Handler)} but returns a {@code Future} of the asynchronous result */ Future getLock(String name); /** * Like {@link #getLock(String, Handler)} but specifying a timeout. If the lock is not obtained within the timeout * a failure will be sent to the handler. *

* In general lock acquision is unordered, so that sequential attempts to acquire a lock, * even from a single thread, can happen in non-sequential order. *

* * @param name the name of the lock * @param timeout the timeout in ms * @param resultHandler the handler */ void getLockWithTimeout(String name, long timeout, Handler> resultHandler); /** * Same as {@link #getLockWithTimeout(String, long, Handler)} but returns a {@code Future} of the asynchronous result */ Future getLockWithTimeout(String name, long timeout); /** * Get an asynchronous local lock with the specified name. The lock will be passed to the handler when it is available. *

* In general lock acquision is unordered, so that sequential attempts to acquire a lock, * even from a single thread, can happen in non-sequential order. *

* * @param name the name of the lock * @param resultHandler the handler */ void getLocalLock(String name, Handler> resultHandler); /** * Same as {@link #getLocalLock(String, Handler)} but returns a {@code Future} of the asynchronous result */ Future getLocalLock(String name); /** * Like {@link #getLocalLock(String, Handler)} but specifying a timeout. If the lock is not obtained within the timeout * a failure will be sent to the handler. *

* In general lock acquision is unordered, so that sequential attempts to acquire a lock, * even from a single thread, can happen in non-sequential order. *

* * @param name the name of the lock * @param timeout the timeout in ms * @param resultHandler the handler */ void getLocalLockWithTimeout(String name, long timeout, Handler> resultHandler); /** * Same as {@link #getLocalLockWithTimeout(String, long, Handler)} but returns a {@code Future} of the asynchronous result */ Future getLocalLockWithTimeout(String name, long timeout); /** * Get an asynchronous counter. The counter will be passed to the handler. * * @param name the name of the counter. * @param resultHandler the handler */ void getCounter(String name, Handler> resultHandler); /** * Same as {@link #getCounter(String, Handler)} but returns a {@code Future} of the asynchronous result */ Future getCounter(String name); /** * Get an asynchronous local counter. The counter will be passed to the handler. * * @param name the name of the counter. * @param resultHandler the handler */ void getLocalCounter(String name, Handler> resultHandler); /** * Same as {@link #getLocalCounter(String, Handler)} but returns a {@code Future} of the asynchronous result */ Future getLocalCounter(String name); /** * Return a {@code LocalMap} with the specific {@code name}. * * @param name the name of the map * @return the map */ LocalMap getLocalMap(String name); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy