本文整理匯總了Java中org.voltdb.exceptions.SerializableException類的典型用法代碼示例。如果您正苦於以下問題:Java SerializableException類的具體用法?Java SerializableException怎麽用?Java SerializableException使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
SerializableException類屬於org.voltdb.exceptions包,在下文中一共展示了SerializableException類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: init
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
public void init(LocalTransaction ts,
Status status,
byte appStatus,
String appStatusString,
VoltTable[] results,
String statusString,
SerializableException e) {
this.txn_id = ts.getTransactionId().longValue();
this.clientHandle = ts.getClientHandle();
this.basePartition = ts.getBasePartition();
this.appStatus = appStatus;
this.appStatusString = appStatusString;
this.restartCounter = ts.getRestartCounter();
this.singlepartition = ts.isPredictSinglePartition();
this.speculative = ts.getSpeculationType();
this.setResults(status, results, statusString, e);
}
示例2: testPrepareShutdownSerializeError
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
/**
* testPrepareShutdownSerializeError
*/
@Test
public void testPrepareShutdownSerializeError() throws Exception {
String errorMsg = "XXXXXXXXX";
Throwable error = null;
try {
throw new RuntimeException(errorMsg);
} catch (Throwable ex) {
error = ex;
}
assertNotNull(error);
SerializableException sError = new SerializableException(error);
ByteBuffer buffer = sError.serializeToBuffer();
buffer.rewind();
ShutdownPrepareRequest.Builder builder = ShutdownPrepareRequest.newBuilder()
.setSenderSite(0)
.setError(ByteString.copyFrom(buffer));
ShutdownPrepareRequest request = builder.build();
assertTrue(request.hasError());
buffer = request.getError().asReadOnlyByteBuffer();
SerializableException clone = SerializableException.deserializeFromBuffer(buffer);
assertTrue(clone.getMessage(), clone.getMessage().contains(errorMsg));
}
示例3: initFromBuffer
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
@Override
public void initFromBuffer(ByteBuffer buf) {
m_executorHSId = buf.getLong();
m_destinationHSId = buf.getLong();
m_txnId = buf.getLong();
m_spHandle = buf.getLong();
m_status = buf.get();
m_dirty = buf.get() == 0 ? false : true;
m_recovering = buf.get() == 0 ? false : true;
m_dependencyCount = buf.getShort();
for (int i = 0; i < m_dependencyCount; i++)
m_dependencyIds.add(buf.getInt());
for (int i = 0; i < m_dependencyCount; i++) {
boolean isNull = buf.get() == 0 ? true : false;
if (isNull) {
m_dependencies.add(null);
} else {
m_dependencies.add(PrivateVoltTableFactory.createVoltTableFromSharedBuffer(buf));
}
}
m_exception = SerializableException.deserializeFromBuffer(buf);
assert(buf.capacity() == buf.position());
}
示例4: shutdownPrepare
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
@Override
public void shutdownPrepare(RpcController controller, ShutdownPrepareRequest request, RpcCallback<ShutdownPrepareResponse> done) {
String originName = HStoreThreadManager.formatSiteName(request.getSenderSite());
// See if they gave us the original error. If they did, then we'll
// try to be helpful and print it out here
SerializableException error = null;
if (request.hasError() && request.getError().isEmpty() == false) {
error = SerializableException.deserializeFromBuffer(request.getError().asReadOnlyByteBuffer());
}
LOG.warn(String.format("Got %s from %s [hasError=%s]%s",
request.getClass().getSimpleName(), originName, (error != null),
(error != null ? "\n" + error : "")));
// Tell the HStoreSite to prepare to shutdown
HStoreCoordinator.this.hstore_site.prepareShutdown(request.hasError());
ThreadUtil.sleep(5000);
// Then send back the acknowledgment that we're good to go
ShutdownPrepareResponse response = ShutdownPrepareResponse.newBuilder()
.setSenderSite(HStoreCoordinator.this.local_site_id)
.build();
done.run(response);
LOG.warn(String.format("Sent %s back to %s",
response.getClass().getSimpleName(), originName));
}
示例5: setPendingError
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
/**
* Set the Exception that is causing this txn to abort. It will need
* to be processed later on.
* This is a thread-safe operation. Only the first error will be stored.
* @param error
*/
public synchronized void setPendingError(SerializableException error) {
assert(error != null) : "Trying to set a null error for txn #" + this.txn_id;
if (this.pending_error == null) {
if (debug.val)
LOG.warn(String.format("%s - Got %s error for txn: %s",
this, error.getClass().getSimpleName(), error.getMessage()));
this.pending_error = error;
}
}
示例6: throwExceptionForError
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
/** Utility method to throw a Runtime exception based on the error code and serialized exception **/
@Override
final protected void throwExceptionForError(final int errorCode) throws RuntimeException {
exceptionBuffer.clear();
final int exceptionLength = exceptionBuffer.getInt();
if (exceptionLength == 0) {
throw new EEException(errorCode);
} else {
exceptionBuffer.position(0);
exceptionBuffer.limit(4 + exceptionLength);
throw SerializableException.deserializeFromBuffer(exceptionBuffer);
}
}
示例7: getErrorResponse
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
protected ClientResponseImpl getErrorResponse(byte status, String msg, SerializableException e) {
return new ClientResponseImpl(
status,
m_appStatusCode,
m_appStatusString,
new VoltTable[0],
"VOLTDB ERROR: " + msg);
}
示例8: prepareShutdownCluster
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
protected void prepareShutdownCluster(final Throwable error) throws Exception {
final CountDownLatch latch = new CountDownLatch(this.num_sites-1);
if (this.num_sites > 1) {
RpcCallback<ShutdownPrepareResponse> callback = new ShutdownPrepareCallback(this.num_sites, latch);
ShutdownPrepareRequest.Builder builder = ShutdownPrepareRequest.newBuilder()
.setSenderSite(this.catalog_site.getId());
// Pack the error into a SerializableException
if (error != null) {
SerializableException sError = new SerializableException(error);
ByteBuffer buffer = sError.serializeToBuffer();
buffer.rewind();
builder.setError(ByteString.copyFrom(buffer));
if (debug.val)
LOG.debug("Serializing error message in shutdown request");
}
ShutdownPrepareRequest request = builder.build();
if (debug.val)
LOG.debug(String.format("Sending %s to %d remote sites",
request.getClass().getSimpleName(), this.num_sites-1));
for (int site_id = 0; site_id < this.num_sites; site_id++) {
if (site_id == this.local_site_id) continue;
if (this.channels[site_id] == null) {
LOG.error(String.format("Trying to send %s to %s before the connection was established",
request.getClass().getSimpleName(),
HStoreThreadManager.formatSiteName(site_id)));
} else {
this.channels[site_id].shutdownPrepare(new ProtoRpcController(), request, callback);
if (trace.val)
LOG.trace(String.format("Sent %s to %s",
request.getClass().getSimpleName(),
HStoreThreadManager.formatSiteName(site_id)));
}
} // FOR
}
// Tell ourselves to get ready
this.hstore_site.prepareShutdown(error != null);
// Block until the latch releases us
if (this.num_sites > 1) {
LOG.info(String.format("Waiting for %d sites to finish shutting down", latch.getCount()));
boolean result = latch.await(10, TimeUnit.SECONDS);
if (result == false) {
LOG.warn("Failed to recieve all shutdown responses");
}
}
}
示例9: setPendingError
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
@Override
public void setPendingError(SerializableException error) {
this.setPendingError(error, true);
}
示例10: ClientResponseImpl
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
public ClientResponseImpl(long txn_id, long client_handle, int basePartition, Status status, byte appStatus, String appStatusString, VoltTable[] results, String statusString, SerializableException e) {
this.init(txn_id, client_handle, basePartition, status, appStatus, appStatusString, results, statusString, e);
}
示例11: setResults
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
private void setResults(Status status, VoltTable[] results, String extra, SerializableException e) {
m_exception = e;
setResults(status, results, extra);
}
示例12: getException
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
public SerializableException getException() {
return m_exception;
}
示例13: readExternal
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
@Override
public void readExternal(FastDeserializer in) throws IOException {
in.readByte();//Skip version byte // 1 byte
this.restartCounter = in.readByte(); // 1 byte
this.txn_id = in.readLong(); // 8 bytes
this.clientHandle = in.readLong(); // 8 bytes
this.singlepartition = in.readBoolean(); // 1 byte
this.basePartition = in.readInt(); // 4 bytes
this.speculative = SpeculationType.get(in.readByte()); // 1 byte
this.status = Status.valueOf(in.readByte()); // 1 byte
byte presentFields = in.readByte(); // 1 byte
if ((presentFields & (1 << 5)) != 0) {
statusString = in.readString();
} else {
statusString = null;
}
appStatus = in.readByte();
if ((presentFields & (1 << 7)) != 0) {
appStatusString = in.readString();
} else {
appStatusString = null;
}
clusterRoundTripTime = in.readInt();
if ((presentFields & (1 << 6)) != 0) {
m_exception = SerializableException.deserializeFromBuffer(in.buffer());
} else {
m_exception = null;
}
results = (VoltTable[]) in.readArray(VoltTable.class);
setProperly = true;
if (in.readBoolean()) {
this.debug = new ClientResponseDebug();
this.debug.readExternal(in);
}
// added by hawk, 2013/11/5
// String[] proArr = (String[]) in.readArray(String.class);
// for(int i=0;i<proArr.length;i++)
// followingProcedures.add(proArr[i]);
// if ((presentFields & (1 << 4)) != 0) {
// m_exception = SerializableException.deserializeFromBuffer(in.buffer());
// } else {
// m_exception = null;
// }
this.initiateTime = in.readLong();
this.batchId = in.readLong();
// ended by hawk
}
示例14: run
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
@Override
public void run() {
rejoinLog.trace("Starting ack receiver thread");
try {
while (true) {
rejoinLog.trace("Blocking on receiving mailbox");
VoltMessage msg = m_mb.recvBlocking(10 * 60 * 1000); // Wait for 10 minutes
if (msg == null) {
rejoinLog.warn("No stream snapshot ack message was received in the past 10 minutes" +
" or the thread was interrupted (expected eofs: " + m_expectedEOFs.get() + ")" );
continue;
}
// TestMidRejoinDeath ignores acks to trigger the watchdog
if (StreamSnapshotDataTarget.m_rejoinDeathTestMode && (m_msgFactory.getAckTargetId(msg) == 1)) {
continue;
}
SerializableException se = m_msgFactory.getException(msg);
if (se != null) {
m_lastException = se;
rejoinLog.error("Received exception in ack receiver", se);
return;
}
AckCallback ackCallback = m_callbacks.get(m_msgFactory.getAckTargetId(msg));
if (ackCallback == null) {
rejoinLog.error("Unknown target ID " + m_msgFactory.getAckTargetId(msg) +
" in stream snapshot ack message");
} else if (m_msgFactory.getAckBlockIndex(msg) != -1) {
ackCallback.receiveAck(m_msgFactory.getAckBlockIndex(msg));
}
if (m_msgFactory.isAckEOS(msg)) {
// EOS message indicates end of stream.
// The receiver is shared by multiple data targets, each of them will
// send an end of stream message, must wait until all end of stream
// messages are received before terminating the thread.
if (m_expectedEOFs.decrementAndGet() == 0) {
return;
}
}
}
} catch (Exception e) {
m_lastException = e;
rejoinLog.error("Error reading a message from a recovery stream", e);
} finally {
rejoinLog.trace("Ack receiver thread exiting");
}
}
示例15: getException
import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
@Override
public SerializableException getException(VoltMessage msg)
{
return null;
}