当前位置: 首页>>代码示例>>Java>>正文


Java StreamMessage类代码示例

本文整理汇总了Java中org.apache.cassandra.streaming.messages.StreamMessage的典型用法代码示例。如果您正苦于以下问题:Java StreamMessage类的具体用法?Java StreamMessage怎么用?Java StreamMessage使用的例子?那么恭喜您, 这里精选的类代码示例或许可以为您提供帮助。


StreamMessage类属于org.apache.cassandra.streaming.messages包,在下文中一共展示了StreamMessage类的14个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。

示例1: run

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
@Override
public void run()
{
    try
    {
        // streaming connections are per-session and have a fixed version.  we can't do anything with a wrong-version stream connection, so drop it.
        if (version != StreamMessage.CURRENT_VERSION)
            throw new IOException(String.format("Received stream using protocol version %d (my version %d). Terminating connection", version, MessagingService.current_version));

        DataInput input = new DataInputStream(socket.getInputStream());
        StreamInitMessage init = StreamInitMessage.serializer.deserialize(input, version);

        // The initiator makes two connections, one for incoming and one for outgoing.
        // The receiving side distinguish two connections by looking at StreamInitMessage#isForOutgoing.
        // Note: we cannot use the same socket for incoming and outgoing streams because we want to
        // parallelize said streams and the socket is blocking, so we might deadlock.
        StreamResultFuture.initReceivingSide(init.sessionIndex, init.planId, init.description, init.from, socket, init.isForOutgoing, version);
    }
    catch (IOException e)
    {
        logger.debug("IOException reading from socket; closing", e);
        try
        {
            socket.close();
        }
        catch (IOException e2)
        {
            logger.debug("error closing socket", e2);
        }
    }
}
 
开发者ID:vcostet,项目名称:cassandra-kmean,代码行数:32,代码来源:IncomingStreamingConnection.java

示例2: initiate

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
/**
 * Set up incoming message handler and initiate streaming.
 *
 * This method is called once on initiator.
 *
 * @throws IOException
 */
public void initiate() throws IOException
{
    logger.debug("[Stream #{}] Sending stream init for incoming stream", session.planId());
    Socket incomingSocket = session.createConnection();
    incoming.start(incomingSocket, StreamMessage.CURRENT_VERSION);
    incoming.sendInitMessage(incomingSocket, true);

    logger.debug("[Stream #{}] Sending stream init for outgoing stream", session.planId());
    Socket outgoingSocket = session.createConnection();
    outgoing.start(outgoingSocket, StreamMessage.CURRENT_VERSION);
    outgoing.sendInitMessage(outgoingSocket, false);
}
 
开发者ID:vcostet,项目名称:cassandra-kmean,代码行数:20,代码来源:ConnectionHandler.java

示例3: sendMessage

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
public void sendMessage(StreamMessage message)
{
    if (outgoing.isClosed())
        throw new RuntimeException("Outgoing stream handler has been closed");

    outgoing.enqueue(message);
}
 
开发者ID:vcostet,项目名称:cassandra-kmean,代码行数:8,代码来源:ConnectionHandler.java

示例4: run

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
public void run()
{
    try
    {
        ReadableByteChannel in = getReadChannel(socket);
        while (!isClosed())
        {
            // receive message
            StreamMessage message = StreamMessage.deserialize(in, protocolVersion, session);
            // Might be null if there is an error during streaming (see FileMessage.deserialize). It's ok
            // to ignore here since we'll have asked for a retry.
            if (message != null)
            {
                logger.debug("[Stream #{}] Received {}", session.planId(), message);
                session.messageReceived(message);
            }
        }
    }
    catch (SocketException e)
    {
        // socket is closed
        close();
    }
    catch (Throwable t)
    {
        JVMStabilityInspector.inspectThrowable(t);
        session.onError(t);
    }
    finally
    {
        signalCloseDone();
    }
}
 
开发者ID:vcostet,项目名称:cassandra-kmean,代码行数:34,代码来源:ConnectionHandler.java

