腾讯高工手写13W字“Netty速成手册”,3天走向实战

news/2024/11/28 20:48:21/

前言

在java界,netty无疑是开发网络应用的拿手菜。你不需要太多关注复杂的nio模型和底层网络的细节,使用其丰富的接口,可以很容易的实现复杂的通讯功能。

作为当前最流行的NIO框架,Netty在互联网领域、大数据分布式计算领域、游戏行业、通信行业等获得了广泛的应用,一些业界著名的开源组件也基于Netty构建,比如RPC框架、zookeeper等。由此可见,掌握Netty技术对于开发人员来说是非常重要的。

为了让更多的开发人员学习好Netty,特此公布:腾讯高工手写的13万字的“Netty速成手册”。

第一部分:Netty的概念及体系结构

1.Netty——异步和事件驱动(Java网络编程+Netty简介+Netty的核心组件)

2.你的第一款Netty应用程序(设置开发环境+Netty客户端/服务器概览+编写Echo服务器+编写Echo客户端+构建和运行Echo服务器和客户端)

3.Netty的组件和设计

4.传输(案例研究:传输迁移+传输API+内置的传输+传输的用例)

5.ByteBuf(ByteBuf的API+ByteBuf类——Netty的数据容器+字节级操作+ByteBufHolder接口+ByteBuf分配+引用计数)

6.ChannelHandler和ChannelPipeline(ChannelHandler家族+ChannelPipeline接口+ChannelHandlerContext接口+异常处理)

7.EventLoop和线程模型(线程模型概述+EventLoop接口+任务调度+实现细节)

8.引导(Bootstrap类+引导客户端和无连接协议+引导服务器+从Channel引导客户端+在引导过程中添加多个ChannelHandler+引导DatagramChannel+关闭)

9.单元测试(EmbeddedChannel概述+使用EmbeddedChannel测试ChannelHandler+测试异常处理)

第二部分:编解码器

1.编解码器框架(什么是编码器?+解码器+编码器+抽象的编解码器类)

2.预置的ChannelHandler和编解码器(通过SSL/TLS保护Netty应用程序+构建基于Netty的HTTP/HTTPS应用程序+空闲的连接和超时+解码基于分隔符的协议和基于长度的协议+写大型数据+序列化数据)

第三部分:网络协议

1.WebSocket(WebSocket简介+我们的WebSocket示例应用程序+添加WebSocket支持+测试该应用程序)

2.使用UDP广播事件(UDP的基础知识+UDP广播+UDP示例应用程序+消息POJO: LogEvent+编写广播者+编写监视器+运行LogEventBroadcaster和LogEventMonitor)

第四部分:案例研究

1.案例研究(上)

2.案例研究(下)

总结

为什么要学习Netty?作为开发人员,你到今天还没有找到答案吗?

对于流行的新技术,我们要懂得它的重要性,世界在发展,时代在更替,技术也在进步,而我们有什么理由拒绝呢?


http://www.ppmy.cn/news/62816.html

相关文章

Javascript面试题:20道含答案和代码示例的练习题

请写出一个将字符串转换为数字的函数,例如将字符串“123”转换为数字123。 function stringToNumber(str) {return Number(str); }请写出一个将数字转换为字符串的函数,例如将数字123转换为字符串“123”。 function numberToString(num) {return num.…

【ED合集】事件检测的文章

1 CorED: Incorporating Type-level and Instance-level Correlationsfor Fine-grained Event Detection 论文来源:SIGIR 2022(CCF A类会议) 论文链接:https://dl.acm.org/doi/pdf/10.1145/3477495.3531956 代码链接:GitHub - JiaweiSheng…

GPU理解

什么是GPU GPU(Graphics Processing Unit)代表图形处理单元。该术语通常与图形卡或视频卡等术语互换使用。从技术上讲,GPU 是第三方显卡或主板上的主要图形处理芯片。 GPU 与 CPU不同。CPU 是中央处理器,它是计算机的主要大脑。GPU 专用于执行在计算机…

基础语法——笔记一

一、基础语法 编码 源码文件以UTF-8编码,所有字符串都是Unicode字符串标识符 第一个字符必须是字母表中的字母或下划线_ 标识符的其他部分由字母、数字、下划线组成 标识符对大小写敏感python保留字(关键字) 不能用于任何标识符输出python标…

MVCC

相关数据库知识点回顾 1.1 什么是数据库事务,为什么要有事务 事务,由一个有限的数据库操作序列构成,这些操作要么全部执行,要么全部不执行,是一个不可分割的工作单位。 ​假如A转账给B 100 元,先从A的账户里扣除 100 元…

8个方法判断一个项目是否值得投资

01看准 投资就是投人,投资就是投团队,尤其要看准团队的领头人。 对目标企业团队成员的要求是:富有激情、和善诚信、专业敬业、善于学习。 02发掘 发掘---两大优势(优势行业、优势企业) 在优势行业中发掘、寻找优势…

yarn的安装以及使用

4.1 安装yarn 在npm的基础上写 npm i -g yarn ​ 查看是否成功: yarn -v#注 : 有的安装yarn成功之后 会发现yarn既不是内部命令也不是外部命令,解决办法 1. yarn global bin 得到一个yarn的安装地址 C:\Users\你自己的电脑\AppData\Local\Yarn\bin 2…

Web缓存利用分析(三)

导语:前一篇文章介绍了Server Cache Poisoning在实际应用场景下,产生DOS攻击的利用方式。本篇文章则介绍Web Cache Deception在真实场景下的应用方式和测试情况。 前言 前一篇文章介绍了Server Cache Poisoning在实际应用场景下,产生DOS攻击…