1 /*
2 * Copyright 2012 The Netty Project
3 *
4 * The Netty Project licenses this file to you under the Apache License,
5 * version 2.0 (the "License"); you may not use this file except in compliance
6 * with the License. You may obtain a copy of the License at:
7 *
8 * https://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
12 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13 * License for the specific language governing permissions and limitations
14 * under the License.
15 */
16 package io.netty.example.echo;
17
18 import io.netty.bootstrap.Bootstrap;
19 import io.netty.channel.ChannelFuture;
20 import io.netty.channel.ChannelInitializer;
21 import io.netty.channel.ChannelOption;
22 import io.netty.channel.ChannelPipeline;
23 import io.netty.channel.EventLoopGroup;
24 import io.netty.channel.nio.NioEventLoopGroup;
25 import io.netty.channel.socket.SocketChannel;
26 import io.netty.channel.socket.nio.NioSocketChannel;
27 import io.netty.example.util.ServerUtil;
28 import io.netty.handler.ssl.SslContext;
29
30 /**
31 * Sends one message when a connection is open and echoes back any received
32 * data to the server. Simply put, the echo client initiates the ping-pong
33 * traffic between the echo client and server by sending the first message to
34 * the server.
35 */
36 public final class EchoClient {
37
38 static final String HOST = System.getProperty("host", "127.0.0.1");
39 static final int PORT = Integer.parseInt(System.getProperty("port", "8007"));
40 static final int SIZE = Integer.parseInt(System.getProperty("size", "256"));
41
42 public static void main(String[] args) throws Exception {
43 // Configure SSL.git
44 final SslContext sslCtx = ServerUtil.buildSslContext();
45
46 // Configure the client.
47 EventLoopGroup group = new NioEventLoopGroup();
48 try {
49 Bootstrap b = new Bootstrap();
50 b.group(group)
51 .channel(NioSocketChannel.class)
52 .option(ChannelOption.TCP_NODELAY, true)
53 .handler(new ChannelInitializer<SocketChannel>() {
54 @Override
55 public void initChannel(SocketChannel ch) throws Exception {
56 ChannelPipeline p = ch.pipeline();
57 if (sslCtx != null) {
58 p.addLast(sslCtx.newHandler(ch.alloc(), HOST, PORT));
59 }
60 //p.addLast(new LoggingHandler(LogLevel.INFO));
61 p.addLast(new EchoClientHandler());
62 }
63 });
64
65 // Start the client.
66 ChannelFuture f = b.connect(HOST, PORT).sync();
67
68 // Wait until the connection is closed.
69 f.channel().closeFuture().sync();
70 } finally {
71 // Shut down the event loop to terminate all threads.
72 group.shutdownGracefully();
73 }
74 }
75 }