返回顶部
首页 > 资讯 > 精选 >Java的IO模型和Netty框架是什么
  • 565
分享到

Java的IO模型和Netty框架是什么

2023-06-29 13:06:43 565人浏览 独家记忆
摘要

这篇文章主要介绍“Java的io模型和Netty框架是什么”,在日常操作中,相信很多人在Java的IO模型和Netty框架是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java的IO模型和Netty框架

这篇文章主要介绍“Java的io模型和Netty框架是什么”,在日常操作中,相信很多人在Java的IO模型和Netty框架是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java的IO模型和Netty框架是什么”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

    什么是Netty

    • 异步,基于事件驱动的网络应用框架,用以快速开发高性能,高可靠的网络IO程序

    • 主要针对在tcp协议下,面向Clients端的高并发应用

    • 本质是一个NIO框架,适用于服务器通讯等场景

    异步:发送请求无需等待响应,程式接着往下走。

    事件驱动:一个连接事件或者断开事件,或者读事件或者写事件,发生后的后续处理。

    Java的IO模型和Netty框架是什么

    Netty典型应用:

    • 高性能rpc框架用来远程服务(过程)调用,比如dubbo

    • 游戏行业,页面数据交互。

    • 大数据领域如hadoop高性能通讯和序列化组件(AVRO)。

    IO模型

    简单理解就是用什么通道去进行数据发送和接收。

    BIO:一个连接一个线程,连接不做任何事会造成不必要的线程开销。适用于连接数目较小且固定的架构

    Java的IO模型和Netty框架是什么

    NIO:服务端一个线程(也可以多个),维护一个多路复用器。由多路复用器去处理IO线程。适用于连接数目多且较短的架构

    Java的IO模型和Netty框架是什么

    aiO:异步非阻塞,还未得到广泛应用。适用于连接数目多且连接较长的架构。

    BIO

    BIO编程简单流程

    • 服务端创建启动ServerSocket

    • 客户端启动Socket对服务器进行通信,默认服务器会对每一个客户创建一个线程。

    • 客户端发出请求后,先咨询线程是否有响应,如果没有则等待或者拒绝。

    • 如果有响应,则等待请求结束后,再继续执行。(阻塞)

    BIO简单实例

    public class BiOServer {    public static void main(String[] args) throws IOException {        // 为了方便直接用了Executors创建线程池        ExecutorService service = Executors.newCachedThreadPool();        //指定服务端端口        ServerSocket serverSocket = new ServerSocket(6666);        System.out.println("服务器启动");        while(true){            //阻塞等待连接            Socket socket = serverSocket.accept();            System.out.println("连接到一个客户端");            //每个连接对应一个线程            service.execute(new Runnable() {                @Override                public void run() {                    try {                        handler(socket);                    }catch (Exception e){                        e.printStackTrace();                    }                }            });        }    }    public static void handler(Socket socket) throws IOException {        System.out.println("Thread:"+Thread.currentThread().getId());        byte[] bytes = new byte[1024];        InputStream inputStream = socket.getInputStream();        while (true){            //阻塞等待读取            int n = inputStream.read(bytes);            if(n!=-1){                System.out.println(new String(bytes,0,n));            }else {                break;            }        }        socket.close();    }}

    测试:使用windows的telnet

    Java的IO模型和Netty框架是什么

    使用 ctrl+]

    Java的IO模型和Netty框架是什么

    Java的IO模型和Netty框架是什么

     可以在服务端控制台看到,已经读取到发送的数据

    Java的IO模型和Netty框架是什么

    NIO

    三大核心部分:Channel(可类比Socket),Buffer,Selector

    大概是这个样子。客户端和Buffer交互,Buffer和Channel是一对一的关系。Selector选择操作Channel(事件驱动,如果Channel有事件发生,Selector才去选择操作。)

    Java的IO模型和Netty框架是什么

    Buffer

    Buffer基本使用

    ByteBuffer使用场景较为广泛。

    buffer就是一个内存块,所以说nio是面向块/缓冲,底层是数组。数据读写是通过buffer。可以使用方法flip切换读写。

    public class BufferNio {    public static void main(String[] args) {        //创建buffer容量为5个int        IntBuffer buffer = IntBuffer.allocate(5);        //放数据        buffer.put(1);        buffer.put(2);        buffer.put(3);        buffer.put(4);        buffer.put(5);        //读写切换        buffer.flip();        //取数据        //内部维护一个索引,每次get索引都会往后边移动        while(buffer.hasRemaining()){            System.out.println(buffer.get());        }    }}

    Buffer四个主要属性

    // Invariants: mark <= position <= limit <= capacity    private int mark = -1;    private int position = 0;    private int limit;    private int capacity;

    mark:标记,很少改变

    position:下一个要被读元素的位置,为下次读写做准备

    limit:缓冲器当前的终点,不能对缓冲区极限意外的区域读写,可变。

    capacity:不可变,创建时指定的最大容量。

    上边出现了读写切换的方法flip,我们看下源码,可以看出来通过改变属性实现可读可写的。

    public final Buffer flip() {        limit = position;        position = 0;        mark = -1;        return this;    }

    可以通过啊更改limit或者position来实现你想要的操作。参数自己决定

    buffer.limit(2);        buffer.position(1);

    Channel

    可读可写,上接Selector,下连Buffer。

    当客户端连接ServerSocketChannel时,创建客户端自己的SocketChannel。

    本地文件写案例

    public class ChannelNio {    public static void main(String[] args) throws IOException {        String str = "少壮不努力,老大徒伤悲";        //创建输出流        FileOutputStream os = new FileOutputStream("D:\\xxxxxxxxxxxxxxxxxxx\\a.txt");        //获取FileChannel        FileChannel channel = os.getChannel();        //创建缓冲        ByteBuffer buffer = ByteBuffer.allocate(1024);        //把字符串放入缓冲区        buffer.put(str.getBytes());        //反转ByteBuffer        buffer.flip();        //将ByteBuffer写入到FileChannel        channel.write(buffer);        //关闭流        os.close();    }}

    图示理解

    Java的IO模型和Netty框架是什么

    本地文件读案例

    public class ChannelNio {    public static void main(String[] args) throws IOException {        FileInputStream is = new FileInputStream("D:\\xxxxxxxxxxxxxxxxxxx\\a.txt");        FileChannel channel = is.getChannel();        ByteBuffer buffer = ByteBuffer.allocate(1024);        channel.read(buffer);        System.out.println(new String(buffer.array()));        is.close();    }}

    本地文件拷贝案例

    方法一

    public class ChannelNio {    public static void main(String[] args) throws IOException {        FileInputStream is = new FileInputStream("D:\\xxxxxxxxxxxxxxxxxxx\\a.txt");        FileChannel channel = is.getChannel();        ByteBuffer buffer = ByteBuffer.allocate(1024);        FileOutputStream os = new FileOutputStream("D:\\xxxxxxxxxxxxxxxxxxx\\b.txt");        FileChannel osChannel = os.getChannel();        while (true){            buffer.clear();            int i = channel.read(buffer);            if(i==-1){                break;            }            buffer.flip();            osChannel.write(buffer);        }        is.close();        os.close();    }}

    方法二

    public class ChannelNio {    public static void main(String[] args) throws IOException {        FileInputStream is = new FileInputStream("D:\\xxxxxxxxxxxxxxxxxxx\\HELP.md");        FileChannel channel = is.getChannel();        FileOutputStream os = new FileOutputStream("D:\\xxxxxxxxxxxxxxxxxxx\\HELP222.md");        FileChannel osChannel = os.getChannel();        osChannel.transferFrom(channel,0,channel.size());        is.close();        os.close();    }}

    Selector

    用一个线程处理多个客户端连接。可以检测多个注册通道的事件,并作出相应处理。不用维护所有线程。

    Java的IO模型和Netty框架是什么

    Selector可以获得被注册的SocketChannel的一个SelectionKey集合,然后监听select,获得有事件发生的SelectionKey,最后通过SelectionKey获得通道进行相应操作,完成业务。

    到此,关于“Java的IO模型和Netty框架是什么”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

    --结束END--

    本文标题: Java的IO模型和Netty框架是什么

    本文链接: https://lsjlt.com/news/325129.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • Java的IO模型和Netty框架是什么
      这篇文章主要介绍“Java的IO模型和Netty框架是什么”,在日常操作中,相信很多人在Java的IO模型和Netty框架是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java的IO模型和Netty框架...
      99+
      2023-06-29
    • Java笔记之从IO模型到Netty框架学习初识篇
      目录什么是NettyIO模型BIOBIO编程简单流程BIO简单实例NIOBufferBuffer基本使用Buffer四个主要属性Channel本地文件写案例本地文件读案例本地文件拷贝...
      99+
      2024-04-02
    • Java IO模型中的BIO,NIO和AIO是什么
      本篇内容主要讲解“Java IO模型中的BIO,NIO和AIO是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java IO模型中的BIO,NIO和AIO是什么”吧!一、I/O模型1.1 I...
      99+
      2023-06-29
    • Java IO中Reactor网络模型的概念是什么
      小编给大家分享一下Java IO中Reactor网络模型的概念是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、什么是 Reactor 模型:Th...
      99+
      2023-06-28
    • Redis中线程IO模型是什么
      这篇文章将为大家详细讲解有关Redis中线程IO模型是什么,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Redis是一个单线程的应用程序,NodeJs、Nginx都是单线...
      99+
      2024-04-02
    • Linux中五种IO模型是什么
      这篇文章主要介绍了Linux中五种IO模型是什么,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。我们都知道unix世界里、一切皆文件、而文件是什么呢?文件就是一串二进制流而已、...
      99+
      2023-06-27
    • Java框架解说之BIO NIO AIO不同IO模型演进之路
      目录引言IO模型1、什么是IO2、应用程序IO交互(1)计算机资源统一管理(2)底层硬件调用统一封装3、5种IO模型(1)阻塞型IO(2)非阻塞型IO(3)多路复用IO(4)信号驱动...
      99+
      2024-04-02
    • CSS中框模型是什么
      小编给大家分享一下CSS中框模型是什么,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! CSS 框模型概述 元素框的最内一小部...
      99+
      2024-04-02
    • Linux网络编程中IO模型指的是什么
      今天就跟大家聊聊有关Linux网络编程中IO模型指的是什么,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。基于IO访问中存在的两个阶段详细介绍了Linux产生的五种IO模型。同步与异步...
      99+
      2023-06-06
    • java rpc框架的功能和特点是什么
      Java RPC框架是一种用于实现远程过程调用的框架,可以让不同的Java应用程序之间进行通信和调用远程的方法。其功能和特点包括: ...
      99+
      2024-03-08
      java
    • CSS框模型的概念是什么
      这篇文章主要介绍“CSS框模型的概念是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“CSS框模型的概念是什么”文章能帮助大家解决问题。   元素框的最内部分是...
      99+
      2024-04-02
    • Java三大框架是什么
      这篇文章给大家介绍Java三大框架是什么,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Java的优点是什么1. 简单,只需理解基本的概念,就可以编写适合于各种情况的应用程序;2. 面向对象;3. 分布性,Java是面向...
      99+
      2023-06-14
    • Java集合框架是什么
      这篇文章主要介绍了Java集合框架是什么,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一、简介1、集合框架介绍Java集合框架提供了一套性能优良,使用方便的接口和类,他们位于...
      99+
      2023-06-29
    • Java中的netty原理是什么
      一、 Netty简介Netty是一个高性能、异步事件驱动的NIO框架,基于JAVA NIO提供的API实现。它提供了对TCP、UDP和文件传输的支持,作为一个异步NIO框架,Netty的所有IO操作都是异步非阻塞的,通过Future-Lis...
      99+
      2020-04-09
      java教程 java netty 原理
    • Java集合框架和数组的排序是什么
      这篇文章将为大家详细讲解有关Java集合框架和数组的排序是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。根据约定,在使用java编程的时候应尽可能的使用现有的类库,当然你也可以自己编写一...
      99+
      2023-06-17
    • Linux和Java框架:同步的挑战和机遇是什么?
      Linux和Java是当今最流行的操作系统和编程语言之一。Linux作为一种开源操作系统,已经成为许多企业的首选,而Java作为一种可移植的编程语言,已经成为企业开发中的主流选择。然而,在使用Linux和Java进行应用程序开发时,同步是...
      99+
      2023-09-18
      框架 linux 同步
    • Java的内存模型是什么
      这篇文章主要介绍“Java的内存模型是什么”,在日常操作中,相信很多人在Java的内存模型是什么问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java的内存模型是什么”的疑惑有所帮助!接下来,请跟着小编一起来...
      99+
      2023-06-15
    • ETF的框架和功能是什么
      这篇文章主要介绍“ETF的框架和功能是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“ETF的框架和功能是什么”文章能帮助大家解决问题。ETF 的架构ETF 的框架是用 Python 写的,因为这...
      99+
      2023-06-27
    • Linux和Java框架:同步的最佳实践是什么?
      随着互联网的快速发展,Linux和Java框架成为了开发者们最为熟悉和常用的技术。然而,在使用这些技术的过程中,如何合理地进行同步操作却是一个常见的难题。本文将从实践出发,结合演示代码,探讨Linux和Java框架的同步最佳实践。 一、L...
      99+
      2023-09-18
      框架 linux 同步
    • 文件框架:Java和Laravel之间的差异是什么?
      在软件开发中,文件框架是一个重要的概念,它是指一个软件系统中所有的文件和目录的组织结构。Java和Laravel是两个常用的软件开发框架,它们在文件框架方面有着明显的差异。本文将介绍Java和Laravel的文件框架差异,并通过演示代码来...
      99+
      2023-08-26
      laravel 文件 框架
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作