示例5: run

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
@Override
public void run()
{
    try
    {
        // streaming connections are per-session and have a fixed version.  we can't do anything with a wrong-version stream connection, so drop it.
        if (version != StreamMessage.CURRENT_VERSION)
            throw new IOException(String.format("Received stream using protocol version %d (my version %d). Terminating connection", version, MessagingService.current_version));

        DataInput input = new DataInputStream(socket.getInputStream());
        StreamInitMessage init = StreamInitMessage.serializer.deserialize(input, version);

        // The initiator makes two connections, one for incoming and one for outgoing.
        // The receiving side distinguish two connections by looking at StreamInitMessage#isForOutgoing.
        // Note: we cannot use the same socket for incoming and outgoing streams because we want to
        // parallelize said streams and the socket is blocking, so we might deadlock.
        StreamResultFuture.initReceivingSide(init.planId, init.description, init.from, socket, init.isForOutgoing, version);
    }
    catch (IOException e)
    {
        logger.debug("IOException reading from socket; closing", e);
        try
        {
            socket.close();
        }
        catch (IOException e2)
        {
            logger.debug("error closing socket", e2);
        }
    }
}
 
开发者ID:pgaref,项目名称:ACaZoo,代码行数:32,代码来源:IncomingStreamingConnection.java

示例6: initiate

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
/**
 * Set up incoming message handler and initiate streaming.
 *
 * This method is called once on initiator.
 *
 * @throws IOException
 */
public void initiate() throws IOException
{
    logger.debug("[Stream #{}] Sending stream init for incoming stream", session.planId());
    Socket incomingSocket = connect(session.peer);
    incoming = new IncomingMessageHandler(session, incomingSocket, StreamMessage.CURRENT_VERSION);
    incoming.sendInitMessage(true);
    incoming.start();

    logger.debug("[Stream #{}] Sending stream init for outgoing stream", session.planId());
    Socket outgoingSocket = connect(session.peer);
    outgoing = new OutgoingMessageHandler(session, outgoingSocket, StreamMessage.CURRENT_VERSION);
    outgoing.sendInitMessage(false);
    outgoing.start();
}
 
开发者ID:pgaref,项目名称:ACaZoo,代码行数:22,代码来源:ConnectionHandler.java

示例7: run

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
public void run()
{
    StreamMessage next;
    while (!isClosed())
    {
        try
        {
            if ((next = messageQueue.poll(1, TimeUnit.SECONDS)) != null)
            {
                logger.debug("[Stream #{}] Sending {}", session.planId(), next);
                sendMessage(next);
                if (next.type == StreamMessage.Type.SESSION_FAILED)
                    close();
            }
        }
        catch (InterruptedException e)
        {
            throw new AssertionError(e);
        }
    }

    try
    {
        // Sends the last messages on the queue
        while ((next = messageQueue.poll()) != null)
            sendMessage(next);
    }
    finally
    {
        signalCloseDone();
    }
}
 
开发者ID:pgaref,项目名称:ACaZoo,代码行数:33,代码来源:ConnectionHandler.java

示例8: run

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
@Override
@SuppressWarnings("resource") // Not closing constructed DataInputPlus's as the stream needs to remain open.
public void run()
{
    try
    {
        // streaming connections are per-session and have a fixed version.
        // we can't do anything with a wrong-version stream connection, so drop it.
        if (version != StreamMessage.CURRENT_VERSION)
            throw new IOException(String.format("Received stream using protocol version %d (my version %d). Terminating connection", version, StreamMessage.CURRENT_VERSION));

        DataInputPlus input = new DataInputStreamPlus(socket.getInputStream());
        StreamInitMessage init = StreamInitMessage.serializer.deserialize(input, version);

        //Set SO_TIMEOUT on follower side
        if (!init.isForOutgoing)
            socket.setSoTimeout(DatabaseDescriptor.getStreamingSocketTimeout());

        // The initiator makes two connections, one for incoming and one for outgoing.
        // The receiving side distinguish two connections by looking at StreamInitMessage#isForOutgoing.
        // Note: we cannot use the same socket for incoming and outgoing streams because we want to
        // parallelize said streams and the socket is blocking, so we might deadlock.
        StreamResultFuture.initReceivingSide(init.sessionIndex, init.planId, init.description, init.from, this, init.isForOutgoing, version, init.keepSSTableLevel, init.isIncremental);
    }
    catch (IOException e)
    {
        logger.error(String.format("IOException while reading from socket from %s, closing: %s",
                                   socket.getRemoteSocketAddress(), e));
        close();
    }
}
 
