欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

netty5alph1源碼分析(服務(wù)端創(chuàng)建過程)

參照《Netty系列之Netty 服務(wù)端創(chuàng)建》,研究了netty的服務(wù)端創(chuàng)建過程。至于netty的優(yōu)勢,可以參照網(wǎng)絡(luò)其他文章?!禢etty系列之Netty 服務(wù)端創(chuàng)建》是 李林鋒撰寫的netty源碼分析的一篇好文,絕對是技術(shù)干貨。但拋開技術(shù)來說,也存在一些瑕疵。

為湘潭等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計制作服務(wù),及湘潭網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都網(wǎng)站制作、網(wǎng)站建設(shè)、湘潭網(wǎng)站設(shè)計,以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!

缺點(diǎn)如下

  1. 代碼銜接不連貫,上下不連貫。

  2. 代碼片段是截圖,對閱讀代理不便(可能和閱讀習(xí)慣有關(guān))

本篇主要內(nèi)容,參照《Netty系列之Netty 服務(wù)端創(chuàng)建》,梳理出自己喜歡的閱讀風(fēng)格。

1.整體邏輯圖

整體將服務(wù)端創(chuàng)建分為2部分:(1)綁定端口,提供服務(wù)過程;(2)輪詢網(wǎng)絡(luò)請求

netty 5 alph1源碼分析(服務(wù)端創(chuàng)建過程)

1.1 綁定端口序列圖

netty 5 alph1源碼分析(服務(wù)端創(chuàng)建過程)

1.2 類圖

netty 5 alph1源碼分析(服務(wù)端創(chuàng)建過程)

類圖僅僅涵蓋了綁定過程中比較重要的幾個組件

1.3 代碼分析

step 2 doBind 綁定本地端口,啟動服務(wù)

private ChannelFuture doBind(final SocketAddress localAddress) {
    final ChannelFuture regFuture = initAndRegister();//1
    final Channel channel = regFuture.channel();
    if (regFuture.cause() != null) {
        return regFuture;
    }

    final ChannelPromise promise;
    if (regFuture.isDone()) {
        promise = channel.newPromise();
        doBind0(regFuture, channel, localAddress, promise);//2
    } else {
        // Registration future is almost always fulfilled already, but just in case it's not.
        promise = new DefaultChannelPromise(channel, GlobalEventExecutor.INSTANCE);
        regFuture.addListener(new ChannelFutureListener() {
            @Override
            public void operationComplete(ChannelFuture future) throws Exception {
                doBind0(regFuture, channel, localAddress, promise);//2
            }
        });
    }

    return promise;
}
主要分為2個處理單元

step3 initAndRegister

final ChannelFuture initAndRegister() {
    Channel channel;
    try {
        channel = createChannel();
    } catch (Throwable t) {
        return VoidChannel.INSTANCE.newFailedFuture(t);
    }

    try {
        init(channel);
    } catch (Throwable t) {
        channel.unsafe().closeForcibly();
        return channel.newFailedFuture(t);
    }
//注冊NioServerSocketChannel到Reactor線程的多路復(fù)用器上
    ChannelPromise regFuture = channel.newPromise();
    channel.unsafe().register(regFuture);
    if (regFuture.cause() != null) {
        if (channel.isRegistered()) {
            channel.close();
        } else {
            channel.unsafe().closeForcibly();
        }
    }

    return regFuture;
}

createChannel由子類ServerBootstrap實現(xiàn),創(chuàng)建新的NioServerSocketChannel,并完成Channel初始化,以及注冊。

4.ServerBootstrap.createChannel

Channel createChannel() {
    EventLoop eventLoop = group().next();
    return channelFactory().newChannel(eventLoop, childGroup);
}

它有兩個參數(shù),參數(shù)1是從父類的NIO線程池中順序獲取一個NioEventLoop,它就是服務(wù)端用于監(jiān)聽和接收客戶端連接的Reactor線程。第二個參數(shù)就是所謂的workerGroup線程池,它就是處理IO讀寫的Reactor線程組。

5.ServerBootstrap.init

void init(Channel channel) throws Exception {
//設(shè)置Socket參數(shù)和NioServerSocketChannel的附加屬性
    final Map<ChannelOption<?>, Object> options = options();
    synchronized (options) {
        channel.config().setOptions(options);
    }
    final Map<AttributeKey<?>, Object> attrs = attrs();
    synchronized (attrs) {
        for (Entry<AttributeKey<?>, Object> e: attrs.entrySet()) {
            @SuppressWarnings("unchecked")
            AttributeKey<Object> key = (AttributeKey<Object>) e.getKey();
            channel.attr(key).set(e.getValue());
        }
    }
//將AbstractBootstrap的Handler添加到NioServerSocketChannel的ChannelPipeline中
    ChannelPipeline p = channel.pipeline();
    if (handler() != null) {
        p.addLast(handler());
    }

    final ChannelHandler currentChildHandler = childHandler;
    final Entry<ChannelOption<?>, Object>[] currentChildOptions;
    final Entry<AttributeKey<?>, Object>[] currentChildAttrs;
    synchronized (childOptions) {
        currentChildOptions = childOptions.entrySet().toArray(newOptionArray(childOptions.size()));
    }
    synchronized (childAttrs) {
        currentChildAttrs = childAttrs.entrySet().toArray(newAttrArray(childAttrs.size()));
    }
//將用于服務(wù)端注冊的Handler ServerBootstrapAcceptor添加到ChannelPipeline中
    p.addLast(new ChannelInitializer<Channel>() {
        @Override
        public void initChannel(Channel ch) throws Exception {
            ch.pipeline().addLast(new ServerBootstrapAcceptor(currentChildHandler, currentChildOptions,
                    currentChildAttrs));
        }
    });
}

