欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在netty中使用native傳輸協(xié)議的方法

 更新時間:2022年05月26日 17:02:59   作者:程序那些事  
這篇文章主要介紹了在netty中使用native傳輸協(xié)議,這里我們只以Kqueue為例介紹了netty中native傳輸協(xié)議的使用,需要的朋友可以參考下

簡介

對于IO來說,除了傳統(tǒng)的block IO,使用最多的就是NIO了,通常我們在netty程序中最常用到的就是NIO,比如NioEventLoopGroup,NioServerSocketChannel等。

我們也知道在IO中有比NIO更快的IO方式,比如kqueue和epoll,但是這兩種方式需要native方法的支持,也就是說需要在操作系統(tǒng)層面提供服務。

如果我們在支持Kqueue或者epoll的服務器上,netty是否可以提供對這些優(yōu)秀IO的支持呢?

答案是肯定的。但是首先kqueue和epoll需要JNI支持,也就是說JAVA程序需要調(diào)用本地的native方法。

native傳輸協(xié)議的依賴

要想使用kequeue和epoll這種native的傳輸方式,我們需要額外添加項目的依賴,如果是linux環(huán)境,則可以添加如下的maven依賴環(huán)境:

  <dependencies>
    <dependency>
      <groupId>io.netty</groupId>
      <artifactId>netty-transport-native-epoll</artifactId>
      <version>${project.version}</version>
      <classifier>linux-x86_64</classifier>
    </dependency>
    ...
  </dependencies>

其中version需要匹配你所使用的netty版本號,否則可能出現(xiàn)調(diào)用異常的情況。

classifier表示的是系統(tǒng)架構(gòu),它的值可以是linux-x86_64,也可以是linux-aarch_64.

如果你使用的mac系統(tǒng),那么可以這樣引入:

  <dependencies>
    <dependency>
      <groupId>io.netty</groupId>
      <artifactId>netty-transport-native-kqueue</artifactId>
      <version>${project.version}</version>
      <classifier>osx-x86_64</classifier>
    </dependency>
    ...
  </dependencies>

netty除了單獨的個體包之外,還有一個all in one的netty-all包,如果你使用了這個all in one的包,那么不需要額外添加native的依賴。

如果netty提供的系統(tǒng)架構(gòu)并沒有你正在使用的,那么你需要手動進行編譯,以下是編譯所依賴的程序包, 如果是在RHEL/CentOS/Fedora系統(tǒng)中,則使用:

sudo yum install autoconf automake libtool make tar \
                 glibc-devel \
                 libgcc.i686 glibc-devel.i686

如果是在Debian/Ubuntu系統(tǒng)中,則使用:

sudo apt-get install autoconf automake libtool make tar \
                     gcc

如果是在MacOS/BSD系統(tǒng)中,則使用:

brew install autoconf automake libtool

netty本地傳輸協(xié)議的使用

安裝好依賴包之后,我們就可以在netty中使用這些native傳輸協(xié)議了。

native傳輸協(xié)議的使用和NIO的使用基本一致,我們只需要進行下面的替換即可。

如果是在liunx系統(tǒng)中,則進行下面的替換:

    NioEventLoopGroup → EpollEventLoopGroup
    NioEventLoop → EpollEventLoop
    NioServerSocketChannel → EpollServerSocketChannel
    NioSocketChannel → EpollSocketChannel

如果是在mac系統(tǒng)中,則進行下面的替換:

    NioEventLoopGroup → KQueueEventLoopGroup
    NioEventLoop → KQueueEventLoop
    NioServerSocketChannel → KQueueServerSocketChannel
    NioSocketChannel → KQueueSocketChannel

這里還是使用我們熟悉的聊天服務為例,首先看下基于Kqueue的netty服務器端應該怎么寫:

