netty的入门

netty是什么?

netty是一个基于NIO的通信框架,对于传统计算机,系统的瓶颈一直在输入输出设备上,计算速度超过IO速度,所以对于i o的性能提高异常重要。

什么是NIO?

非阻塞IO,N表示no-blocking io,简单来说就是不需要传统的IO 包中的阻塞的读写。对应jdk中的nio包,

简单而有趣的理解:

我们从应用服务器的角度,tomcat出发,我们可以每个用户连接都创建一个线程为它服务,如果有几万用户创建几万线程很恐怖,创建线程需要消耗资源的。在长期的观察中我们发现,很多用户连接上来后,很久才做一次操作( 这里的就可能是1秒,2秒,3秒等对于机器来说3秒可以做很多事),所以我们可以一个线程对应多个用户请求。

即使我们没有为一个用户独立提供一个线程,但是我们必须提供一个独立的资源给一个用户,这里对应得就是socketChanel,和channelBuffer.通过一个操作系统对这些buffer进行监听,然后socketChannel获取事件类型,传递给自己的channel 处理。

时间: 2024-12-09 12:11:51

netty的入门的相关文章

Netty快速入门(08)ByteBuf组件介绍

前面的内容对netty进行了介绍,写了一个入门例子.作为一个netty的使用者,我们关注更多的还是业务代码.也就是netty中这两种组件: ChannelHandler和ChannelPipeline---对应于NIO中的客户逻辑实现handleRead/handleWrite(interceptor pattern) ByteBuf---- 对应于NIO 中的ByteBuffer 我们的业务逻辑要放在handler里面,读写数据用的是ByteBuf.其余的Transport.ServerBoo

Netty之入门

在上篇<Netty之引题>中,分别对AIO,BIO,PIO,NIO进行了简单的阐述,并写了简单的demo.但是这里说的简单,我也只能呵呵了,特别是NIO.AIO(我全手打的,好麻烦).在开始netty开发TimeServer之前,先回顾下NIO进行服务端开发的步骤: 1.创建ServerSocketChannel,配置它为非阻塞: 2.绑定监听,配置TCP参数,如backlog大小: 3.创建独立的IO线程,用于轮询多路复用器Selector; 4.创建Selector,将之前创建的Serve

netty从入门到深入

这段时间领导让我熟悉Socket开发,我花了三周时间左右去学习相关的知识,包括Java socket开发,重点学习了netty这个异步非阻塞通信框架. 在这里把我学习过程中遇到的有用资料整理了,供大家参考. 第一步:Java 原生的Socket网络开发学习 重点掌握CS通信的基本原理和那些常用类,以及如何实现通信的过程. 这个阶段练习的demo主要有 TCP服务端到客户端,UDP的单播,组播,广播.参考博文: 1.  http://blog.csdn.net/qq_23473123/articl

Netty实战入门详解——让你彻底记住什么是Netty(看不懂你来找我)

一.Netty 简介 Netty 是基于 Java NIO 的异步事件驱动的网络应用框架,使用 Netty 可以快速开发网络应用,Netty 提供了高层次的抽象来简化 TCP 和 UDP 服务器的编程,但是你仍然可以使用底层的 API. Netty 的内部实现是很复杂的,但是 Netty 提供了简单易用的API从网络处理代码中解耦业务逻辑.Netty 是完全基于 NIO 实现的,所以整个 Netty 都是异步的. Netty 是最流行的 NIO 框架,它已经得到成百上千的商业.商用项目验证,许多

Netty从入门到放弃,从放弃在到入门

Nio的好文章:https://zhuanlan.zhihu.com/p/64537916?utm_source=wechat_session&utm_medium=social&utm_oi=660405125986914304 服务端Channel初始化过程1. 通过 BootstrapChannelFactory 实例化 NioServerSocketChannel(实例化 Channel 的具体类型又是和在初始化 ServerBootstrap 时传入的 channel() 方法的

Netty5快速入门及实例视频教程(整合Spring)

Netty5快速入门及实例视频教程+源码(整合Spring) https://pan.baidu.com/s/1pL8qF0J 01.传统的Socket分析02.NIO的代码分析03.对于NIO的一些疑惑04.Netty服务端HelloWorld入门05.Netty服务端入门补充06.Netty客户端入门07.如何构建一个多线程NIO系统08.Netty源码分析一09.Netty源码分析二10.Netty5服务端入门案例11.Netty5客户端入门案例12.单客户端多连接程序13.Netty学习

Netty系列之Netty高性能之道(转载InfoQ)

1. 背景 1.1. 惊人的性能数据 最近一个圈内朋友通过私信告诉我,通过使用Netty4 + Thrift压缩二进制编解码技术,他们实现了10W TPS(1K的复杂POJO对象)的跨节点远程服务调用.相比于传统基于Java序列化+BIO(同步阻塞IO)的通信框架,性能提升了8倍多. 事实上,我对这个数据并不感到惊讶,根据我5年多的NIO编程经验,通过选择合适的NIO框架,加上高性能的压缩二进制编解码技术,精心的设计Reactor线程模型,达到上述性能指标是完全有可能的. 下面我们就一起来看下N

Netty系列之Netty高性能之道

from:http://itindex.net/detail/49964-netty-%E7%B3%BB%E5%88%97-netty 1. 背景 1.1. 惊人的性能数据 最近一个圈内朋友通过私信告诉我,通过使用Netty4 + Thrift压缩二进制编解码技术,他们实现了10W TPS(1K的复杂POJO对象)的跨节点远程服务调用.相比于传统基于Java序列化+BIO(同步阻塞IO)的通信框架,性能提升了8倍多. 事实上,我对这个数据并不感到惊讶,根据我5年多的NIO编程经验,通过选择合适的

Netty高性能之道

1. 背景 1.1. 惊人的性能数据 最近一个圈内朋友告诉我,通过使用Netty4 + Thrift压缩二进制编解码技术,他们实现了10W TPS(1K的复杂POJO对象)的跨节点远程服务调用.相比于传统基于Java序列化+BIO(同步阻塞IO)的通信框架,性能提升了8倍多. 事实上,我对这个数据并不感到惊讶,根据我5年多的NIO编程经验,通过选择合适的NIO框架,加上高性能的压缩二进制编解码技术,精心的设计Reactor线程模型,达到上述性能指标是完全有可能的. 下面我们就一起来看下Netty