到此處,Netty服務(wù)端監(jiān)聽的相關(guān)資源已經(jīng)初始化完畢。

6.AbstractChannel.AbstractUnsafe.register

public final void register(final ChannelPromise promise) {
//首先判斷是否是NioEventLoop自身發(fā)起的操作,如果是,則不存在并發(fā)操作,直接執(zhí)行Channel注冊;
    if (eventLoop.inEventLoop()) {
        register0(promise);
    } else {//如果由其它線程發(fā)起,則封裝成一個Task放入消息隊列中異步執(zhí)行。
        try {
            eventLoop.execute(new Runnable() {
                @Override
                public void run() {
                    register0(promise);
                }
            });
        } catch (Throwable t) {
            logger.warn(
                    "Force-closing a channel whose registration task was not accepted by an event loop: {}",
                    AbstractChannel.this, t);
            closeForcibly();
            closeFuture.setClosed();
            promise.setFailure(t);
        }
    }
}

7.register0

private void register0(ChannelPromise promise) {
    try {
        // check if the channel is still open as it could be closed in the mean time when the register
        // call was outside of the eventLoop
        if (!ensureOpen(promise)) {
            return;
        }
        doRegister();
        registered = true;
        promise.setSuccess();
        pipeline.fireChannelRegistered();
        
        if (isActive()) {//完成綁定時,不會調(diào)用該代碼段
            pipeline.fireChannelActive();
        }
    } catch (Throwable t) {
        // Close the channel directly to avoid FD leak.
        closeForcibly();
        closeFuture.setClosed();
        if (!promise.tryFailure(t)) {
            logger.warn(
                    "Tried to fail the registration promise, but it is complete already. " +
                            "Swallowing the cause of the registration failure:", t);
        }
    }
}

觸發(fā)事件

8.doRegister

protected void doRegister() throws Exception {
    boolean selected = false;
    for (;;) {
        try {
        //將NioServerSocketChannel注冊到NioEventLoop的Selector上
            selectionKey = javaChannel().register(eventLoop().selector, 0, this);
            return;
        } catch (CancelledKeyException e) {
            if (!selected) {
                // Force the Selector to select now as the "canceled" SelectionKey may still be
                // cached and not removed because no Select.select(..) operation was called yet.
                eventLoop().selectNow();
                selected = true;
            } else {
                // We forced a select operation on the selector before but the SelectionKey is still cached
                // for whatever reason. JDK bug ?
                throw e;
            }
        }
    }
}

大伙兒可能會很詫異,應(yīng)該注冊O(shè)P_ACCEPT(16)到多路復(fù)用器上,怎么注冊0呢?0表示只注冊,不監(jiān)聽任何網(wǎng)絡(luò)操作。這樣做的原因如下:

  1. 注冊方法是多態(tài)的,它既可以被NioServerSocketChannel用來監(jiān)聽客戶端的連接接入,也可以用來注冊SocketChannel,用來監(jiān)聽網(wǎng)絡(luò)讀或者寫操作;

  2. 通過SelectionKey的interestOps(int ops)方法可以方便的修改監(jiān)聽操作位。所以,此處注冊需要獲取SelectionKey并給AbstractNioChannel的成員變量selectionKey賦值。

網(wǎng)頁名稱:netty5alph1源碼分析(服務(wù)端創(chuàng)建過程)
鏈接URL:http://aaarwkj.com/article48/peiphp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、云服務(wù)器自適應(yīng)網(wǎng)站、App設(shè)計、響應(yīng)式網(wǎng)站、網(wǎng)站導(dǎo)航

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)
91激情黑丝在线观看| 在线观看亚洲毛片网站| 亚洲综合欧美自偷自拍| 日本免费一区二区三区等视频| 日本 午夜 在线 视频| 999久久免费精品国产| 国产三级视频在线观看视频 | 久久中文字幕日韩精品| 一区二区不卡中文av| 92国产精品午夜福利| 日韩av人妻一区二区三区| 另类视频在线观看免费| 日韩在线不卡中文字幕| 亚洲欧美日韩激情另类| 成人av免费高清在线| 蜜臀国产午夜在线视频| 最新免费观看男女啪啪视频| 亚洲人妻av一区二区三区| 日本黄色录像黄色录像| 国产三级国产剧情国产av| 亚洲精品第一页中文字幕| 国产不卡视频观看网站| 国产丝袜美腿一二三区| 欧美日韩国产成人一区| 日韩一二三四区精品电影免费播放| 亚洲成人日韩在线播放 | 最近日本免费高清完整版| 国产成人在线观看av| 亚洲男人天堂在线播放| 国产高清自拍视频在线一区| 亚洲男女尻逼片视频网站| 欧美国产日韩激情在线| 国产91极品尤物白丝美女| 日本区一区二区三啪啪| 青青草原这里只有精品| 亚洲欧美国产成人在线| 国产黄色一区二区三区,| 91精品国产自产在线蜜臀| 国产日韩精品一区二区在线 | 国产成人免费高清av| 欧美日韩视频一区二区|