1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package io.netty.example.uptime;
17
18 import io.netty.bootstrap.ServerBootstrap;
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.socket.SocketChannel;
25 import io.netty.channel.socket.nio.NioServerSocketChannel;
26 import io.netty.handler.logging.LogLevel;
27 import io.netty.handler.logging.LoggingHandler;
28
29
30
31
32
33 public final class UptimeServer {
34 private static final int PORT = Integer.parseInt(System.getProperty("port", "8080"));
35 private static final UptimeServerHandler handler = new UptimeServerHandler();
36
37 private UptimeServer() {
38 }
39
40 public static void main(String[] args) throws Exception {
41
42 EventLoopGroup bossGroup = new MultiThreadIoEventLoopGroup(1, NioIoHandler.newFactory());
43 EventLoopGroup workerGroup = new MultiThreadIoEventLoopGroup(NioIoHandler.newFactory());
44 try {
45 ServerBootstrap b = new ServerBootstrap();
46 b.group(bossGroup, workerGroup)
47 .channel(NioServerSocketChannel.class)
48 .handler(new LoggingHandler(LogLevel.INFO))
49 .childHandler(new ChannelInitializer<SocketChannel>() {
50 @Override
51 public void initChannel(SocketChannel ch) {
52 ch.pipeline().addLast(handler);
53 }
54 });
55
56
57 ChannelFuture f = b.bind(PORT).sync();
58
59
60
61
62 f.channel().closeFuture().sync();
63 } finally {
64 workerGroup.shutdownGracefully();
65 bossGroup.shutdownGracefully();
66 }
67 }
68 }