一卷到底,大明哥带你横扫 Netty

news2024/11/30 6:54:41

上一个死磕 Java 专栏【死磕 NIO】(当然写的不是很好,争取今年将它重写一遍)是**【死磕 Netty】**的铺垫,对于我们 Java 程序员而言,我们在实际开发过程一般都不会直接使用 Java NIO 作为我们的网络编程框架,因为写出一套高质量的 Java NIO 程序并不是一件容易的事,除了 Java NIO 固有的复杂性和 bug 之外,作为 NIO 服务端,我们要处理的事情太多了,如网络闪断、客户端认证、消息编解码、半包读写,客户端一样也有很多复杂的事情要处理,所以如果我们对 Java NIO 没有足够了解,没有足够的网络编程经验的话,利用 Java NIO 来编写一个高性能的稳定网络编程框架并不是一件容易的事。 所以我们一般都不会直接使用 Java NIO ,当然有特殊需求除外。

Netty 作为目前互联网中间件领域使用最广泛最核心的网络通信框架,它使用简单,功能强大、高性能且稳定,而且经历过大规模的生产验证,质量能够得到保障。它被广泛使用,几乎所有互联网中间件或者大数据领域均离不开 Netty,比如知名的 Dubbo、RocketMQ,Spark、ES 等等。所以掌握 Netty 是作为一名初中级工程师迈向高级工程师最重要的技能之一。

为什么要学 Netty

可能有小伙伴说,在实际工作中我并没有用到 Netty,对网络编程涉及的内容也不多,都是些业务逻辑,那还有必要花精力来学习 Netty 吗?当然如果你止步于 CRUD boy ,不想进大厂,不追求高薪的话,确实是没有必要学习 Netty,连这篇文章你也可以不用再看了,因为后面我都是来说服你要学 Netty 的。

在互联网大厂的中高级面试中,网络编程绝对是一个必问的栏目,只要涉及到网络编程必问 Netty,因为 Netty 是考察一个人 Java 内功最佳的面试题,因为它涉及的知识点多,而且重要。比如:

  1. 网络协议相关知识点
  2. 内存处理相关知识点
  3. IO 及 OS 内核相关知识点
  4. Java 并发相关知识点
  5. 数据结构相关知识点
  6. 设计模式相关知识点

是不是只要一个 Netty 就可以把面试官想问的全部都问了?确实是这样,不仅可以问,而且它们是环环相扣,紧密关联的,大明哥在网上收集并整理了一些 Netty 面试题:

  1. Netty 的核心有哪些,这些组件承担的角色是什么?
  2. 说说你对 Reactor 模式的理解,Netty 采用的是哪种线程模型?这种线程模式的优势在哪里?
  3. 说说什么是粘包和粘包?怎么产生的?有哪些解决方案?Netty 又提供了哪些方案?
  4. 什么是零拷贝(Zero-Copy)?Netty 提供了哪些零拷贝的技术?Netty如何利用零拷贝来提升性能的?
  5. 内存池了解吗?解释下内存池在Netty中的作用。
  6. 内存泄露了解吗?如何避免内存泄露?Netty 是如何避免内存泄露的?又提供了哪些检测机制?
  7. 了解堆外内存吗?Netty 是怎么规避堆外内存泄露的?
  8. 知道断线重连功能吗?怎么实现的?Netty 的重连机制是怎么样的?它的作用又是什么?
  9. 解释一下心跳检测在 Netty 中的原理和应用场景。
  10. Netty如何处理网络中断和异常?
  11. 知道异步编程吗?JDK 的 Future 的核心原理是什么? Promise 呢?Future和Promise在Netty中的角色是什么?
  12. 什么是ChannelPipeline ?它采用了哪种设计模式?Netty 中使用了哪些设计模式?你在实际生产环境使用过哪些?怎么使用的?

这 12 连问能顶住吗?涉及到的知识点是不是及其广泛而且重要,而且这些还是没有延伸的,比如问 Netty 内存池,就可以延伸到堆内堆外内存,由此可以推到 JVM ,GC 相关知识点等等。线程模型可以延伸到 Java 的线程池,任务调度去。还有锁、性能优化等等。

所以,通过学习 Netty,可以把 Java 大壁江山的知识点都串连起来,达到融会贯通的作用。当你掌握 Netty 后,你对 I/O 模型 、内存管理、线程模型、数据结构、Java 并发等知识点基本上都会有一个更加深层次的认识。

