本文整理匯總了Java中java.nio.channels.AsynchronousSocketChannel類的典型用法代碼示例。如果您正苦於以下問題:Java AsynchronousSocketChannel類的具體用法?Java AsynchronousSocketChannel怎麽用?Java AsynchronousSocketChannel使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。
AsynchronousSocketChannel類屬於java.nio.channels包,在下文中一共展示了AsynchronousSocketChannel類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: AioServerConnection
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
public AioServerConnection(AsynchronousSocketChannel channel) {
this.channel = channel;
this.reader = new MsgReader(channel) {
@Override
protected void onMsg(Msg msg) {
Command command = MsgConverter.convert(msg);
Reply reply = commandHandler.handle(command);
writer.write(reply.toMsg());
}
};
this.writer = new MsgWriter(channel) {
@Override
protected void onWriteDone() {
super.onWriteDone();
processCommand();
}
};
}
示例2: completed
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
/**
*@description 接收客戶端請求成功之後回調
*@time 創建時間:2017年7月20日上午11:05:16
*@param channel
*@param serverHandler
*@author dzn
*/
@Override
public void completed(AsynchronousSocketChannel channel,
AsyncTimeServerHandler serverHandler) {
System.out.println("成功接收到客戶端連接 : " + channel.toString());
//繼續注冊一個接收請求的處理類
serverHandler.asynchronousServerSocketChannel.accept(serverHandler, this);
//創建一個數據緩衝區
ByteBuffer bb = ByteBuffer.allocate(1024);
//去讀取客戶端發送的數據,並注冊一個數據處理類
channel.read(bb, bb, new ReadCompletionHandler(channel));
}
示例3: make
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
@SuppressWarnings({"unchecked", "rawtypes"})
public MySQLConnection make(MySQLDataSource pool, ResponseHandler handler,
String schema) throws IOException {
DBHostConfig dsc = pool.getConfig();
NetworkChannel channel = openSocketChannel(DbleServer.getInstance().isAIO());
MySQLConnection c = new MySQLConnection(channel, pool.isReadNode());
c.setSocketParams(false);
c.setHost(dsc.getIp());
c.setPort(dsc.getPort());
c.setUser(dsc.getUser());
c.setPassword(dsc.getPassword());
c.setSchema(schema);
c.setHandler(new MySQLConnectionAuthenticator(c, handler));
c.setPool(pool);
c.setIdleTimeout(pool.getConfig().getIdleTimeout());
if (channel instanceof AsynchronousSocketChannel) {
((AsynchronousSocketChannel) channel).connect(
new InetSocketAddress(dsc.getIp(), dsc.getPort()), c,
(CompletionHandler) DbleServer.getInstance().getConnector());
} else {
((NIOConnector) DbleServer.getInstance().getConnector()).postConnect(c);
}
return c;
}
示例4: handleNewConnection
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
/**
* Creates a new client and adds it to the list of connections.
* Sets the clients handler to the initial state of NameReader
*
* @param channel the newly accepted channel
*/
private void handleNewConnection(AsynchronousSocketChannel channel) {
try {
channel.setOption(StandardSocketOptions.TCP_NODELAY, true);
} catch (IOException e) {
// ignore
//
e.printStackTrace();
}
//new dealer and channel
AioServerDataDealer dealer = null;
dealer = aioDataDealerFactory.getAioServerDataDealer();
int channelId = getChannelId();
AioServerChannel aioChannel = new AioServerChannel(channelId, channel, dealer, this);
connections.put(channelId, aioChannel);
//start channel
aioChannel.run(null);
}
示例5: setAsynchronousSocketChannel
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
/**
* @param asynchronousSocketChannel the asynchronousSocketChannel to set
*/
public void setAsynchronousSocketChannel(AsynchronousSocketChannel asynchronousSocketChannel)
{
this.asynchronousSocketChannel = asynchronousSocketChannel;
if (asynchronousSocketChannel != null)
{
try
{
Node clientNode = createClientNode(asynchronousSocketChannel);
setClientNode(clientNode);
} catch (IOException e)
{
log.info(e.toString(), e);
assignAnUnknownClientNode();
}
} else
{
assignAnUnknownClientNode();
}
}
示例6: retry
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
private void retry() {
try {
TimeUnit.SECONDS.sleep(1);
if (null != this.channel && this.channel.isOpen()) {
this.channel.close();
}
log.debug("連接:{}", this.socketAddress.toString());
final AsynchronousSocketChannel asynchronousSocketChannel = AsynchronousSocketChannel.open(this.group);
asynchronousSocketChannel.setOption(StandardSocketOptions.TCP_NODELAY, true);
asynchronousSocketChannel.setOption(StandardSocketOptions.SO_REUSEADDR, true);
asynchronousSocketChannel.setOption(StandardSocketOptions.SO_KEEPALIVE, true);
asynchronousSocketChannel.connect(this.socketAddress).get(5, TimeUnit.SECONDS);
this.channel = new FastChannel(asynchronousSocketChannel, this.serializer, timeout);
} catch (final Exception e) {
retry();
}
}
示例7: acceptCompletionHandler
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
private CompletionHandler<AsynchronousSocketChannel, Integer> acceptCompletionHandler(
int byteCount, AsynchronousServerSocketChannel socket) {
return new CompletionHandler<AsynchronousSocketChannel, Integer>() {
public void completed(
AsynchronousSocketChannel ch,
Integer acceptsToGo) {
acceptsToGo = acceptsToGo-1;
// System.out.println("server accepted, to go = " + acceptsToGo);
writeStuffThreadAsync(socket, ch, byteCount, acceptsToGo);
if (acceptsToGo > 0) {
socket.accept(acceptsToGo, acceptCompletionHandler(byteCount, socket));
}
}
public void failed(Throwable exc, Integer attachment) {
exc.printStackTrace();
try {
socket.close();
} catch (IOException e) {
e.printStackTrace();
}
}
};
}
示例8: completed
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
@Override
public void completed(AsynchronousSocketChannel socketChannel, AioServerSocket serverSocket) {
try {
//接續接收 accept 請求
serverSocket.catchAccept();
AioSocket socket = new AioSocket(serverSocket,socketChannel);
//觸發 Accept 事件
EventTrigger.fireAcceptThread(socket.getSession());
} catch (IOException e) {
EventTrigger.fireExceptionThread(null, e);
}
}
示例9: main
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
public static void main(String[] args) throws IOException, ExecutionException,
InterruptedException, TimeoutException {
//打開 AsychronousServerSocketChannel 並將其綁定到類似於 ServerSocketChannel 的地址
//方法 bind() 將一個套接字地址作為其參數。找到空閑端口的便利方法是傳遞一個 null 地址,它會自動將套接字綁定到本地主機地址,並使用空閑的 臨時 端口。
AsynchronousServerSocketChannel server = AsynchronousServerSocketChannel.open().bind(null);
//告訴通道接受一個連接
Future<AsynchronousSocketChannel> future = server.accept();
// 利用 Future 對象,當前線程可阻塞來等待結果:
AsynchronousSocketChannel worker = future.get();
//超時
//AsynchronousSocketChannel worker = future.get(10, TimeUnit.SECONDS);
//取消
// if (!future.isDone()) {
// future.cancel(true);//cancel() 方法可利用一個布爾標誌來指出執行接受的線程是否可被中斷
// }
//
//// read a message from the client
ByteBuffer readBuffer = ByteBuffer.allocate(1024);
worker.read(readBuffer).get(10, TimeUnit.SECONDS);
System.out.println("Message: " + new String(readBuffer.array()));
}
示例10: Nio2SSLSocket
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
public Nio2SSLSocket(AsynchronousSocketChannel sock, SSLContext sslc, boolean clientMode)
{
super(sock);
this.engine = sslc.createSSLEngine();
this.engine.setUseClientMode(clientMode);
String[] procols = { "TLSv1" };
this.engine.setEnabledProtocols(procols);
int packetBufferSize = engine.getSession().getPacketBufferSize();
decodeBuf = ByteBuffer.allocateDirect(packetBufferSize);
readBuf = ByteBuffer.allocateDirect(packetBufferSize);
for (int i = 0; i < 2; i++)
{
writeBufs[i] = ByteBuffer.allocateDirect(packetBufferSize);
writeBufs[i].limit(0);
}
writeBufs[0].clear();
}
示例11: connect
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
private void connect() throws BindException{
String errorMessage = "";
if (socketChannel == null || !socketChannel.isOpen() || closed) {
try {
socketChannel = AsynchronousSocketChannel.open();
socketChannel.setOption(StandardSocketOptions.SO_REUSEADDR, true);
socketChannel.setOption(StandardSocketOptions.SO_KEEPALIVE, true);
socketChannel.connect(new InetSocketAddress(ip, port)).get(timeout, TimeUnit.MILLISECONDS);
closed = false;
//when connect to the server, keep receiving data either server response or server call
receive();
} catch (Exception e) {
log.error("Connection error: " + e.getMessage());
errorMessage = e.getMessage();
}
}
if (socketChannel == null) {
throw new BindException(errorMessage);
}
}
示例12: connect
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
private void connect() throws BindException{
String errorMessage = "";
if (socketChannel == null || !socketChannel.isOpen() || closed) {
try {
socketChannel = AsynchronousSocketChannel.open();
socketChannel.setOption(StandardSocketOptions.SO_REUSEADDR, true);
socketChannel.setOption(StandardSocketOptions.SO_KEEPALIVE, true);
socketChannel.connect(new InetSocketAddress(ip, port)).get(timeout, TimeUnit.MILLISECONDS);
closed = false;
log.debug("Session start to " + socketChannel.getRemoteAddress());
//when connect to the server, keep receiving data either server response or server call
receive();
} catch (Exception e) {
log.error("Connection error: " + e.getMessage());
errorMessage = e.getMessage();
}
}
if (socketChannel == null) {
throw new BindException(errorMessage);
}
}
示例13: make
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
public MySQLConnection make(MySQLDataSource pool, ResponseHandler handler)
throws IOException {
DBHostConfig dsc = pool.getConfig();
AsynchronousSocketChannel channel = openSocketChannel();
MySQLConnection c = new MySQLConnection(channel, pool.isReadNode());
c.setHost(dsc.getIp());
c.setPort(dsc.getPort());
c.setUser(dsc.getUser());
c.setPassword(dsc.getPassword());
// c.setSchema(dsc.getDatabase());
c.setHandler(new MySQLConnectionAuthenticator(c, handler));
c.setPool(pool);
c.setIdleTimeout(pool.getConfig().getIdleTimeout());
channel.connect(new InetSocketAddress(dsc.getIp(), dsc.getPort()), c,
MycatServer.getInstance().getConnector());
return c;
}
示例14: SocketSession
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
public SocketSession(AsynchronousSocketChannel channel, ByteBuffer buffer,
CodecFactory codecFactory) throws IOException {
this.channel = channel;
this.remoteAddress = channel.getRemoteAddress();
this.processor = new Processor(this);
this.buffer = buffer;
this.codec = codecFactory.getCodec();
this.describe = "local:" + channel.getLocalAddress() + " remote:"
+ remoteAddress + " hashCode/" + super.hashCode();
this.hashCode = super.hashCode();
attachment = new ConcurrentHashMap<Object, Object>(128);
this.attachment.put(MSG_SURPLUS_LENGTH, -1);
this.attachment.put(MSG_TMP, new byte[0]);
this.remotePort = Integer.parseInt(this.toString().split(" ")[1]
.split(":")[2]);
}
示例15: AbstractClient
import java.nio.channels.AsynchronousSocketChannel; //導入依賴的package包/類
/**
* Construct a new {@code Client}
* @param channel that this client listens on
* @throws IOException If an I/O error occurs
*/
AbstractClient(AsynchronousSocketChannel channel) {
super();
this.channel = channel;
this.cipher = new Cryptographer();
/*
* TODO This option was part of the ChatServer example by Oracle, but
* should be used with caution: "The socket option should only be
* enabled in cases where it is known that the coalescing impacts
* performance". We need to figure out whether it is required to set
* this option to true.
*
* try {
* this.channel.setOption(StandardSocketOptions.TCP_NODELAY, true);
* } catch (IOException e) {
* e.printStackTrace();
* }
*
*/
}