Netty入门指南之基础介绍

news2024/11/16 13:40:52

作者简介:☕️大家好,我是Aomsir,一个爱折腾的开发者!
个人主页:Aomsir_Spring5应用专栏,Netty应用专栏,RPC应用专栏-CSDN博客
当前专栏:Netty应用专栏_Aomsir的博客-CSDN博客

文章目录

  • 参考文献
  • 介绍
  • 为什么要学习Netty?
  • Netty能帮助我们做什么?
  • 什么是NIO编程?
  • 总结

参考文献

  • 孙哥suns说Netty
  • Netty官方文档

介绍

  • Netty是一个异步事件驱动网络应用框架。用于快速开发可维护的高性能协议服务器和客户端。
  • Netty是一个NIO客户服务器框架,它能够快速和容易地开发网络应用,如协议服务器和客户端。它大大精简了网络编程,如TCP和UDP套接字服务器。快速和简单 "并不意味着开发出来的应用程序会出现可维护性或性能问题。
  • Netty的设计是经过精心设计的,其经验来自于许多协议的实施,如FTPSMTPHTTP以及各种基于二进制和文本的遗留协议。因此,Netty成功地找到了一种方法来实现开发的简易性、性能、稳定性和灵活性,而没有任何妥协。
    在这里插入图片描述

为什么要学习Netty?

  1. Netty已经成为Java网络通信编程的行业标准,被广泛认可和采用。它为构建高性能、可扩展的网络应用提供了强大的工具和框架
  2. Netty在多个领域得到广泛应用,特别是在游戏行业和需要实时通信的领域。其卓越的性能和灵活性使其成为这些行业的首选
  3. Netty不仅仅用于应用程序的开发,还广泛用于许多框架的通信底层,用于解决进程间通信的需求。一些知名的开源框架如DubboRocketMQWebFlux等都将Netty作为其通信的核心组件,因此学习Netty将帮助您更好地理解和使用这些框架

Netty能帮助我们做什么?

在回答这个问题之前,我们结合Java中的 Socket编程以及HTTP协议服务端开发的原理来进行讲解

  1. 创建一个ServerSocket,绑定一个端口并监听启动
  2. 一系列客户端来请求这个IP:端口
  3. 服务器使用Accept,获得每一个来自客户端的Socket连接对象
  4. 启动一个新线程处理连接
    • Socket,得到字节流
    • 解码协议数据,得到HTTP请求对象
    • 处理Http请求,得到一个结果,封装成一个HttpResponse对象
    • 编码协议,将结果序列化字节流
    • 写Socket,将字节流发给客户端
  5. 继续循环步骤3

HTTP服务器之所以称为HTTP服务器,是因为 编码解码的协议是HTTP协议,如果协议是Redis协议,那它就成了Redis服务器,如果协议是WebSocket,那它就成了WebSocket服务器。

为啥上面这些步骤,我作为一个初级程序员很少写到,几乎只在学习TCP/UDP网络编程的时候见到过?因为我们日常都写HTTP接口,服务端基本都在使用Tomcat,不需要我们去处理。

所以使用Netty你就可以定制编解码协议,实现使用自己的特定协议的服务器与客户端,而不是啥情况都使用HTTP。HTTP虽好可不要贪杯嗷

有了Netty,作为Java程序员的我们就可以自己去实现HTTP服务器、FTP服务器、WebSocket服务器、Dubbo服务器、gRPC服务器

什么是NIO编程?

在前面的内容中,我们讨论了HTTP协议服务端的开发,其中涉及了Socket网络编程和多线程。然而,当并发性较高时,可能会出现问题,尤其是线程创建数量的问题。值得注意的是,这里强调的是高并发情况。在这种情况下,可能会涉及大量线程的创建和管理。

为了解决这一问题,Java引入了NIO技术,它代表着一种I/O多路复用的方法。全称为非阻塞I/O(NonBlocking I/O),与传统的阻塞I/O(Blocking I/O,BIO)不同。通过NIO,我们能够在单个线程内有效地管理多个通道,从而减少线程的创建数量,降低系统开销。

然而,NIO本身可能仍然相对复杂,需要开发人员自行处理底层细节。正是在这一点上,Netty作为一个高级网络应用框架,进一步封装了NIO,提供了更加高级的抽象和易于使用的API。Netty负责处理诸多底层复杂性,包括事件处理、并发、缓冲区管理以及自定义协议的支持,使得开发者能够更专注于应用程序的逻辑,而不必深入处理NIO的复杂性。

此外,Netty还提供了多种有用的组件,如编解码器处理器事件处理机制,以更容易地构建服务器和客户端应用,处理协议的编解码、数据包处理和其他任务。这些特性使Netty成为构建高性能、可扩展和易维护的网络应用的理想选择

总结

今天带着了解了Netty的本质,NIO的工作原理,以及Netty在网络应用开发中的潜力。这些知识为我们提供了灵活性和选择性。

在今后的开发中,如果HTTP/1协议无法满足我们的需求,我们不必依赖HTTP协议或Tomcat服务器。相反,我们可以选择其他更高效的协议,或者利用Netty来自行开发服务端和客户端,以满足特定需求。我们可以通过Netty来自定义协议,实现更多定制化的功能和性能优化。

这种灵活性和自主权使我们能够更好地满足不同应用场景的需求,为开发更高性能、定制化的网络应用提供了广阔的机会

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

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

相关文章

报错:AttributeError: module ‘tensorflow‘ has no attribute ‘flags‘

改成如下: 报错原因:tensorflow1.x与2.x版本问题不兼容

重装操作系统后 gitee:Failed to create Gitee Repository

错误描述 重装系统后,提交项目代码到gitee程序报错: 11:21 Failed to create Gitee Repositorydetected dubious ownership in repository at E:/Workspaces/SpringBoot/saTokenE:/Workspaces/SpringBoot/saToken is owned by:S-1-5-21-1301660696-421…

【已解决】ubuntu耳机单侧有声音

背景 台式机,双系统:win10 ubuntu 20.04;ubuntu 系统当中,左侧耳机有声音,右侧没有; 解决方法 终端输入:alsamixer,显示下面的图片: 调整方法:键盘上下左…

微信native-v3版支付对接流程及demo

1.将p12证书转为pem证书,得到商户私钥 openssl pkcs12 -in apiclient_cert.p12 -out apiclient_cert.pem -nodes 密码是:商户id 2.将获取到的apiclient_cert.pem证书,复制出这一块内容,其他的不要 3.下载这个工具包 https://gi…

Sqoop技术文档笔记

Sqoop是一个用于在Hadoop和关系型数据库之间传输数据的开源工具。它可以将结构化数据从关系型数据库(如MySQL、Oracle、SQL Server等)导入到Hadoop的分布式文件系统(HDFS)或hive中,并且可以将数据从HDFS、hive导出到关…

数据分析在游戏行业的应用

数据分析在游戏行业中扮演着至关重要的角色,它可以用于以下方面: 1、玩家行为分析 了解玩家在游戏中的行为,包括游戏时长、最喜欢的游戏模式、关卡通过率等,从而为游戏设计和运营提供参考。 2、留存率 监控玩家在游戏中的持续参…

ChatGPT/GPT4科研技术应用与AI绘图及论文高效写作

2023年我们进入了AI2.0时代。微软创始人比尔盖茨称ChatGPT的出现有着重大历史意义,不亚于互联网和个人电脑的问世。360创始人周鸿祎认为未来各行各业如果不能搭上这班车,就有可能被淘汰在这个数字化时代,如何能高效地处理文本、文献查阅、PPT…

交换奇偶位

写一个宏,可以将一个整数的二进制位的奇数位和偶数位交换。 要交换二进制位的奇数位和偶数位,那么肯定要先拿到奇数位和偶数位,然后让奇数位左移一位,偶数位右移一位,再将移动后的这两组数相加就可以了(一个…

【网络安全】被恶意攻击的IP地址有多可怕?

被恶意攻击的IP地址可以导致一系列问题,其严重性和可怕程度取决于攻击的性质、目标、攻击者的动机以及受影响的系统或组织。以下是一些可能出现的问题和可怕性的因素: 数据泄露和盗窃:攻击者可能试图入侵系统,窃取敏感数据&#x…

barzilar_borwein算法微调函数的优化收敛

import optimtool as oo from optimtool.base import np, sp, pltpip install optimtool>2.4.2加载barzilar_borwein算法 import optimtool.unconstrain as ou barzilar_borwein ou.gradient_descent.barzilar_borwein初始化输入数据 f ( x ) ∑ i 1 n / 2 c ( x 2 i −…

ZKP4.2 SNARKs via Interactive Proofs (Sum-check Protocol [LFKN90])

ZKP学习笔记 ZK-Learning MOOC课程笔记 Lecture 4: SNARKs via Interactive Proofs (Justin Thaler) 4.3 Interactive proof design: Technical Preliminaries SZDL Lemma Equal test (in multivariate polynomials) Low-Defree and Multilinear Extensions Extensions …

新版多功能去水印工具微信小程序源码下载+带流量主功能

新版多功能去水印工具微信小程序源码下载,带流量主功能。自带去水印接口的多功能小程序,支持各大平台短视频去水印。 支持保存封面、图集、标题等等;支持本地图片去水印;支持图片拼接;支持九宫格切图;支持修…

程序环境、预处理和宏

前言: 目录 一、程序的翻译环境 二、运行环境 三、预处理 1.预处理上的文本操作 Ⅰ注释的删除 Ⅱ头文件的包含 Ⅲ#define的替换 2.预定义符号 3.#define Ⅰ #define 定义标识符 Ⅱ #define 定义宏 Ⅲ #define 替换规则 Ⅳ #和## 四、宏和函数的区别 …

一文浅析Linux 中断处理

1. 中断的概念 中断是指在CPU正常运行期间,由于内外部事件或由程序预先安排的事件引起的 CPU 暂时停止正在运行的程序,转而为该内部或外部事件或预先安排的事件服务的程序中去,服务完毕后再返回去继续运行被暂时中断的程序。Linux中通常分为…

东方通部署vue项目

在东方通中部署vue项目需要以war 的形式进行部署具体操作步骤如下 1. 正常打包完vue 项目 在其项目目录下创建WEB-INF 文件夹,同时在里面新建一个 rewrite.config 的文件文件具体内容如下: RewriteRule ^/index\.html$ - [L]RewriteCond …

【树莓派图像处理】

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、Qt OPENCV 安装测试?运行Qt错误 二、使用步骤1.框架1. 开启摄像头2.获取显示图像的内容 2.测试 总结 前言 提示:这里可以添加本文要…

uniapp 测试 app 到安卓模拟器部署方法以及常见错误解决 无废话

uniapp 测试 app 到安卓模拟器 1.1 安装安卓模拟器 https://www.yeshen.com/ 1.2 查看安装模拟器端口 右击夜神模拟器属性打开文件位置 在打开的文件夹找到 debugReport 双击运行查看运行出来的端口号 一般都是:62001 1.3 HBuilder 配置 选中项目运行运行到手机…

TSINGSEE青犀AI智能分析算法助力小区规范整改:楼道杂物堆放检测

小区楼道属于公共消防通道,是小区居民出行的唯一通道,但由于物业管理不到位或业主个人素质问题,经常存在在楼梯间堆放杂物的问题,严重影响居民日常出行,也增加了楼道消防安全隐患。为做到彻底解决小区楼道堆积杂物问题…

Python数据挖掘实用案例——自动售货机销售数据分析与应用

🚀欢迎来到本文🚀 🍉个人简介:陈童学哦,目前学习C/C、算法、Python、Java等方向,一个正在慢慢前行的普通人。 🏀系列专栏:陈童学的日记 💡其他专栏:CSTL&…

即使密码正确,App Store可能也会不断询问密码,那么如何修复呢

当你从app Store购买并安装应用程序时,你需要使用Apple ID和密码登录以确认你的帐户。然而,许多iOS用户面临的情况是,无论他们输入多少次,App Store都会不断要求输入密码。你的iPhone是否也会不断提示你输入密码? 事实上,即使你输入了好几次正确的密码,App Store也会不…