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

com.dasasian.chok.node.IContentServer Maven / Gradle / Ivy

/**
 * Copyright (C) 2014 Dasasian ([email protected])
 *
 * 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.
 */
package com.dasasian.chok.node;

import com.dasasian.chok.util.NodeConfiguration;
import org.apache.hadoop.ipc.ProtocolInfo;
import org.apache.hadoop.ipc.VersionedProtocol;

import java.nio.file.Path;
import java.util.Collection;
import java.util.Map;

/**
 * This describes the interaction between the general Node class and a specific
 * Chok server instance it is managing. The Node class talks to Zookeeper, and
 * manages the shards on disk. It tells the server when to start and stop using
 * the shards, and when to shut down.
 * 

* The RPC calls from the client will not go through the Node. The Hadoop * RPC.Server uses a separate interface for those calls. *

* Implementations need to have a default constructor. */ @ProtocolInfo(protocolName = "IContentServer", protocolVersion = 0L) public interface IContentServer extends VersionedProtocol { /** * The key fetched from getShardMetadata() which in order to report the size * of the shard in the listIndexes command. The value must be parsable as an * integer. The units depend on the type of data in the shard. Reporting the * shard size is optional. */ String SHARD_SIZE_KEY = "shard-size"; /** * The key fetched from getShardMetadata() which in order to report the size * of the shard in the listIndexes command. The value must be parsable as an * integer. The units depend on the type of data in the shard. Reporting the * shard size is optional. */ String SHARD_DISK_USAGE_KEY = "shard-disk-usage"; /** * Initializes the content-server after the instance has been created. Passes * the node-name. * * @param nodeName the name of the local machine, for example "sever21.foo.com:8000". * Use this name in your results if you need to refer to the current * node * @param nodeConfiguration chok.node.properties which may contain custom properties for the * content-server */ void init(String nodeName, NodeConfiguration nodeConfiguration); /** * Include the shard (directory of data) when computing results. The shard is * a directory, ready to be used. * * @param shardName The name of the shard. Will be used in removeShard(). May also be * used in requests. * @param shardDir The directory where the shard data is. * @throws Exception when an error occurs */ void addShard(String shardName, Path shardDir) throws Exception; /** * Replace the shard (directory of data) when computing results. The shard is * a directory, ready to be used. * * @param shardName The name of the shard. Will be used in removeShard(). May also be * used in requests. * @param shardDir The directory where the shard data is. * @return the replaced shardDir * @throws Exception when an error occurs */ Path replaceShard(String shardName, Path shardDir) throws Exception; /** * Stop including the shard (directory of data). After this call returns, the * server should use the directory, or even assume that it exists. * * @param shardName Which shard to stop using. This was the name provided in * addShard(). * @throws Exception when an error occurs */ void removeShard(String shardName) throws Exception; /** * @return all included shards */ Collection getShards(); /** * Returns data about a shard. Currently the only standard key is * SHARD_SIZE_KEY. This value will be reported by the listIndexes command. The * units depend on the type of server. It is OK to return an empty map or * null. * * @param shardName The name of the shard to measure. This was the name provided in * addShard(). * @return a map of key/value pairs which describe the shard. * @throws Exception when an error occurs */ Map getShardMetaData(String shardName) throws Exception; /** * Release all resources. No further calls will happen after this call. * * @throws Exception when an error occurs */ void shutdown() throws Exception; }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy