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