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