com.dingwang.netty.client.DiscardClient.java Source code

Java tutorial

Introduction

Here is the source code for com.dingwang.netty.client.DiscardClient.java

Source

/*
 * Copyright 2016 Zhongan.com All right reserved. This software is the
 * confidential and proprietary information of Zhongan.com ("Confidential
 * Information"). You shall not disclose such Confidential Information and shall
 * use it only in accordance with the terms of the license agreement you entered
 * into with Zhongan.com.
 */
package com.dingwang.netty.client;

import com.dingwang.netty.decoder.TimeDecoder;
import com.dingwang.netty.handler.TimeClientHandler;

import io.netty.bootstrap.Bootstrap;
import io.netty.channel.ChannelFuture;
import io.netty.channel.ChannelInitializer;
import io.netty.channel.ChannelOption;
import io.netty.channel.EventLoopGroup;
import io.netty.channel.nio.NioEventLoopGroup;
import io.netty.channel.socket.SocketChannel;
import io.netty.channel.socket.nio.NioSocketChannel;

/**
 * DiscardClient.java??TODO ??
 * 
 * @author wangding_91@163.com 2016218 ?4:37:39
 */
public class DiscardClient {

    private int port;

    private String host;

    public DiscardClient(int port, String host) {
        this.port = port;
        this.host = host;
    }

    public void run() {
        EventLoopGroup workerGroup = new NioEventLoopGroup();

        //BootStrapServerBootstrap,???channel?channel
        Bootstrap b = new Bootstrap();

        //?EventLoopGroup?bossworkder
        //??boss
        b.group(workerGroup);

        //NioServerSocketChannelNioSocketChannel,channel
        b.channel(NioSocketChannel.class);

        //??ServerBootstrap?childOption()SocketChannelchannel
        b.option(ChannelOption.SO_KEEPALIVE, true);
        b.handler(new ChannelInitializer<SocketChannel>() {

            @Override
            protected void initChannel(SocketChannel ch) throws Exception {
                ch.pipeline().addLast(new TimeDecoder(), new TimeClientHandler());
            }
        });

        ChannelFuture f;
        try {
            //connect()bind()
            f = b.connect(host, port).sync();
            f.channel().writeAndFlush("dddddd");
            f.channel().closeFuture().sync();
        } catch (InterruptedException e) {
            e.printStackTrace();
        } finally {
            workerGroup.shutdownGracefully();
        }
    }

}