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