所以,来和大明哥一起卷 Netty 吧!!

为什么写死磕 Netty

有小伙伴可能会问,现在市面上这么多 Netty 教程,从入门、实战到源码,几乎 Netty 的所有知识点都可以在网上找到,为什么还要花大精力来写这个课程呢?但是,不知道小伙伴们注意没有,这些资料都是零散的啊,很难找到系统性的学习 Netty 课程,比如在讲 Netty 的内存模型,网上几乎所有的资料就仅仅只是 Netty 的内存模型,但是大明哥会讲解操作系统的内存管理,内存管理算法,以及内存分配器 jemalloc 和 Netty 的内存模型,Netty 的内存模型我不仅仅有理论知识还有源码分析。在比如 Netty 的 ByteBuf 组件,市面很多资料都仅仅只介绍 ByteBuf 的 API 使用,但是大明哥会讲 ByteBuf API、零拷贝、内存分配机制以及源码等等。

死磕 Netty 绝对是大明哥目前死磕系列写的最最认真的,课程非常详细,整个课程分为四个部分:入门、进阶、实战、源码,文章数量不少于 120 篇。最最重要的是这个也是我学习 Netty 的路径,个人认为这是一个比较好且完备的学习路径。

当然大明哥也不是 Netty 高手,在生产环境也没有经过大规模的应用,对 Netty 也有很多理解不到位的地方,所以文章难免出错的地方,提前打招呼,免得到时被骂,O(∩_∩)O哈哈~!!!!

最后贴一个课程的全局图例:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1095815.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【C++初阶(二)缺省参数与函数重载】

本专栏内容为:C学习专栏,分为初阶和进阶两部分。 通过本专栏的深入学习,你可以了解并掌握C。 💓博主csdn个人主页:小小unicorn ⏩专栏分类:C 🚚代码仓库:小小unicorn的代码仓库&…

Kwik Trip IT系统遭遇神秘的“网络事件”导致系统故障

导语 近日,美国连锁便利店和加油站Kwik Trip遭遇了一系列神秘的业务中断,这很可能是一次赎金软件攻击。本文将为您详细介绍此次事件的背景和影响,并探讨赎金软件攻击对企业和个人的危害。 神秘的“网络事件” Kwik Trip是一家在密歇根州、明尼…

云上攻防-云原生篇K8s安全Config泄漏Etcd存储Dashboard鉴权Proxy暴露

文章目录 云原生-K8s安全-etcd未授权访问云原生-K8s安全-Dashboard未授权访问云原生-K8s安全-Configfile鉴权文件泄漏云原生-K8s安全-Kubectl Proxy不安全配置 云原生-K8s安全-etcd未授权访问 攻击2379端口:默认通过证书认证,主要存放节点的数据&#x…

14 | 乐观锁机制和重试机制在实战中应该怎么用

什么是乐观锁? 乐观锁在实际开发过程中很常用,它没有加锁、没有阻塞,在多线程环境以及高并发的情况下 CPU 的利用率是最高的,吞吐量也是最大的。 而 Java Persistence API 协议也对乐观锁的操作做了规定:通过指定 Ve…

服务器感染了.360、.halo勒索病毒,如何确保数据文件完整恢复?

导言: 数据的安全性至关重要,但威胁不断进化,.360、.halo勒索病毒是其中的令人担忧的勒索软件。本文91数据恢复将深入介绍.360、.halo勒索病毒,包括其威胁本质、数据恢复方法和如何采取预防措施来保护您的数据。 如果受感染的数据…

智慧公厕高精尖技术揭秘,让卫生管理更智能、更舒适

随着科技的飞速发展,智慧公厕正逐渐走进人们的生活。借助物联网、互联网、云计算、大数据、人工智能、自动化控制等技术的应用,智慧公厕将卫生管理提升到一个全新的水平,为公众打造了清洁舒适的使用环境。本文以智慧公厕源头厂家广州中期科技…

94. 二叉树的中序遍历(递归+迭代)

题目链接:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台 解题思路: 方法一:递归 中序遍历的操作定义为,若二叉树为空,则空操作,否则: 中序遍历左子树访问根节点中…

✔ ★【备战实习(面经+项目+算法)】 10.15学习时间表

