1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package io.netty.example.socksproxy;
17
18 import io.netty.bootstrap.ServerBootstrap;
19 import io.netty.channel.EventLoopGroup;
20 import io.netty.channel.nio.NioEventLoopGroup;
21 import io.netty.channel.socket.nio.NioServerSocketChannel;
22 import io.netty.handler.logging.LogLevel;
23 import io.netty.handler.logging.LoggingHandler;
24
25 public final class SocksServer {
26
27 static final int PORT = Integer.parseInt(System.getProperty("port", "1080"));
28
29 public static void main(String[] args) throws Exception {
30 EventLoopGroup bossGroup = new NioEventLoopGroup(1);
31 EventLoopGroup workerGroup = new NioEventLoopGroup();
32 try {
33 ServerBootstrap b = new ServerBootstrap();
34 b.group(bossGroup, workerGroup)
35 .channel(NioServerSocketChannel.class)
36 .handler(new LoggingHandler(LogLevel.INFO))
37 .childHandler(new SocksServerInitializer());
38 b.bind(PORT).sync().channel().closeFuture().sync();
39 } finally {
40 bossGroup.shutdownGracefully();
41 workerGroup.shutdownGracefully();
42 }
43 }
44 }