EventLoopGroup bossGroup = new KQueueEventLoopGroup(1);
        EventLoopGroup workerGroup = new KQueueEventLoopGroup();
        try {
            ServerBootstrap b = new ServerBootstrap();
            b.group(bossGroup, workerGroup)
             .channel(KQueueServerSocketChannel.class)
             .handler(new LoggingHandler(LogLevel.INFO))
             .childHandler(new NativeChatServerInitializer());

            Channel channel = b.bind(PORT).sync().channel();
            log.info("server channel:{}", channel);
            channel.closeFuture().sync();

和NIO一樣,在服務器端我們需要使用KQueueEventLoopGroup創(chuàng)建兩個EventLoopGroup,一個是bossGroup, 一個是workerGroup。

然后將這兩個group傳入到ServerBootstrap中,并且添加KQueueServerSocketChannel作為channel。

其他的內(nèi)容和NIO server的內(nèi)容是一樣的。

接下來我們看下基于Kqueue的netty客戶端改如何跟server端建立連接:

EventLoopGroup group = new KQueueEventLoopGroup();
        try {
            Bootstrap b = new Bootstrap();
            b.group(group)
             .channel(KQueueSocketChannel.class)
             .handler(new NativeChatClientInitializer());

            // 建立連接
            Channel ch = b.connect(HOST, PORT).sync().channel();
            log.info("client channel: {}", ch);

這里使用的是KQueueEventLoopGroup,并將KQueueEventLoopGroup放到Bootstrap中,并且為Bootstrap提供了和server端一致的KQueueSocketChannel。

然后就是客戶端向channel中寫消息,這里我們直接從命令行輸入:

// 從命令行輸入
            ChannelFuture lastWriteFuture = null;
            BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
            for (;;) {
                String line = in.readLine();
                if (line == null) {
                    break;
                }
                // 將從命令行輸入的一行字符寫到channel中
                lastWriteFuture = ch.writeAndFlush(line + "\r\n");
                // 如果輸入'再見',則等待server端關閉channel
                if ("再見".equalsIgnoreCase(line)) {
                    ch.closeFuture().sync();
                    break;
                }
            }

上面代碼的意思是將命令行收到的消息寫入到channel中,如果輸入的是’再見’,則關閉channel。

為了能夠處理字符串,這里用到了三個編碼解碼器:

        // 添加行分割器
        pipeline.addLast(new DelimiterBasedFrameDecoder(8192, Delimiters.lineDelimiter()));
        // 添加String Decoder和String Encoder,用來進行字符串的轉(zhuǎn)換
        pipeline.addLast(new StringEncoder());
        pipeline.addLast(new StringDecoder());

分別是行分割器,字符編碼器和字符解碼器。

運行一下看,程序運行沒問題,客戶端和服務器端可以進行通訊。

總結(jié)

這里我們只以Kqueue為例介紹了netty中native傳輸協(xié)議的使用,具體的代碼,大家可以參考:

learn-netty4

到此這篇關于在netty中使用native傳輸協(xié)議的文章就介紹到這了,更多相關native傳輸協(xié)議內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Spring Security 控制授權(quán)的方法

    Spring Security 控制授權(quán)的方法

    本篇文章主要介紹了Spring Security 控制授權(quán)的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • java秒殺之redis限流操作詳解

    java秒殺之redis限流操作詳解

    這篇文章主要為大家詳細介紹了java秒殺之redis限流操作,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • 手把手搭建Java共享網(wǎng)盤的方法步驟

    手把手搭建Java共享網(wǎng)盤的方法步驟

    這篇文章主要介紹了手把手搭建Java共享網(wǎng)盤,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-12-12
  • Java實現(xiàn)儲存對象并按對象某屬性排序的幾種方法示例

    Java實現(xiàn)儲存對象并按對象某屬性排序的幾種方法示例

    這篇文章主要介紹了Java實現(xiàn)儲存對象并按對象某屬性排序的幾種方法,結(jié)合實例形式詳細分析了Java儲存對象并按對象某屬性排序的具體實現(xiàn)方法與操作注意事項,需要的朋友可以參考下
    2020-05-05
  • Spring依賴注入與第三方Bean管理基礎詳解

    Spring依賴注入與第三方Bean管理基礎詳解

    依賴注入(Dependency Injection)和控制反轉(zhuǎn)(Inversion of Control)是同一個概念。具體含義是:當某個角色(可能是一個Java實例,調(diào)用者)需要另一個角色(另一個Java實例,被調(diào)用者)的協(xié)助時,在 傳統(tǒng)的程序設計過程中,通常由調(diào)用者來創(chuàng)建被調(diào)用者的實例
    2022-12-12
  • swagger?@ApiModel添加實體類不生效的解決

    swagger?@ApiModel添加實體類不生效的解決

    這篇文章主要介紹了swagger?@ApiModel添加實體類不生效的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教。
    2022-01-01
  • SpringBoot如何正確配置并運行Kafka

    SpringBoot如何正確配置并運行Kafka

    這篇文章主要介紹了SpringBoot如何正確配置并運行Kafka問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Java中ArrayList的removeAll方法詳解

    Java中ArrayList的removeAll方法詳解

    這篇文章主要給大家介紹了關于Java中ArrayList的removeAll方法的相關資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面跟著小編一起來看看吧。
    2017-07-07
  • Java8實戰(zhàn)之Stream的延遲計算

    Java8實戰(zhàn)之Stream的延遲計算

    JDK中Stream的中間函數(shù)如 filter(Predicate super T>)是惰性求值的,filter并非對流中所有元素調(diào)用傳遞給它的Predicate,下面這篇文章主要給大家介紹了關于Java8實戰(zhàn)之Stream延遲計算的相關資料,需要的朋友可以參考下
    2021-09-09
  • Spring思維導圖助你輕松學習Spring

    Spring思維導圖助你輕松學習Spring

    這篇文章主要為大家詳細介紹了Spring思維導圖,幫助你輕松學習Spring的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-03-03

最新評論