DotNetty完全教程(一)

DotNetty完全教程(一)写本系列文章的目的我一直以来都在从事 NET 相关的工作 做过工控 做过网站 工作初期维护过别人写的网络库 后来自己写网络库 我发现在使用 C 编程的程序员中 能否写出高性能的网络库一直都是考验一个程序员能力的标杆 为了写出高性能的网络库 我查阅了很多资料 发现 Java 的 Netty 有着得天独厚的设计以及实现优势 Java 也因为 Netty 的存在 在开发大吞吐量的应用程序中得心应手 我想 NET 程序

写本系列文章的目的

我一直以来都在从事.NET相关的工作,做过工控,做过网站,工作初期维护过别人写的网络库,后来自己写网络库,我发现在使用C#编程的程序员中,能否写出高性能的网络库一直都是考验一个程序员能力的标杆。为了写出高性能的网络库,我查阅了很多资料,发现Java的Netty有着得天独厚的设计以及实现优势,Java也因为Netty的存在,在开发大吞吐量的应用程序中得心应手。

我想,.NET程序员为什么不能使用这么好的应用程序框架。好在,Azure团队写出了DotNetty,使得.NET程序员也可以迅速的,便捷的搭建一个高性能的网络应用程序,但是,DotNetty并没有多少资料,项目代码中也没有多少注释,这对我们的学习以及使用带来了极大的障碍。

我通过对于Netty的研究,一步步的使用DotNetty来创建应用程序,分析DotNetty实现了哪些,没有实现哪些,实现的有何不同,希望通过最简单的描述,让读者能够了解DotNetty,无论是在工作学习中快速搭建网络应用程序还是通过分析Netty的思想,为自己写的网络库添砖加瓦都是十分有意义的。

本系列文章参考了《Netty实战》,感兴趣的同学可以去看看这本书。

Netty是什么

Netty 是一款用于创建高性能网络应用程序的高级框架。

DotNetty是什么

DotNetty是微软的Azure团队仿造Netty编写的网络应用程序框架。

优点

  1. 关注点分离——业务和网络逻辑解耦;
  2. 模块化和可复用性;
  3. 可测试性作为首要的要求

历史

  1. 阻塞Socket通信特点:
    1. 建立连接要阻塞线程,读取数据要阻塞线程
    2. 如果要管理多个客户端,就需要为每个客户端建立不同的线程
    3. 会有大量的线程在休眠状态,等待接收数据,资源浪费
    4. 每个线程都要占用系统资源
    5. 线程的切换很耗费系统资源
  2. 非阻塞Socket(NIO)特点:
    1. DotNetty完全教程(一)
    2. 如图,每个Socket如果需要读写操作,都通过事件通知的方式通知选择器,这样就实现了一个线程管理多个Socket的目的。
    3. 选择器甚至可以在所有的Socket空闲的时候允许线程先去干别的事情
    4. 减少了线程数量导致的资源占用,减少了线程切换导致的资源消耗
  3. Netty特点
    在这里插入图片描述

Netty设计的关键点

异步和事件驱动是Netty设计的关键

核心组件

  • Channel:一个连接就是一个Channel
  • 回调:通知的基础
public class ConnectHandler : SimpleChannelInboundHandler 
  
    { public override void ChannelActive(IChannelHandlerContext context) { // 新的连接建立的时候会触发这个回调 base.ChannelActive(context); } protected override void ChannelRead0(IChannelHandlerContext ctx, string msg) { throw new NotImplementedException(); } } 
  
  • Future:通知的另一种方式,可以认为ChannelFuture是包装了一系列Channel事件的对象。回调和Future相互补充,相互结合同时也可以理解Future是一种更加精细的回调。

    但是ChannelFuture在DotNetty中被Task取代

  • 事件和ChannelHandler
    ChannelHandler是事件处理器,负责处理入站事件和出站事件。通常每一个事件都由一系列的Handler处理。

本文参考资料以及截图来自《Netty实战》

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/214071.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 下午5:03
下一篇 2026年3月18日 下午5:03


相关推荐

  • java在线编辑_十大在线编译器(IDE),干货收藏!

    java在线编辑_十大在线编译器(IDE),干货收藏!文章来源:网络整理:薛定谔的coding猫1.CodeSandbox(基于React的在线代码沙盒平台)①主流的脚手架都支持,比如在线create-react-app,vue-cli等(在线fork修改),支持github登录(项目导入),也支持cli上传例子,例子可以在线访问和下载,当然也支持内嵌到其他博客等网页中。②地址:https://codesandbox.i…

    2022年7月8日
    152
  • 一款能自动生成报表的软件,工作秒完成!「建议收藏」

    一款能自动生成报表的软件,工作秒完成!「建议收藏」报表软件是企业管理的基本措施和途径,是企业的基本业务要求和实施 BI战略的基础。报表可以帮助企业访问、格式化数据,并把数据信息以可靠和安全的方式呈现给使用者,深入洞察企业运营状况,是企业发

    2022年8月1日
    8
  • VB.NET 用循环判断文本框是否为空

    VB.NET 用循环判断文本框是否为空VB.NET 用循环判断文本框是否为空

    2022年4月24日
    116
  • MITM(中间人攻击)原理及防范初探(二)

    MITM(中间人攻击)原理及防范初探(二)上一篇文章 MITM 中间人攻击 原理及防范初探 一 给大家介绍了利用 ettercap 进行 arp 欺骗及劫持明文口令 后来我发现好友 rootoorotor 的文章介绍比我写的更透彻 所以基础利用大家可以参看他的博文 很棒哦 这次我会给大家着重介绍在进行 MITM 时使用到的一个强大的嗅探工具 ettercap0x00 介绍 0x01ettercap 欺骗规则建立 0 02 攻击举

    2025年8月18日
    3
  • IDEA常用插件Top16

    IDEA常用插件Top16前言 精心推荐给大家的一些日常开发中最常用的效率插件 真心祝愿各位程序猿们开发效率提高 永不加班 一 AlibabaJavaC 代码规范检查工具 AlibabaJavaC 阿里开发的一款强大的代码规范检查工具 可以让自己写出易读性更高的代码 可以让团队代码风格尽量统一易于维护 前面博客已经介绍过了 不赘述了 Al

    2026年3月19日
    2
  • 排列汇总

    排列汇总

    2021年12月31日
    47

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号