1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16 package io.netty.example.factorial;
17
18 import io.netty.bootstrap.Bootstrap;
19 import io.netty.channel.ChannelFuture;
20 import io.netty.channel.EventLoopGroup;
21 import io.netty.channel.nio.NioEventLoopGroup;
22 import io.netty.channel.socket.nio.NioSocketChannel;
23 import io.netty.example.util.ServerUtil;
24 import io.netty.handler.ssl.SslContext;
25
26
27
28
29
30 public final class FactorialClient {
31
32 static final String HOST = System.getProperty("host", "127.0.0.1");
33 static final int PORT = Integer.parseInt(System.getProperty("port", "8322"));
34 static final int COUNT = Integer.parseInt(System.getProperty("count", "1000"));
35
36 public static void main(String[] args) throws Exception {
37
38 final SslContext sslCtx = ServerUtil.buildSslContext();
39
40 EventLoopGroup group = new NioEventLoopGroup();
41 try {
42 Bootstrap b = new Bootstrap();
43 b.group(group)
44 .channel(NioSocketChannel.class)
45 .handler(new FactorialClientInitializer(sslCtx));
46
47
48 ChannelFuture f = b.connect(HOST, PORT).sync();
49
50
51 FactorialClientHandler handler =
52 (FactorialClientHandler) f.channel().pipeline().last();
53
54
55 System.err.format("Factorial of %,d is: %,d", COUNT, handler.getFactorial());
56 } finally {
57 group.shutdownGracefully();
58 }
59 }
60 }