當前位置: 首頁>>代碼示例>>Java>>正文


Java SerializableException類代碼示例

本文整理匯總了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);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:18,代碼來源:ClientResponseImpl.java

示例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));
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:28,代碼來源:TestHStoreCoordinator.java

示例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());
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:24,代碼來源:FragmentResponseMessage.java

示例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));
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:28,代碼來源:HStoreCoordinator.java

示例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;
    }
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:16,代碼來源:AbstractTransaction.java

示例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);
    }
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:15,代碼來源:ExecutionEngineJNI.java

示例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);
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:9,代碼來源:ProcedureRunner.java

示例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");
        }
    }
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:51,代碼來源:HStoreCoordinator.java

示例9: setPendingError

import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
@Override
public void setPendingError(SerializableException error) {
    this.setPendingError(error, true);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:5,代碼來源:LocalTransaction.java

示例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);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:4,代碼來源:ClientResponseImpl.java

示例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);
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:5,代碼來源:ClientResponseImpl.java

示例12: getException

import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
public SerializableException getException() {
    return m_exception;
}
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:4,代碼來源:ClientResponseImpl.java

示例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
    }
 
開發者ID:s-store,項目名稱:sstore-soft,代碼行數:53,代碼來源:ClientResponseImpl.java

示例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");
    }
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:52,代碼來源:StreamSnapshotAckReceiver.java

示例15: getException

import org.voltdb.exceptions.SerializableException; //導入依賴的package包/類
@Override
public  SerializableException getException(VoltMessage msg)
{
    return null;
}
 
開發者ID:anhnv-3991,項目名稱:VoltDB,代碼行數:6,代碼來源:StreamSnapshotBase.java


注:本文中的org.voltdb.exceptions.SerializableException類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。