【闪电侠学netty】第5章 客户端启动流程

【Netty】读书笔记 - 跟闪电侠学

1. 内容概要

1 客户端启动Demo

启动客户端步骤

  • Step1:线程模型,服务器引导类Bootstrap 
  • Step2:IO 模型
  • Step3:IO 处理逻辑
  • Step4:建立连接
public class NettyClient {
    private static final int MAX_RETRY = 5;//最大重连次数


    public static void main(String[] args) {
        NioEventLoopGroup workerGroup = new NioEventLoopGroup();

        Bootstrap bootstrap = new Bootstrap();
        bootstrap
                // 1.指定线程模型
                .group(workerGroup)
                // 2.指定 IO 类型为 NIO
                .channel(NioSocketChannel.class)
                // 绑定自定义属性到 channel
                .attr(AttributeKey.newInstance("clientName"), "nettyClient")
                // 设置TCP底层属性
                .option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 5000)
                .option(ChannelOption.SO_KEEPALIVE, true)
                .option(ChannelOption.TCP_NODELAY, true)
                // 3.IO 处理逻辑
                .handler(new ChannelInitializer<SocketChannel>() {
                    @Override
                    public void initChannel(SocketChannel ch) {
                    }
                });

        // 4.建立连接
        connect(bootstrap, "juejin.im", 80, MAX_RETRY);
    }

    private static void connect(Bootstrap bootstrap, String host, int port, int retry) {
        bootstrap.connect(host, port).addListener(future -> {
            if (future.isSuccess()) {
                System.out.println("连接成功!");
            } else if (retry == 0) {
                System.err.println("重试次数已用完,放弃连接!");
            } else {
                // 第几次重连
                int order = (MAX_RETRY - retry) + 1;
                // 本次重连的间隔
                int delay = 1 << order;
                System.err.println(new Date() + ": 连接失败,第" + order + "次重连……");
                bootstrap.config().group().schedule(() -> connect(bootstrap, host, port, retry - 1), delay, TimeUnit
                        .SECONDS);
            }
        });
    }
}

2 失败重连(见上代码

        添加监听:bootstrap.connect(host, port).addListener()


3 客户端启动的其他方法

        如 Bootstrap.group()

方法名是否常用描述
attr()给客户端Channel指定自定义属性,通过channel.attr()取出属性
option()

Bootstrap
       .option(ChannelOption.CONNECT_TIMEOUT_MILLIS, 5000)
       .option(ChannelOption.SO_KEEPALIVE, true)
       .option(ChannelOption.TCP_NODELAY, true)

给客户端设置一些TCP参数

ChannelOption.CONNECT_TIMEOUT_MILLIS:连接的超时时间

ChannelOption.SO_KEEPALIVE:是否开启TCP底层心跳机制,true:开启

ChannelOption.TCP_NODELAY:是否开启Nagle算法,true:关闭,false: 开启

通俗讲,要求高实时性,有数据马上发送就设置true:关闭

posted @ 2023-01-17 13:44  随风落木  阅读(10)  评论(0)    收藏  举报  来源