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