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.MultiThreadIoEventLoopGroup;
22 import io.netty.channel.nio.NioIoHandler;
23 import io.netty.channel.socket.nio.NioSocketChannel;
24 import io.netty.example.util.ServerUtil;
25 import io.netty.handler.ssl.SslContext;
26
27
28
29
30
31 public final class FactorialClient {
32
33 static final String HOST = System.getProperty("host", "127.0.0.1");
34 static final int PORT = Integer.parseInt(System.getProperty("port", "8322"));
35 static final int COUNT = Integer.parseInt(System.getProperty("count", "1000"));
36
37 public static void main(String[] args) throws Exception {
38
39 final SslContext sslCtx = ServerUtil.buildSslContext();
40
41 EventLoopGroup group = new MultiThreadIoEventLoopGroup(NioIoHandler.newFactory());
42 try {
43 Bootstrap b = new Bootstrap();
44 b.group(group)
45 .channel(NioSocketChannel.class)
46 .handler(new FactorialClientInitializer(sslCtx));
47
48
49 ChannelFuture f = b.connect(HOST, PORT).sync();
50
51
52 FactorialClientHandler handler =
53 (FactorialClientHandler) f.channel().pipeline().last();
54
55
56 System.err.format("Factorial of %,d is: %,d", COUNT, handler.getFactorial());
57 } finally {
58 group.shutdownGracefully();
59 }
60 }
61 }