✔ ★【备战实习(面经项目算法)】 坚持完成每天必做如何找到好工作1. 科学的学习方法(专注!效率!记忆!心流!)2. 每天认真完成必做项,踏实学习技术 认真完成每天必做&…

【Vue面试题二十六】、SSR解决了什么问题?有做过SSR吗?你是怎么做的?

文章底部有个人公众号:热爱技术的小郑。主要分享开发知识、学习资料、毕业设计指导等。有兴趣的可以关注一下。为何分享? 踩过的坑没必要让别人在再踩,自己复盘也能加深记忆。利己利人、所谓双赢。 面试官:SSR解决了什么问题&…

【Vue面试题二十九】、Vue项目中你是如何解决跨域的呢?

文章底部有个人公众号:热爱技术的小郑。主要分享开发知识、学习资料、毕业设计指导等。有兴趣的可以关注一下。为何分享? 踩过的坑没必要让别人在再踩,自己复盘也能加深记忆。利己利人、所谓双赢。 面试官:Vue项目中你是如何解决跨…

京东优惠券怎么找?

京东优惠券怎么找? 1、手机安装「草柴」后,打开京东挑选要购买的商品; 2、挑选好京东商品后,点击右上角的「分享」,并点击「复制链接」; 3、将复制的京东商品链接,粘贴到草柴输入框&#xff0c…

查找算法:二分查找、插值查找、斐波那契查找

二分查找 查找的前提是数组有序 思路分析 代码实现 # 二分查找(递归法实现) # 找到一个相等的值就返回该值的下标 def binary_search(arr: list, find_val: int, left: int, right: int):mid (left right) // 2 # 寻找数组中间位置的下标if left &…

MySQL进阶(再论JDBC)——JDBC编程思想的分析 JDBC的规范架构 JDBC相关的类分析

前言 SQL(Structured Query Language)是一种用于管理关系型数据库的标准化语言,它用于定义、操作和管理数据库中的数据。SQL是一种通用的语言,可以用于多种关系型数据库管理系统(RDBMS),如MySQ…

自动泊车系统设计学习笔记

1 概述 1.1 自动泊车系统研究现状 目前对于自动泊车系统的研究方法通常有两种实现方式: 整个泊车操作可以分为四个阶段:第一阶段车辆向前行驶进行车位识别,第二阶段车辆行驶到准备泊车时的待泊车区域,第三阶段车辆按照规划好的…

联邦学习综述三

A Survey on Federated Learning Systems Vision Hype and Reality for Data Privacy and Protection 选自:IEEE Transactions on Knowledge and Data Engineering,2021 链接 本文主要从数据分布、机器学习模型、隐私机制、通信架构、联邦规模和联邦动…

aps.net core 6.0 web API SwaggerUI IIS部署【23.10.15】亲测,通过

目录 一、aps.net core 6.0 web API 项目配置 创建项目设置 Swagger UI 为起始页发布项目二、在 IIS 部署 安装IIS安装 Hosting Bundle三、内网穿透 使用的是 VS2022社区版,WebAPI的版本是 .netcore6.0 一、aps.net core 6.0 web API 项目配置 1.创建项目 运行项目…

网络层哪些事?

在本文讲解的网络层中,注意了解一下:IP协议! 地址管理:每个网络上的设备,要能分配一个地址(唯一)路由选择:A给B发消息,具体走哪条路线?? IP地址&…

kube-controller-manager和kube-scheduler不能正常启动

kube-controller-manager-k8s-worker01和kube-scheduler-k8s-worker01没有启动起来 原因: 解决:进入/etc/kubernetes/manifests 编辑 将镜像地址修改为 然后重启kubelet:systemctl restart kubelet.service

JVM 垃圾回收机制(可达性分析、引用计数)

目录 1 什么是垃圾2 为什么需要回收3 哪些对象被判定为垃圾呢3.1 引用计数法3.2 可达性分析算法:GC Roots根 1 什么是垃圾 垃圾是指在运行程序中没有任何指针指向的对象,就是需要被回收的。 2 为什么需要回收 执行程序会不断地分配内存空间&#xff0c…

快速上手 vue3

快速上手 vue3 文章目录 1. 组合式 api2. 路由3. 定义全局方法和变量4. 父子组件调用 --> 自定义事件5. 生命周期函数6. 状态管理 vuex 1. 组合式 api setuprefreactivecomputed生命周期钩子 , onMounted … 2. 路由 安装路由: npm install vue-router 创建一个 router…