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


Java MessagingException類代碼示例

本文整理匯總了Java中org.onosproject.store.cluster.messaging.MessagingException的典型用法代碼示例。如果您正苦於以下問題:Java MessagingException類的具體用法?Java MessagingException怎麽用?Java MessagingException使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


MessagingException類屬於org.onosproject.store.cluster.messaging包,在下文中一共展示了MessagingException類的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: sendAndReceive

import org.onosproject.store.cluster.messaging.MessagingException; //導入依賴的package包/類
protected <T, U> CompletableFuture<U> sendAndReceive(MessageSubject subject, T request, MemberId memberId) {
    CompletableFuture<U> future = new CompletableFuture<>();
    clusterCommunicator.<T, U>sendAndReceive(
            request, subject, serializer::encode, serializer::decode, NodeId.nodeId(memberId.id()))
            .whenComplete((result, error) -> {
                if (error == null) {
                    future.complete(result);
                } else {
                    if (error instanceof CompletionException) {
                        error = error.getCause();
                    }
                    if (error instanceof MessagingException.NoRemoteHandler) {
                        error = new ConnectException(error.getMessage());
                    } else if (error instanceof MessagingException.RemoteHandlerFailure
                            || error instanceof MessagingException.ProtocolException) {
                        error = new RaftException.ProtocolException(error.getMessage());
                    }
                    future.completeExceptionally(error);
                }
            });
    return future;
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:23,代碼來源:RaftCommunicator.java

示例2: addSubscriber

import org.onosproject.store.cluster.messaging.MessagingException; //導入依賴的package包/類
@Override
public <M, R> void addSubscriber(
        MessageSubject subject,
        Function<byte[], M> decoder,
        Function<M, R> handler,
        Function<R, byte[]> encoder,
        Executor executor) {
    subscribers.put(subject, message -> {
        CompletableFuture<byte[]> future = new CompletableFuture<>();
        executor.execute(() -> {
            try {
                future.complete(encoder.apply(handler.apply(decoder.apply(message))));
            } catch (Exception e) {
                future.completeExceptionally(new MessagingException.RemoteHandlerFailure());
            }
        });
        return future;
    });
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:20,代碼來源:TestClusterCommunicationService.java

示例3: dispatch

import org.onosproject.store.cluster.messaging.MessagingException; //導入依賴的package包/類
/**
 * Dispatches a message to a local handler.
 *
 * @param message the message to dispatch
 */
private void dispatch(InternalReply message) {
    if (message.preamble() != preamble) {
        log.debug("Received {} with invalid preamble", message.type());
        return;
    }

    clockService.recordEventTime(message.time());

    Callback callback = completeCallback(message.id());
    if (callback != null) {
        if (message.status() == InternalReply.Status.OK) {
            callback.complete(message.payload());
        } else if (message.status() == InternalReply.Status.ERROR_NO_HANDLER) {
            callback.completeExceptionally(new MessagingException.NoRemoteHandler());
        } else if (message.status() == InternalReply.Status.ERROR_HANDLER_EXCEPTION) {
            callback.completeExceptionally(new MessagingException.RemoteHandlerFailure());
        } else if (message.status() == InternalReply.Status.PROTOCOL_EXCEPTION) {
            callback.completeExceptionally(new MessagingException.ProtocolException());
        }
    } else {
        log.debug("Received a reply for message id:[{}] "
                + "but was unable to locate the"
                + " request handle", message.id());
    }
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:31,代碼來源:NettyMessagingManager.java

示例4: sendAndReceive

import org.onosproject.store.cluster.messaging.MessagingException; //導入依賴的package包/類
@Override
public <M, R> CompletableFuture<R> sendAndReceive(
        M message,
        MessageSubject subject,
        Function<M, byte[]> encoder,
        Function<byte[], R> decoder,
        NodeId toNodeId) {
    TestClusterCommunicationService node = nodes.get(toNodeId);
    if (node == null) {
        return Futures.exceptionalFuture(new MessagingException.NoRemoteHandler());
    }
    return node.handle(subject, encoder.apply(message)).thenApply(decoder);
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:14,代碼來源:TestClusterCommunicationService.java

示例5: handle

import org.onosproject.store.cluster.messaging.MessagingException; //導入依賴的package包/類
private CompletableFuture<byte[]> handle(MessageSubject subject, byte[] message) {
    Function<byte[], CompletableFuture<byte[]>> subscriber = subscribers.get(subject);
    if (subscriber != null) {
        return subscriber.apply(message);
    }
    return Futures.exceptionalFuture(new MessagingException.NoRemoteHandler());
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:8,代碼來源:TestClusterCommunicationService.java

示例6: reply

import org.onosproject.store.cluster.messaging.MessagingException; //導入依賴的package包/類
@Override
public void reply(InternalRequest message, InternalReply.Status status, Optional<byte[]> payload) {
    if (future != null) {
        if (status == InternalReply.Status.OK) {
            future.complete(payload.orElse(EMPTY_PAYLOAD));
        } else if (status == InternalReply.Status.ERROR_NO_HANDLER) {
            future.completeExceptionally(new MessagingException.NoRemoteHandler());
        } else if (status == InternalReply.Status.ERROR_HANDLER_EXCEPTION) {
            future.completeExceptionally(new MessagingException.RemoteHandlerFailure());
        } else if (status == InternalReply.Status.PROTOCOL_EXCEPTION) {
            future.completeExceptionally(new MessagingException.ProtocolException());
        }
    }
}
 
開發者ID:opennetworkinglab,項目名稱:onos,代碼行數:15,代碼來源:NettyMessagingManager.java


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