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

com.orientechnologies.orient.core.command.OCommandDistributedReplicateRequest Maven / Gradle / Ivy

/*
 *
 *  *  Copyright 2014 Orient Technologies LTD (info(at)orientechnologies.com)
 *  *
 *  *  Licensed under the Apache License, Version 2.0 (the "License");
 *  *  you may not use this file except in compliance with the License.
 *  *  You may obtain a copy of the License at
 *  *
 *  *       http://www.apache.org/licenses/LICENSE-2.0
 *  *
 *  *  Unless required by applicable law or agreed to in writing, software
 *  *  distributed under the License is distributed on an "AS IS" BASIS,
 *  *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  *  See the License for the specific language governing permissions and
 *  *  limitations under the License.
 *  *
 *  * For more information: http://www.orientechnologies.com
 *
 */
package com.orientechnologies.orient.core.command;

/**
 * Interface to know if the command must be distributed in clustered scenario.
 * 
 * @author Luca Garulli
 */
public interface OCommandDistributedReplicateRequest {

  enum DISTRIBUTED_EXECUTION_MODE {
    LOCAL, REPLICATE, SHARDED
  }

  enum QUORUM_TYPE {
    NONE, READ, WRITE, ALL
  }

  /**
   * Returns the execution mode when distributed configuration is active:
   * 
    *
  • LOCAL: executed on local node only
  • *
  • REPLICATE: executed on all the nodes and expect the same result
  • *
  • SHARDED: executed on all the involved nodes and merge results
  • *
*/ DISTRIBUTED_EXECUTION_MODE getDistributedExecutionMode(); /** * Returns the quorum type for the command: *
    *
  • NONE: no quorum
  • *
  • READ: configured Read quorum
  • *
  • WRITE: configured Write quorum
  • *
  • ALL: all nodes
  • *
*/ QUORUM_TYPE getQuorumType(); /** * Returns the distributed timeout in milliseconds. * * @return */ long getDistributedTimeout(); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy