1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package io.netty.example.udt.echo.bytes;
17
18 import io.netty.bootstrap.Bootstrap;
19 import io.netty.channel.ChannelFuture;
20 import io.netty.channel.ChannelInitializer;
21 import io.netty.channel.nio.NioEventLoopGroup;
22 import io.netty.channel.udt.UdtChannel;
23 import io.netty.channel.udt.nio.NioUdtProvider;
24 import io.netty.handler.logging.LogLevel;
25 import io.netty.handler.logging.LoggingHandler;
26 import io.netty.util.concurrent.DefaultThreadFactory;
27
28 import java.util.concurrent.ThreadFactory;
29
30
31
32
33
34
35
36
37
38 public final class ByteEchoClient {
39
40 static final String HOST = System.getProperty("host", "127.0.0.1");
41 static final int PORT = Integer.parseInt(System.getProperty("port", "8007"));
42 static final int SIZE = Integer.parseInt(System.getProperty("size", "256"));
43
44 public static void main(String[] args) throws Exception {
45
46 final ThreadFactory connectFactory = new DefaultThreadFactory("connect");
47 final NioEventLoopGroup connectGroup = new NioEventLoopGroup(1,
48 connectFactory, NioUdtProvider.BYTE_PROVIDER);
49 try {
50 final Bootstrap boot = new Bootstrap();
51 boot.group(connectGroup)
52 .channelFactory(NioUdtProvider.BYTE_CONNECTOR)
53 .handler(new ChannelInitializer<UdtChannel>() {
54 @Override
55 public void initChannel(final UdtChannel ch)
56 throws Exception {
57 ch.pipeline().addLast(
58 new LoggingHandler(LogLevel.INFO),
59 new ByteEchoClientHandler());
60 }
61 });
62
63 final ChannelFuture f = boot.connect(HOST, PORT).sync();
64
65 f.channel().closeFuture().sync();
66 } finally {
67
68 connectGroup.shutdownGracefully();
69 }
70 }
71 }