《Netty实战》读书笔记(一)

简介: 《Netty实战》读书笔记(一)

Netty——异步和事件驱动


  • JAVA网络编程
  • Netty简介
  • Netty核心组件


Netty是什么?



基于java NIO的进一步升级,也是真正意义上的异步非阻塞的模型,使用最小的资源开销来达到最大的性能


  • 支持多种通讯协议
  • 高度的抽象,隐藏底层实现细节
  • 简单易用
  • IO性能良好

核心思想:使用最小的开销来实现最高效率的能力


核心组件:


  • Channel
  • 回调
  • Future 设计模式
  • 事件和ChannelHandle


Channel


可以看做一个黑盒,载体,可以输入和输出


回调


一个指向被提供给另一个方法的引用


Future

核心组件之一

用于实现异步通知

interface java.util.concurrent.Future是JDK预置的接口的完成通知形式

由 ChannelFutureListener 提供的通知机制

每次的IO都会产生一个ChannelFutrue


事件和ChannelHandler


由于Netty是事件驱动的,将整个IO拆分为下面的事件

  • 连接事件
  • 数据读取
  • 用户事件
  • 错误事件
  • 关闭连接事件
  • 数据写入


谁在使用它?


  • Elastic Search
  • Kibana


为什么要学netty?


  • 高并发框架
  • 极高的IO性能
  • 对于NIO有进一步的扩展
  • 将关注点由底层转向业务实现
  • 大大的降低了网络编程,IO,多线程复杂结构


Netty的同类框架


  • hadoop
  • 大数据框架
  • elasticsearch
  • 为什么es性能那么强,底层就是netty
  • Mina


如何学习?


  • 看书
  • 写案例
  • netty的历史


代理设置:
127.0.0.1
端口:
1080
具体设置:
windows10.microdone.cn
复制代码


JAVA 网络编程



阻塞I/O样板代码



大致流程:

  • 创建一个ServerSocket,用来监听客户端请求
  • 调用**accept()**核心方法,该方法会产生阻塞,等待请求创建
  • 使用socket获取输出和输出流对象,一般使用包装buffer对应提高读写效率
  • 创建流对象
  • 读取数据,处理请求数据,得到处理后的响应信息,最后在进行处理

accept()方法做了什么事情:

  1. 初始化,创建socketImpl()实现类
  2. 校验套接字
  3. 检测请求是否合法
  4. 异常处理

阻塞I/O的优点:

  • 简单易懂
  • 对于并发量不是很大情况可以很好的处理

阻塞I/O的缺点:

  • 每一个请求就要建立一个线程,并且要一直等待,资源浪费
  • 开启的线程数取决于操作系统,
  • 上下文切换的代价昂贵

示范代码:


public static void main(String[] args) throws IOException {
        // 1. 创建一个套接字
        ServerSocket socket = new ServerSocket(8080);
        // 创建一个请求对象
        Socket accept = socket.accept();
        // 获取输入流和输出流
        BufferedReader in = new BufferedReader(new InputStreamReader(accept.getInputStream()));
        PrintWriter out = new PrintWriter(accept.getOutputStream());
        // 创建流对象
        String request, response;
        while ((request =in.readLine())!=null){
            // 读取字节流数据
            if(request.equals("Done")){
                break;
            }
            // 调用服务器处理流数据的方法,处理请求流
            response = processRequest(request);
            out.println(response);
        }
    }
复制代码


JAVA NIO


原理:调用本地套接字的非阻塞套接字


  • 使用setsockept()配置套接字,读写的时候没有数据可以返回
  • 使用事件通知的API注册非阻塞的套接字

非阻塞I/O是 jdk1.4引入的

这里有个很大的误区:

NIO是不是非阻塞的?

结论:错误

原因:

NIO是 1.4引入的,它不再新了,而且该API其实内部还是阻塞的,后面会讲到

class java.nio.channels.Selector 非阻塞IO的实现类

优点:

  • 较少的线程处理很多链接
  • 没有IO的时候可以执行其他操作


编写第一个Netty应用程序