开发者ID:scylladb,项目名称:scylla-tools-java,代码行数:32,代码来源:IncomingStreamingConnection.java

示例9: initiate

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
/**
 * Set up incoming message handler and initiate streaming.
 *
 * This method is called once on initiator.
 *
 * @throws IOException
 */
@SuppressWarnings("resource")
public void initiate() throws IOException
{
    logger.debug("[Stream #{}] Sending stream init for incoming stream", session.planId());
    Socket incomingSocket = session.createConnection();
    incoming.start(incomingSocket, StreamMessage.CURRENT_VERSION);
    incoming.sendInitMessage(incomingSocket, true);

    logger.debug("[Stream #{}] Sending stream init for outgoing stream", session.planId());
    Socket outgoingSocket = session.createConnection();
    outgoing.start(outgoingSocket, StreamMessage.CURRENT_VERSION);
    outgoing.sendInitMessage(outgoingSocket, false);
}
 
开发者ID:scylladb,项目名称:scylla-tools-java,代码行数:21,代码来源:ConnectionHandler.java

示例10: run

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
@SuppressWarnings("resource")
public void run()
{
    try
    {
        ReadableByteChannel in = getReadChannel(socket);
        while (!isClosed())
        {
            // receive message
            StreamMessage message = StreamMessage.deserialize(in, protocolVersion, session);
            logger.debug("[Stream #{}] Received {}", session.planId(), message);
            // Might be null if there is an error during streaming (see FileMessage.deserialize). It's ok
            // to ignore here since we'll have asked for a retry.
            if (message != null)
            {
                session.messageReceived(message);
            }
        }
    }
    catch (Throwable t)
    {
        JVMStabilityInspector.inspectThrowable(t);
        session.onError(t);
    }
    finally
    {
        signalCloseDone();
    }
}
 
开发者ID:scylladb,项目名称:scylla-tools-java,代码行数:30,代码来源:ConnectionHandler.java

示例11: initiate

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
/**
 * Set up incoming message handler and initiate streaming.
 *
 * This method is called once on initiator.
 *
 * @throws IOException
 */
public void initiate() throws IOException
{
    logger.debug("[Stream #{}] Sending stream init for incoming stream", session.planId());
    Socket incomingSocket = connect(session.peer);
    incoming.start(incomingSocket, StreamMessage.CURRENT_VERSION);
    incoming.sendInitMessage(incomingSocket, true);

    logger.debug("[Stream #{}] Sending stream init for outgoing stream", session.planId());
    Socket outgoingSocket = connect(session.peer);
    outgoing.start(outgoingSocket, StreamMessage.CURRENT_VERSION);
    outgoing.sendInitMessage(outgoingSocket, false);
}
 
开发者ID:rajath26,项目名称:cassandra-trunk,代码行数:20,代码来源:ConnectionHandler.java

示例12: sendMessages

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
/**
 * Enqueue messages to be sent.
 *
 * @param messages messages to send
 */
public void sendMessages(Collection<? extends StreamMessage> messages)
{
    for (StreamMessage message : messages)
        sendMessage(message);
}
 
开发者ID:vcostet,项目名称:cassandra-kmean,代码行数:11,代码来源:ConnectionHandler.java

示例13: compare

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
public int compare(StreamMessage o1, StreamMessage o2)
{
    return o2.getPriority() - o1.getPriority();
}
 
开发者ID:vcostet,项目名称:cassandra-kmean,代码行数:5,代码来源:ConnectionHandler.java

示例14: enqueue

import org.apache.cassandra.streaming.messages.StreamMessage; //导入依赖的package包/类
public void enqueue(StreamMessage message)
{
    messageQueue.put(message);
}
 
开发者ID:vcostet,项目名称:cassandra-kmean,代码行数:5,代码来源:ConnectionHandler.java


注:本文中的org.apache.cassandra.streaming.messages.StreamMessage类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。