javadoc and model improvements from Stargate github
git-svn-id: https://svn.apache.org/repos/asf/hadoop/hbase/trunk@791045 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
90366d50f8
commit
22aaa2c118
|
@ -18,7 +18,7 @@
|
||||||
* limitations under the License.
|
* limitations under the License.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package org.apache.hadoop.hbase.stargate.model;
|
package org.apache.hadoop.hbase.stargate;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
|
||||||
|
@ -27,7 +27,7 @@ import java.io.IOException;
|
||||||
* and unmarshalling. Hooks up to the ProtobufMessageBodyConsumer and
|
* and unmarshalling. Hooks up to the ProtobufMessageBodyConsumer and
|
||||||
* ProtobufMessageBodyProducer adapters.
|
* ProtobufMessageBodyProducer adapters.
|
||||||
*/
|
*/
|
||||||
public abstract interface IProtobufWrapper {
|
public abstract interface ProtobufMessageHandler {
|
||||||
/**
|
/**
|
||||||
* @return the protobuf represention of the model
|
* @return the protobuf represention of the model
|
||||||
*/
|
*/
|
||||||
|
@ -39,6 +39,6 @@ public abstract interface IProtobufWrapper {
|
||||||
* @return reference to self for convenience
|
* @return reference to self for convenience
|
||||||
* @throws IOException
|
* @throws IOException
|
||||||
*/
|
*/
|
||||||
public IProtobufWrapper getObjectFromMessage(byte[] message)
|
public ProtobufMessageHandler getObjectFromMessage(byte[] message)
|
||||||
throws IOException;
|
throws IOException;
|
||||||
}
|
}
|
|
@ -29,6 +29,7 @@ import javax.xml.bind.annotation.XmlType;
|
||||||
import javax.xml.bind.annotation.XmlValue;
|
import javax.xml.bind.annotation.XmlValue;
|
||||||
|
|
||||||
import org.apache.hadoop.hbase.HConstants;
|
import org.apache.hadoop.hbase.HConstants;
|
||||||
|
import org.apache.hadoop.hbase.stargate.ProtobufMessageHandler;
|
||||||
import org.apache.hadoop.hbase.stargate.protobuf.generated.CellMessage.Cell;
|
import org.apache.hadoop.hbase.stargate.protobuf.generated.CellMessage.Cell;
|
||||||
|
|
||||||
import com.google.protobuf.ByteString;
|
import com.google.protobuf.ByteString;
|
||||||
|
@ -37,10 +38,24 @@ import com.google.protobuf.ByteString;
|
||||||
* Representation of a cell. A cell is a single value associated a column and
|
* Representation of a cell. A cell is a single value associated a column and
|
||||||
* optional qualifier, and either the timestamp when it was stored or the user-
|
* optional qualifier, and either the timestamp when it was stored or the user-
|
||||||
* provided timestamp if one was explicitly supplied.
|
* provided timestamp if one was explicitly supplied.
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* <complexType name="Cell">
|
||||||
|
* <sequence>
|
||||||
|
* <element name="value" maxOccurs="1" minOccurs="1">
|
||||||
|
* <simpleType>
|
||||||
|
* <restriction base="base64Binary"/>
|
||||||
|
* </simpleType>
|
||||||
|
* </element>
|
||||||
|
* </sequence>
|
||||||
|
* <attribute name="column" type="base64Binary" />
|
||||||
|
* <attribute name="timestamp" type="int" />
|
||||||
|
* </complexType>
|
||||||
|
* </pre>
|
||||||
*/
|
*/
|
||||||
@XmlRootElement(name="Cell")
|
@XmlRootElement(name="Cell")
|
||||||
@XmlType(propOrder={"column","timestamp"})
|
@XmlType(propOrder={"column","timestamp"})
|
||||||
public class CellModel implements IProtobufWrapper, Serializable {
|
public class CellModel implements ProtobufMessageHandler, Serializable {
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
private long timestamp;
|
private long timestamp;
|
||||||
|
@ -138,7 +153,7 @@ public class CellModel implements IProtobufWrapper, Serializable {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IProtobufWrapper getObjectFromMessage(byte[] message)
|
public ProtobufMessageHandler getObjectFromMessage(byte[] message)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
Cell.Builder builder = Cell.newBuilder();
|
Cell.Builder builder = Cell.newBuilder();
|
||||||
builder.mergeFrom(message);
|
builder.mergeFrom(message);
|
||||||
|
|
|
@ -29,6 +29,7 @@ import javax.xml.bind.annotation.XmlRootElement;
|
||||||
import javax.xml.bind.annotation.XmlElement;
|
import javax.xml.bind.annotation.XmlElement;
|
||||||
|
|
||||||
import org.apache.hadoop.hbase.HConstants;
|
import org.apache.hadoop.hbase.HConstants;
|
||||||
|
import org.apache.hadoop.hbase.stargate.ProtobufMessageHandler;
|
||||||
import org.apache.hadoop.hbase.stargate.protobuf.generated.CellMessage.Cell;
|
import org.apache.hadoop.hbase.stargate.protobuf.generated.CellMessage.Cell;
|
||||||
import org.apache.hadoop.hbase.stargate.protobuf.generated.CellSetMessage.CellSet;
|
import org.apache.hadoop.hbase.stargate.protobuf.generated.CellSetMessage.CellSet;
|
||||||
|
|
||||||
|
@ -37,9 +38,38 @@ import com.google.protobuf.ByteString;
|
||||||
/**
|
/**
|
||||||
* Representation of a grouping of cells. May contain cells from more than
|
* Representation of a grouping of cells. May contain cells from more than
|
||||||
* one row. Encapsulates RowModel and CellModel models.
|
* one row. Encapsulates RowModel and CellModel models.
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* <complexType name="CellSet">
|
||||||
|
* <sequence>
|
||||||
|
* <element name="row" type="tns:Row" maxOccurs="unbounded"
|
||||||
|
* minOccurs="1"></element>
|
||||||
|
* </sequence>
|
||||||
|
* </complexType>
|
||||||
|
*
|
||||||
|
* <complexType name="Row">
|
||||||
|
* <sequence>
|
||||||
|
* <element name="key" type="base64Binary"></element>
|
||||||
|
* <element name="cell" type="tns:Cell"
|
||||||
|
* maxOccurs="unbounded" minOccurs="1"></element>
|
||||||
|
* </sequence>
|
||||||
|
* </complexType>
|
||||||
|
*
|
||||||
|
* <complexType name="Cell">
|
||||||
|
* <sequence>
|
||||||
|
* <element name="value" maxOccurs="1" minOccurs="1">
|
||||||
|
* <simpleType>
|
||||||
|
* <restriction base="base64Binary"/>
|
||||||
|
* </simpleType>
|
||||||
|
* </element>
|
||||||
|
* </sequence>
|
||||||
|
* <attribute name="column" type="base64Binary" />
|
||||||
|
* <attribute name="timestamp" type="int" />
|
||||||
|
* </complexType>
|
||||||
|
* </pre>
|
||||||
*/
|
*/
|
||||||
@XmlRootElement(name="CellSet")
|
@XmlRootElement(name="CellSet")
|
||||||
public class CellSetModel implements Serializable, IProtobufWrapper {
|
public class CellSetModel implements Serializable, ProtobufMessageHandler {
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
@ -97,7 +127,7 @@ public class CellSetModel implements Serializable, IProtobufWrapper {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IProtobufWrapper getObjectFromMessage(byte[] message)
|
public ProtobufMessageHandler getObjectFromMessage(byte[] message)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
CellSet.Builder builder = CellSet.newBuilder();
|
CellSet.Builder builder = CellSet.newBuilder();
|
||||||
builder.mergeFrom(message);
|
builder.mergeFrom(message);
|
||||||
|
|
|
@ -35,6 +35,13 @@ import org.apache.hadoop.hbase.HConstants;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Representation of a column family schema.
|
* Representation of a column family schema.
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* <complexType name="ColumnSchema">
|
||||||
|
* <attribute name="name" type="string"></attribute>
|
||||||
|
* <anyAttribute></anyAttribute>
|
||||||
|
* </complexType>
|
||||||
|
* </pre>
|
||||||
*/
|
*/
|
||||||
@XmlRootElement(name="ColumnSchema")
|
@XmlRootElement(name="ColumnSchema")
|
||||||
@XmlType(propOrder = {"name"})
|
@XmlType(propOrder = {"name"})
|
||||||
|
|
|
@ -0,0 +1,133 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<schema targetNamespace="ModelSchema" elementFormDefault="qualified" xmlns="http://www.w3.org/2001/XMLSchema" xmlns:tns="ModelSchema">
|
||||||
|
|
||||||
|
<element name="CellSet" type="tns:CellSet"></element>
|
||||||
|
|
||||||
|
<complexType name="CellSet">
|
||||||
|
<sequence>
|
||||||
|
<element name="row" type="tns:Row" maxOccurs="unbounded" minOccurs="1"></element>
|
||||||
|
</sequence>
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
<complexType name="Row">
|
||||||
|
<sequence>
|
||||||
|
<element name="key" type="base64Binary"></element>
|
||||||
|
<element name="cell" type="tns:Cell" maxOccurs="unbounded" minOccurs="1"></element>
|
||||||
|
</sequence>
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
<complexType name="Cell">
|
||||||
|
<sequence>
|
||||||
|
<element name="value" maxOccurs="1" minOccurs="1"><simpleType><restriction base="base64Binary"></restriction></simpleType></element>
|
||||||
|
</sequence>
|
||||||
|
<attribute name="column" type="base64Binary" />
|
||||||
|
<attribute name="timestamp" type="int" />
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
<element name="Version" type="tns:Version"></element>
|
||||||
|
|
||||||
|
<complexType name="Version">
|
||||||
|
<attribute name="Stargate" type="string"></attribute>
|
||||||
|
<attribute name="JVM" type="string"></attribute>
|
||||||
|
<attribute name="OS" type="string"></attribute>
|
||||||
|
<attribute name="Server" type="string"></attribute>
|
||||||
|
<attribute name="Jersey" type="string"></attribute>
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
|
||||||
|
<element name="TableList" type="tns:TableList"></element>
|
||||||
|
|
||||||
|
<complexType name="TableList">
|
||||||
|
<sequence>
|
||||||
|
<element name="table" type="tns:Table" maxOccurs="unbounded" minOccurs="1"></element>
|
||||||
|
</sequence>
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
<complexType name="Table">
|
||||||
|
<sequence>
|
||||||
|
<element name="name" type="string"></element>
|
||||||
|
</sequence>
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
<element name="TableInfo" type="tns:TableInfo"></element>
|
||||||
|
|
||||||
|
<complexType name="TableInfo">
|
||||||
|
<sequence>
|
||||||
|
<element name="region" type="tns:TableRegion" maxOccurs="unbounded" minOccurs="1"></element>
|
||||||
|
</sequence>
|
||||||
|
<attribute name="name" type="string"></attribute>
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
<complexType name="TableRegion">
|
||||||
|
<attribute name="name" type="string"></attribute>
|
||||||
|
<attribute name="id" type="int"></attribute>
|
||||||
|
<attribute name="startKey" type="base64Binary"></attribute>
|
||||||
|
<attribute name="endKey" type="base64Binary"></attribute>
|
||||||
|
<attribute name="location" type="string"></attribute>
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
<element name="TableSchema" type="tns:TableSchema"></element>
|
||||||
|
|
||||||
|
<complexType name="TableSchema">
|
||||||
|
<sequence>
|
||||||
|
<element name="column" type="tns:ColumnSchema" maxOccurs="unbounded" minOccurs="1"></element>
|
||||||
|
</sequence>
|
||||||
|
<attribute name="name" type="string"></attribute>
|
||||||
|
<anyAttribute></anyAttribute>
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
<complexType name="ColumnSchema">
|
||||||
|
<attribute name="name" type="string"></attribute>
|
||||||
|
<anyAttribute></anyAttribute>
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
<element name="Scanner" type="tns:Scanner"></element>
|
||||||
|
|
||||||
|
<complexType name="Scanner">
|
||||||
|
<attribute name="startRow" type="base64Binary"></attribute>
|
||||||
|
<attribute name="endRow" type="base64Binary"></attribute>
|
||||||
|
<attribute name="columns" type="base64Binary"></attribute>
|
||||||
|
<attribute name="batch" type="int"></attribute>
|
||||||
|
<attribute name="startTime" type="int"></attribute>
|
||||||
|
<attribute name="endTime" type="int"></attribute>
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
<element name="StorageClusterVersion"
|
||||||
|
type="tns:StorageClusterVersion">
|
||||||
|
</element>
|
||||||
|
|
||||||
|
<complexType name="StorageClusterVersion">
|
||||||
|
<attribute name="version" type="string"></attribute>
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
<element name="StorageClusterStatus"
|
||||||
|
type="tns:StorageClusterStatus">
|
||||||
|
</element>
|
||||||
|
|
||||||
|
<complexType name="StorageClusterStatus">
|
||||||
|
<sequence>
|
||||||
|
<element name="liveNode" type="tns:Node"
|
||||||
|
maxOccurs="unbounded" minOccurs="0">
|
||||||
|
</element>
|
||||||
|
<element name="deadNode" type="string" maxOccurs="unbounded"
|
||||||
|
minOccurs="0">
|
||||||
|
</element>
|
||||||
|
</sequence>
|
||||||
|
<attribute name="regions" type="int"></attribute>
|
||||||
|
<attribute name="requests" type="int"></attribute>
|
||||||
|
<attribute name="averageLoad" type="float"></attribute>
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
<complexType name="Node">
|
||||||
|
<sequence>
|
||||||
|
<element name="region" type="tns:Region" maxOccurs="unbounded" minOccurs="0"></element>
|
||||||
|
</sequence>
|
||||||
|
<attribute name="name" type="string"></attribute>
|
||||||
|
<attribute name="startCode" type="int"></attribute>
|
||||||
|
<attribute name="requests" type="int"></attribute>
|
||||||
|
</complexType>
|
||||||
|
|
||||||
|
<complexType name="Region">
|
||||||
|
<attribute name="name" type="base64Binary"></attribute>
|
||||||
|
</complexType>
|
||||||
|
</schema>
|
|
@ -29,13 +29,25 @@ import javax.xml.bind.annotation.XmlAttribute;
|
||||||
import javax.xml.bind.annotation.XmlElement;
|
import javax.xml.bind.annotation.XmlElement;
|
||||||
import javax.xml.bind.annotation.XmlRootElement;
|
import javax.xml.bind.annotation.XmlRootElement;
|
||||||
|
|
||||||
|
import org.apache.hadoop.hbase.stargate.ProtobufMessageHandler;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Representation of a row. A row is a related set of cells, grouped by common
|
* Representation of a row. A row is a related set of cells, grouped by common
|
||||||
* row key. RowModels do not appear in results by themselves. They are always
|
* row key. RowModels do not appear in results by themselves. They are always
|
||||||
* encapsulated within CellSetModels.
|
* encapsulated within CellSetModels.
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* <complexType name="Row">
|
||||||
|
* <sequence>
|
||||||
|
* <element name="key" type="base64Binary"></element>
|
||||||
|
* <element name="cell" type="tns:Cell"
|
||||||
|
* maxOccurs="unbounded" minOccurs="1"></element>
|
||||||
|
* </sequence>
|
||||||
|
* </complexType>
|
||||||
|
* </pre>
|
||||||
*/
|
*/
|
||||||
@XmlRootElement(name="Row")
|
@XmlRootElement(name="Row")
|
||||||
public class RowModel implements IProtobufWrapper, Serializable {
|
public class RowModel implements ProtobufMessageHandler, Serializable {
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
private byte[] key;
|
private byte[] key;
|
||||||
|
@ -121,7 +133,7 @@ public class RowModel implements IProtobufWrapper, Serializable {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IProtobufWrapper getObjectFromMessage(byte[] message)
|
public ProtobufMessageHandler getObjectFromMessage(byte[] message)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
// there is no standalone row protobuf message
|
// there is no standalone row protobuf message
|
||||||
throw new UnsupportedOperationException(
|
throw new UnsupportedOperationException(
|
||||||
|
|
|
@ -29,6 +29,7 @@ import javax.xml.bind.annotation.XmlAttribute;
|
||||||
import javax.xml.bind.annotation.XmlRootElement;
|
import javax.xml.bind.annotation.XmlRootElement;
|
||||||
|
|
||||||
import org.apache.hadoop.hbase.HConstants;
|
import org.apache.hadoop.hbase.HConstants;
|
||||||
|
import org.apache.hadoop.hbase.stargate.ProtobufMessageHandler;
|
||||||
import org.apache.hadoop.hbase.stargate.protobuf.generated.ScannerMessage.Scanner;
|
import org.apache.hadoop.hbase.stargate.protobuf.generated.ScannerMessage.Scanner;
|
||||||
import org.apache.hadoop.hbase.util.Bytes;
|
import org.apache.hadoop.hbase.util.Bytes;
|
||||||
|
|
||||||
|
@ -36,9 +37,20 @@ import com.google.protobuf.ByteString;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A representation of Scanner parameters.
|
* A representation of Scanner parameters.
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* <complexType name="Scanner">
|
||||||
|
* <attribute name="startRow" type="base64Binary"></attribute>
|
||||||
|
* <attribute name="endRow" type="base64Binary"></attribute>
|
||||||
|
* <attribute name="columns" type="base64Binary"></attribute>
|
||||||
|
* <attribute name="batch" type="int"></attribute>
|
||||||
|
* <attribute name="startTime" type="int"></attribute>
|
||||||
|
* <attribute name="endTime" type="int"></attribute>
|
||||||
|
* </complexType>
|
||||||
|
* </pre>
|
||||||
*/
|
*/
|
||||||
@XmlRootElement(name="Scanner")
|
@XmlRootElement(name="Scanner")
|
||||||
public class ScannerModel implements IProtobufWrapper, Serializable {
|
public class ScannerModel implements ProtobufMessageHandler, Serializable {
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
private byte[] startRow = HConstants.EMPTY_START_ROW;
|
private byte[] startRow = HConstants.EMPTY_START_ROW;
|
||||||
|
@ -223,7 +235,7 @@ public class ScannerModel implements IProtobufWrapper, Serializable {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IProtobufWrapper getObjectFromMessage(byte[] message)
|
public ProtobufMessageHandler getObjectFromMessage(byte[] message)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
Scanner.Builder builder = Scanner.newBuilder();
|
Scanner.Builder builder = Scanner.newBuilder();
|
||||||
builder.mergeFrom(message);
|
builder.mergeFrom(message);
|
||||||
|
|
|
@ -30,6 +30,7 @@ import javax.xml.bind.annotation.XmlElement;
|
||||||
import javax.xml.bind.annotation.XmlElementWrapper;
|
import javax.xml.bind.annotation.XmlElementWrapper;
|
||||||
import javax.xml.bind.annotation.XmlRootElement;
|
import javax.xml.bind.annotation.XmlRootElement;
|
||||||
|
|
||||||
|
import org.apache.hadoop.hbase.stargate.ProtobufMessageHandler;
|
||||||
import org.apache.hadoop.hbase.stargate.protobuf.generated.StorageClusterStatusMessage.StorageClusterStatus;
|
import org.apache.hadoop.hbase.stargate.protobuf.generated.StorageClusterStatusMessage.StorageClusterStatus;
|
||||||
import org.apache.hadoop.hbase.util.Bytes;
|
import org.apache.hadoop.hbase.util.Bytes;
|
||||||
|
|
||||||
|
@ -46,10 +47,40 @@ import com.google.protobuf.ByteString;
|
||||||
* <li>liveNodes: detailed status of the live region servers</li>
|
* <li>liveNodes: detailed status of the live region servers</li>
|
||||||
* <li>deadNodes: the names of region servers declared dead</li>
|
* <li>deadNodes: the names of region servers declared dead</li>
|
||||||
* </ul>
|
* </ul>
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* <complexType name="StorageClusterStatus">
|
||||||
|
* <sequence>
|
||||||
|
* <element name="liveNode" type="tns:Node"
|
||||||
|
* maxOccurs="unbounded" minOccurs="0">
|
||||||
|
* </element>
|
||||||
|
* <element name="deadNode" type="string" maxOccurs="unbounded"
|
||||||
|
* minOccurs="0">
|
||||||
|
* </element>
|
||||||
|
* </sequence>
|
||||||
|
* <attribute name="regions" type="int"></attribute>
|
||||||
|
* <attribute name="requests" type="int"></attribute>
|
||||||
|
* <attribute name="averageLoad" type="float"></attribute>
|
||||||
|
* </complexType>
|
||||||
|
*
|
||||||
|
* <complexType name="Node">
|
||||||
|
* <sequence>
|
||||||
|
* <element name="region" type="tns:Region"
|
||||||
|
* maxOccurs="unbounded" minOccurs="0"></element>
|
||||||
|
* </sequence>
|
||||||
|
* <attribute name="name" type="string"></attribute>
|
||||||
|
* <attribute name="startCode" type="int"></attribute>
|
||||||
|
* <attribute name="requests" type="int"></attribute>
|
||||||
|
* </complexType>
|
||||||
|
*
|
||||||
|
* <complexType name="Region">
|
||||||
|
* <attribute name="name" type="base64Binary"></attribute>
|
||||||
|
* </complexType>
|
||||||
|
* </pre>
|
||||||
*/
|
*/
|
||||||
@XmlRootElement(name="ClusterStatus")
|
@XmlRootElement(name="ClusterStatus")
|
||||||
public class StorageClusterStatusModel
|
public class StorageClusterStatusModel
|
||||||
implements Serializable, IProtobufWrapper {
|
implements Serializable, ProtobufMessageHandler {
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -382,7 +413,7 @@ public class StorageClusterStatusModel
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IProtobufWrapper getObjectFromMessage(byte[] message)
|
public ProtobufMessageHandler getObjectFromMessage(byte[] message)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
StorageClusterStatus.Builder builder = StorageClusterStatus.newBuilder();
|
StorageClusterStatus.Builder builder = StorageClusterStatus.newBuilder();
|
||||||
builder.mergeFrom(message);
|
builder.mergeFrom(message);
|
||||||
|
|
|
@ -26,7 +26,13 @@ import javax.xml.bind.annotation.XmlRootElement;
|
||||||
import javax.xml.bind.annotation.XmlValue;
|
import javax.xml.bind.annotation.XmlValue;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Simple representation of the version of the storage cluster (HBase)
|
* Simple representation of the version of the storage cluster
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* <complexType name="StorageClusterVersion">
|
||||||
|
* <attribute name="version" type="string"></attribute>
|
||||||
|
* </complexType>
|
||||||
|
* </pre>
|
||||||
*/
|
*/
|
||||||
@XmlRootElement(name="ClusterVersion")
|
@XmlRootElement(name="ClusterVersion")
|
||||||
public class StorageClusterVersionModel implements Serializable {
|
public class StorageClusterVersionModel implements Serializable {
|
||||||
|
|
|
@ -30,16 +30,27 @@ import javax.xml.bind.annotation.XmlElement;
|
||||||
import javax.xml.bind.annotation.XmlRootElement;
|
import javax.xml.bind.annotation.XmlRootElement;
|
||||||
import javax.xml.bind.annotation.XmlType;
|
import javax.xml.bind.annotation.XmlType;
|
||||||
|
|
||||||
|
import org.apache.hadoop.hbase.stargate.ProtobufMessageHandler;
|
||||||
import org.apache.hadoop.hbase.stargate.protobuf.generated.TableInfoMessage.TableInfo;
|
import org.apache.hadoop.hbase.stargate.protobuf.generated.TableInfoMessage.TableInfo;
|
||||||
|
|
||||||
import com.google.protobuf.ByteString;
|
import com.google.protobuf.ByteString;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Representation of a list of table regions.
|
* Representation of a list of table regions.
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* <complexType name="TableInfo">
|
||||||
|
* <sequence>
|
||||||
|
* <element name="region" type="tns:TableRegion"
|
||||||
|
* maxOccurs="unbounded" minOccurs="1"></element>
|
||||||
|
* </sequence>
|
||||||
|
* <attribute name="name" type="string"></attribute>
|
||||||
|
* </complexType>
|
||||||
|
* </pre>
|
||||||
*/
|
*/
|
||||||
@XmlRootElement(name="TableInfo")
|
@XmlRootElement(name="TableInfo")
|
||||||
@XmlType(propOrder = {"name","regions"})
|
@XmlType(propOrder = {"name","regions"})
|
||||||
public class TableInfoModel implements Serializable, IProtobufWrapper {
|
public class TableInfoModel implements Serializable, ProtobufMessageHandler {
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
private String name;
|
private String name;
|
||||||
|
@ -134,7 +145,7 @@ public class TableInfoModel implements Serializable, IProtobufWrapper {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IProtobufWrapper getObjectFromMessage(byte[] message)
|
public ProtobufMessageHandler getObjectFromMessage(byte[] message)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
TableInfo.Builder builder = TableInfo.newBuilder();
|
TableInfo.Builder builder = TableInfo.newBuilder();
|
||||||
builder.mergeFrom(message);
|
builder.mergeFrom(message);
|
||||||
|
|
|
@ -28,13 +28,14 @@ import java.util.List;
|
||||||
import javax.xml.bind.annotation.XmlElementRef;
|
import javax.xml.bind.annotation.XmlElementRef;
|
||||||
import javax.xml.bind.annotation.XmlRootElement;
|
import javax.xml.bind.annotation.XmlRootElement;
|
||||||
|
|
||||||
|
import org.apache.hadoop.hbase.stargate.ProtobufMessageHandler;
|
||||||
import org.apache.hadoop.hbase.stargate.protobuf.generated.TableListMessage.TableList;
|
import org.apache.hadoop.hbase.stargate.protobuf.generated.TableListMessage.TableList;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Simple representation of a list of table names.
|
* Simple representation of a list of table names.
|
||||||
*/
|
*/
|
||||||
@XmlRootElement(name="TableList")
|
@XmlRootElement(name="TableList")
|
||||||
public class TableListModel implements Serializable, IProtobufWrapper {
|
public class TableListModel implements Serializable, ProtobufMessageHandler {
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
@ -99,7 +100,7 @@ public class TableListModel implements Serializable, IProtobufWrapper {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IProtobufWrapper getObjectFromMessage(byte[] message)
|
public ProtobufMessageHandler getObjectFromMessage(byte[] message)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
TableList.Builder builder = TableList.newBuilder();
|
TableList.Builder builder = TableList.newBuilder();
|
||||||
builder.mergeFrom(message);
|
builder.mergeFrom(message);
|
||||||
|
|
|
@ -27,6 +27,14 @@ import javax.xml.bind.annotation.XmlRootElement;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Simple representation of a table name.
|
* Simple representation of a table name.
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* <complexType name="Table">
|
||||||
|
* <sequence>
|
||||||
|
* <element name="name" type="string"></element>
|
||||||
|
* </sequence>
|
||||||
|
* </complexType>
|
||||||
|
* </pre>
|
||||||
*/
|
*/
|
||||||
@XmlRootElement(name="table")
|
@XmlRootElement(name="table")
|
||||||
public class TableModel implements Serializable {
|
public class TableModel implements Serializable {
|
||||||
|
|
|
@ -31,6 +31,16 @@ import org.apache.hadoop.hbase.util.Bytes;
|
||||||
/**
|
/**
|
||||||
* Representation of a region of a table and its current location on the
|
* Representation of a region of a table and its current location on the
|
||||||
* storage cluster.
|
* storage cluster.
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* <complexType name="TableRegion">
|
||||||
|
* <attribute name="name" type="string"></attribute>
|
||||||
|
* <attribute name="id" type="int"></attribute>
|
||||||
|
* <attribute name="startKey" type="base64Binary"></attribute>
|
||||||
|
* <attribute name="endKey" type="base64Binary"></attribute>
|
||||||
|
* <attribute name="location" type="string"></attribute>
|
||||||
|
* </complexType>
|
||||||
|
* </pre>
|
||||||
*/
|
*/
|
||||||
@XmlRootElement(name="Region")
|
@XmlRootElement(name="Region")
|
||||||
@XmlType(propOrder = {"name","id","startKey","endKey","location"})
|
@XmlType(propOrder = {"name","id","startKey","endKey","location"})
|
||||||
|
|
|
@ -38,15 +38,27 @@ import javax.xml.namespace.QName;
|
||||||
import org.apache.hadoop.hbase.HColumnDescriptor;
|
import org.apache.hadoop.hbase.HColumnDescriptor;
|
||||||
import org.apache.hadoop.hbase.HConstants;
|
import org.apache.hadoop.hbase.HConstants;
|
||||||
import org.apache.hadoop.hbase.HTableDescriptor;
|
import org.apache.hadoop.hbase.HTableDescriptor;
|
||||||
|
import org.apache.hadoop.hbase.stargate.ProtobufMessageHandler;
|
||||||
import org.apache.hadoop.hbase.stargate.protobuf.generated.ColumnSchemaMessage.ColumnSchema;
|
import org.apache.hadoop.hbase.stargate.protobuf.generated.ColumnSchemaMessage.ColumnSchema;
|
||||||
import org.apache.hadoop.hbase.stargate.protobuf.generated.TableSchemaMessage.TableSchema;
|
import org.apache.hadoop.hbase.stargate.protobuf.generated.TableSchemaMessage.TableSchema;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A representation of HBase table descriptors.
|
* A representation of HBase table descriptors.
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* <complexType name="TableSchema">
|
||||||
|
* <sequence>
|
||||||
|
* <element name="column" type="tns:ColumnSchema"
|
||||||
|
* maxOccurs="unbounded" minOccurs="1"></element>
|
||||||
|
* </sequence>
|
||||||
|
* <attribute name="name" type="string"></attribute>
|
||||||
|
* <anyAttribute></anyAttribute>
|
||||||
|
* </complexType>
|
||||||
|
* </pre>
|
||||||
*/
|
*/
|
||||||
@XmlRootElement(name="TableSchema")
|
@XmlRootElement(name="TableSchema")
|
||||||
@XmlType(propOrder = {"name","columns"})
|
@XmlType(propOrder = {"name","columns"})
|
||||||
public class TableSchemaModel implements Serializable, IProtobufWrapper {
|
public class TableSchemaModel implements Serializable, ProtobufMessageHandler {
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
private static final QName IS_META = new QName(HTableDescriptor.IS_META);
|
private static final QName IS_META = new QName(HTableDescriptor.IS_META);
|
||||||
private static final QName IS_ROOT = new QName(HTableDescriptor.IS_ROOT);
|
private static final QName IS_ROOT = new QName(HTableDescriptor.IS_ROOT);
|
||||||
|
@ -264,7 +276,7 @@ public class TableSchemaModel implements Serializable, IProtobufWrapper {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IProtobufWrapper getObjectFromMessage(byte[] message)
|
public ProtobufMessageHandler getObjectFromMessage(byte[] message)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
TableSchema.Builder builder = TableSchema.newBuilder();
|
TableSchema.Builder builder = TableSchema.newBuilder();
|
||||||
builder.mergeFrom(message);
|
builder.mergeFrom(message);
|
||||||
|
|
|
@ -27,6 +27,7 @@ import javax.servlet.ServletContext;
|
||||||
import javax.xml.bind.annotation.XmlAttribute;
|
import javax.xml.bind.annotation.XmlAttribute;
|
||||||
import javax.xml.bind.annotation.XmlRootElement;
|
import javax.xml.bind.annotation.XmlRootElement;
|
||||||
|
|
||||||
|
import org.apache.hadoop.hbase.stargate.ProtobufMessageHandler;
|
||||||
import org.apache.hadoop.hbase.stargate.RESTServlet;
|
import org.apache.hadoop.hbase.stargate.RESTServlet;
|
||||||
import org.apache.hadoop.hbase.stargate.protobuf.generated.VersionMessage.Version;
|
import org.apache.hadoop.hbase.stargate.protobuf.generated.VersionMessage.Version;
|
||||||
|
|
||||||
|
@ -44,7 +45,7 @@ import com.sun.jersey.spi.container.servlet.ServletContainer;
|
||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
@XmlRootElement(name="Version")
|
@XmlRootElement(name="Version")
|
||||||
public class VersionModel implements Serializable, IProtobufWrapper {
|
public class VersionModel implements Serializable, ProtobufMessageHandler {
|
||||||
|
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
@ -183,7 +184,7 @@ public class VersionModel implements Serializable, IProtobufWrapper {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IProtobufWrapper getObjectFromMessage(byte[] message)
|
public ProtobufMessageHandler getObjectFromMessage(byte[] message)
|
||||||
throws IOException {
|
throws IOException {
|
||||||
Version.Builder builder = Version.newBuilder();
|
Version.Builder builder = Version.newBuilder();
|
||||||
builder.mergeFrom(message);
|
builder.mergeFrom(message);
|
||||||
|
|
|
@ -83,7 +83,6 @@ public class JAXBContextResolver implements ContextResolver<JAXBContext> {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public JAXBContext getContext(Class<?> objectType) {
|
public JAXBContext getContext(Class<?> objectType) {
|
||||||
System.out.println("Executed getContext");
|
|
||||||
return (types.contains(objectType)) ? context : null;
|
return (types.contains(objectType)) ? context : null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,31 +36,31 @@ import javax.ws.rs.ext.Provider;
|
||||||
import org.apache.commons.logging.Log;
|
import org.apache.commons.logging.Log;
|
||||||
import org.apache.commons.logging.LogFactory;
|
import org.apache.commons.logging.LogFactory;
|
||||||
import org.apache.hadoop.hbase.stargate.Constants;
|
import org.apache.hadoop.hbase.stargate.Constants;
|
||||||
import org.apache.hadoop.hbase.stargate.model.IProtobufWrapper;
|
import org.apache.hadoop.hbase.stargate.ProtobufMessageHandler;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adapter for hooking up Jersey content processing dispatch to
|
* Adapter for hooking up Jersey content processing dispatch to
|
||||||
* IProtobufWrapper interface capable handlers for decoding protobuf input.
|
* ProtobufMessageHandler interface capable handlers for decoding protobuf input.
|
||||||
*/
|
*/
|
||||||
@Provider
|
@Provider
|
||||||
@Consumes(Constants.MIMETYPE_PROTOBUF)
|
@Consumes(Constants.MIMETYPE_PROTOBUF)
|
||||||
public class ProtobufMessageBodyConsumer
|
public class ProtobufMessageBodyConsumer
|
||||||
implements MessageBodyReader<IProtobufWrapper> {
|
implements MessageBodyReader<ProtobufMessageHandler> {
|
||||||
private static final Log LOG =
|
private static final Log LOG =
|
||||||
LogFactory.getLog(ProtobufMessageBodyConsumer.class);
|
LogFactory.getLog(ProtobufMessageBodyConsumer.class);
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isReadable(Class<?> type, Type genericType,
|
public boolean isReadable(Class<?> type, Type genericType,
|
||||||
Annotation[] annotations, MediaType mediaType) {
|
Annotation[] annotations, MediaType mediaType) {
|
||||||
return IProtobufWrapper.class.isAssignableFrom(type);
|
return ProtobufMessageHandler.class.isAssignableFrom(type);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public IProtobufWrapper readFrom(Class<IProtobufWrapper> type, Type genericType,
|
public ProtobufMessageHandler readFrom(Class<ProtobufMessageHandler> type, Type genericType,
|
||||||
Annotation[] annotations, MediaType mediaType,
|
Annotation[] annotations, MediaType mediaType,
|
||||||
MultivaluedMap<String, String> httpHeaders, InputStream inputStream)
|
MultivaluedMap<String, String> httpHeaders, InputStream inputStream)
|
||||||
throws IOException, WebApplicationException {
|
throws IOException, WebApplicationException {
|
||||||
IProtobufWrapper obj = null;
|
ProtobufMessageHandler obj = null;
|
||||||
try {
|
try {
|
||||||
obj = type.newInstance();
|
obj = type.newInstance();
|
||||||
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||||
|
|
|
@ -36,10 +36,10 @@ import javax.ws.rs.ext.MessageBodyWriter;
|
||||||
import javax.ws.rs.ext.Provider;
|
import javax.ws.rs.ext.Provider;
|
||||||
|
|
||||||
import org.apache.hadoop.hbase.stargate.Constants;
|
import org.apache.hadoop.hbase.stargate.Constants;
|
||||||
import org.apache.hadoop.hbase.stargate.model.IProtobufWrapper;
|
import org.apache.hadoop.hbase.stargate.ProtobufMessageHandler;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An adapter between Jersey and IProtobufWrapper implementors. Hooks up
|
* An adapter between Jersey and ProtobufMessageHandler implementors. Hooks up
|
||||||
* protobuf output producing methods to the Jersey content handling framework.
|
* protobuf output producing methods to the Jersey content handling framework.
|
||||||
* Jersey will first call getSize() to learn the number of bytes that will be
|
* Jersey will first call getSize() to learn the number of bytes that will be
|
||||||
* sent, then writeTo to perform the actual I/O.
|
* sent, then writeTo to perform the actual I/O.
|
||||||
|
@ -47,18 +47,18 @@ import org.apache.hadoop.hbase.stargate.model.IProtobufWrapper;
|
||||||
@Provider
|
@Provider
|
||||||
@Produces(Constants.MIMETYPE_PROTOBUF)
|
@Produces(Constants.MIMETYPE_PROTOBUF)
|
||||||
public class ProtobufMessageBodyProducer
|
public class ProtobufMessageBodyProducer
|
||||||
implements MessageBodyWriter<IProtobufWrapper> {
|
implements MessageBodyWriter<ProtobufMessageHandler> {
|
||||||
|
|
||||||
private Map<Object, byte[]> buffer = new WeakHashMap<Object, byte[]>();
|
private Map<Object, byte[]> buffer = new WeakHashMap<Object, byte[]>();
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isWriteable(Class<?> type, Type genericType,
|
public boolean isWriteable(Class<?> type, Type genericType,
|
||||||
Annotation[] annotations, MediaType mediaType) {
|
Annotation[] annotations, MediaType mediaType) {
|
||||||
return IProtobufWrapper.class.isAssignableFrom(type);
|
return ProtobufMessageHandler.class.isAssignableFrom(type);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public long getSize(IProtobufWrapper m, Class<?> type, Type genericType,
|
public long getSize(ProtobufMessageHandler m, Class<?> type, Type genericType,
|
||||||
Annotation[] annotations, MediaType mediaType) {
|
Annotation[] annotations, MediaType mediaType) {
|
||||||
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
ByteArrayOutputStream baos = new ByteArrayOutputStream();
|
||||||
try {
|
try {
|
||||||
|
@ -71,7 +71,7 @@ public class ProtobufMessageBodyProducer
|
||||||
return bytes.length;
|
return bytes.length;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void writeTo(IProtobufWrapper m, Class<?> type, Type genericType,
|
public void writeTo(ProtobufMessageHandler m, Class<?> type, Type genericType,
|
||||||
Annotation[] annotations, MediaType mediaType,
|
Annotation[] annotations, MediaType mediaType,
|
||||||
MultivaluedMap<String, Object> httpHeaders, OutputStream entityStream)
|
MultivaluedMap<String, Object> httpHeaders, OutputStream entityStream)
|
||||||
throws IOException, WebApplicationException {
|
throws IOException, WebApplicationException {
|
||||||
|
|
Loading…
Reference in New Issue