本文整理汇总了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;未经允许,请勿转载。 |
请发表评论