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;
/**
* 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;
}