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.ServerBootstrap;
19 import io.netty.channel.ChannelFuture;
20 import io.netty.channel.ChannelInitializer;
21 import io.netty.channel.ChannelOption;
22 import io.netty.channel.nio.NioEventLoopGroup;
23 import io.netty.channel.udt.UdtChannel;
24 import io.netty.channel.udt.nio.NioUdtProvider;
25 import io.netty.handler.logging.LogLevel;
26 import io.netty.handler.logging.LoggingHandler;
27 import io.netty.util.concurrent.DefaultThreadFactory;
28
29 import java.util.concurrent.ThreadFactory;
30
31
32
33
34
35
36 public final class MsgEchoServer {
37
38 static final int PORT = Integer.parseInt(System.getProperty("port", "8007"));
39
40 public static void main(String[] args) throws Exception {
41 final ThreadFactory acceptFactory = new DefaultThreadFactory("accept");
42 final ThreadFactory connectFactory = new DefaultThreadFactory("connect");
43 final NioEventLoopGroup acceptGroup =
44 new NioEventLoopGroup(1, acceptFactory, NioUdtProvider.MESSAGE_PROVIDER);
45 final NioEventLoopGroup connectGroup =
46 new NioEventLoopGroup(1, connectFactory, NioUdtProvider.MESSAGE_PROVIDER);
47
48
49 try {
50 final ServerBootstrap boot = new ServerBootstrap();
51 boot.group(acceptGroup, connectGroup)
52 .channelFactory(NioUdtProvider.MESSAGE_ACCEPTOR)
53 .option(ChannelOption.SO_BACKLOG, 10)
54 .handler(new LoggingHandler(LogLevel.INFO))
55 .childHandler(new ChannelInitializer<UdtChannel>() {
56 @Override
57 public void initChannel(final UdtChannel ch)
58 throws Exception {
59 ch.pipeline().addLast(
60 new LoggingHandler(LogLevel.INFO),
61 new MsgEchoServerHandler());
62 }
63 });
64
65 final ChannelFuture future = boot.bind(PORT).sync();
66
67 future.channel().closeFuture().sync();
68 } finally {
69
70 acceptGroup.shutdownGracefully();
71 connectGroup.shutdownGracefully();
72 }
73 }
74 }