环境准备


  • Apach maven
  • JDK1.7以上


开发工具


  • IntelinJ IDEA 2019版本
相关文章
|
8月前
Netty实战: HTTP文件列表服务器
Netty实战: HTTP文件列表服务器
88 0
|
8月前
|
【Netty技术专题】「原理分析系列」Netty强大特性之Native transports扩展开发实战
当涉及到网络通信和高性能的Java应用程序时,Netty是一个强大的框架。它提供了许多功能和组件,其中之一是JNI传输。JNI传输是Netty的一个特性,它为特定平台提供了高效的网络传输。 在本文中,我们将深入探讨Netty提供的特定平台的JNI传输功能,分析其优势和适用场景。我们将介绍每个特定平台的JNI传输,并讨论其性能、可靠性和可扩展性。通过了解这些特定平台的JNI传输,您将能够更好地选择和配置适合您应用程序需求的网络传输方式,以实现最佳的性能和可靠性。
155 7
【Netty技术专题】「原理分析系列」Netty强大特性之Native transports扩展开发实战
阿里内部Netty实战小册,值得拥有
Netty 是一个高性能的 Java 网络通信框架,简化了网络编程并涵盖了最新的Web技术。它提供了一种抽象,降低了底层复杂性,使得更多开发者能接触网络编程。Netty 因其易用性、高效性和广泛的应用场景受到推崇,适合互联网行业从业者学习,有助于理解和开发基于Netty的系统。免费的《Netty实战小册》详细介绍了Netty的各个方面,包括概念、架构、编解码器、网络协议和实际案例,帮助读者深入理解和应用Netty。如需完整版小册,可点击链接获取。
阿里内部Netty实战小册,值得拥有
(十一)Netty实战篇:基于Netty框架打造一款高性能的IM即时通讯程序
关于Netty网络框架的内容,前面已经讲了两个章节,但总归来说难以真正掌握,毕竟只是对其中一个个组件进行讲解,很难让诸位将其串起来形成一条线,所以本章中则会结合实战案例,对Netty进行更深层次的学习与掌握,实战案例也并不难,一个非常朴素的IM聊天程序。
121 3
Netty实战巅峰:从零构建高性能IM即时通讯系统,解锁并发通信新境界
【8月更文挑战第3天】Netty是一款高性能、异步事件驱动的网络框架,适用于开发高并发网络应用,如即时通讯(IM)系统。本文将指导你利用Netty从零构建高性能IM程序,介绍Netty基础及服务器/客户端设计。服务器端使用`ServerBootstrap`启动,客户端通过`Bootstrap`连接服务器。示例展示了简单的服务器启动过程。通过深入学习,可进一步实现用户认证等功能,打造出更完善的IM系统。
222 1
(十)Netty进阶篇:漫谈网络粘包、半包问题、解码器与长连接、心跳机制实战
在前面关于《Netty入门篇》的文章中,咱们已经初步对Netty这个著名的网络框架有了认知,本章的目的则是承接上文,再对Netty中的一些进阶知识进行阐述,毕竟前面的内容中,仅阐述了一些Netty的核心组件,想要真正掌握Netty框架,对于它我们应该具备更为全面的认知。
277 2
|
8月前
|
Netty实战:模拟Redis的客户端
Netty实战:模拟Redis的客户端
110 0
聚焦实战技能,剖析底层原理:Netty+Redis+ZooKeeper+高并发实战
移动时代、5G时代、物联网时代的大幕已经开启,它们对于高性能、高并发的开发知识和技术的要求,抬升了Java工程师的学习台阶和面试门槛。
13W字!腾讯高工手写“Netty速成手册”,3天能走向实战
在java界,netty无疑是开发网络应用的拿手菜。你不需要太多关注复杂的nio模型和底层网络的细节,使用其丰富的接口,可以很容易的实现复杂的通讯功能。
Netty Review - 深入探讨Netty的心跳检测机制:原理、实战、IdleStateHandler源码分析
Netty Review - 深入探讨Netty的心跳检测机制:原理、实战、IdleStateHandler源码分析
480 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等