这一篇不涉及具体的Netty工作原理的内容,只是作为一个导读的内容来引导大家思考为什么要产生像Netty的框架。后面会写一些文章来探讨Netty的工作原理和源码实现。
多线程处理请求的模型
1. Thread per request
这种模型的结构如下:
//一个主控程序产生新的线程去处理逻辑
while(true){
acceptConnect; //没有连接来就阻塞在这里
if(hasConnect){
newThread().start(); //开户一个新的线程去处理请求
}
}
优点:
编程简单,易用于并发量不是很大的情境中。
缺点:
随着线程数目不断增长,服务器的性能也随之下降,因为开启一个线程系统要消耗8KB的内存大小。
2. Thread per request (thread pool)
针对第一种情况,提出了线程池的解决方案,这样线程数目不会随着连接数的增大而线性增加。但是它也存在问题,如果线程数目大,
线程创建和线程上下文切换是一个非常大的问题,如果线程数目少,那么对于大量的请求而言,很可能是存在连接超时的现象。
其实在我们平时常见的通信中,通信会阻塞在两个地方:
一是:接受连接时,socket.accept(),没有连接来就等待;
二是:IO操作地,read(),write(),没有数据就绪就会等待
下面通过Event Driven模型来解决这个问题。
3. Event Driven
这种模型的结构如下:
while(true){
//所有事件的触发是由操作系统来支持的
if(hasConnectEvent){ //有连接就执行相应的操作,不会阻塞在这里
doConnect();
}
if(hasReadData){ //有数据读就绪就执行相应的操作,不会阻塞在这里
doRead(); //会有一个线程来处理
}
if(hadWriteData){ //有数据写就绪就执行相应的操作,不会阻塞在这里
doWrite(); //会有一个线程来处理
}
}
这种模型就是所谓的NIO原型。这种模型在一定程序上很大的提高了并发量,但是它也存在自己的极限,那就是在读写线程中处理
速度要什么快,一般而言,线程数量达到100就很不错,如果10w并发量,那么每一个线程就要处理1000个连接,也即是每个连接
处理要什么快,如果是1s,那么不就完了,最后1000个线程要等1000s,10几分钟的时间是受不了的!
分享到:
相关推荐
Netty基础,用于学习Netty,参考黑马程序员的netty教程
springboot整合 netty做心跳检测 springboot整合 netty做心跳检测 springboot整合 netty做心跳检测 springboot整合 netty做心跳检测 springboot整合 netty做心跳检测 springboot整合 netty做心跳检测 springboot整合...
netty-3.2.5.Final.jar netty包
Netty (netty-netty-4.0.56.Final.tar.gz)是一个 NIO 客户端服务器框架,可以快速轻松地开发协议服务器和客户端等网络应用程序。它极大地简化和流线了网络编程,例如 TCP 和 UDP 套接字服务器。 “快速和简单”并...
Netty入门教程
netty-buffer-4.1.32.Final-sources.jar netty-buffer-4.1.32.Final.jar netty-build-22-sources.jar netty-build-22.jar netty-codec-4.1.32.Final-sources.jar netty-codec-4.1.32.Final.jar netty-codec-...
Netty (netty-netty-3.10.6.Final.tar.gz)是一个 NIO 客户端服务器框架,可以快速轻松地开发协议服务器和客户端等网络应用程序。它极大地简化和流线了网络编程,例如 TCP 和 UDP 套接字服务器。 “快速和简单”并...
Netty 教程 Netty权威指南 507页完整版
Netty (netty-netty-5.0.0.Alpha2.tar.gz)是一个 NIO 客户端服务器框架,可以快速轻松地开发协议服务器和客户端等网络应用程序。它极大地简化和流线了网络编程,例如 TCP 和 UDP 套接字服务器。 “快速和简单”并...
跟闪电侠学Netty:Netty即时聊天实战与底层原理-book-netty
Netty大纲-同步netty专栏
netty学习,netty进阶之路:实战,案列,进阶知识
Netty进阶之路,跟着案例学Netty,李林峰大神新作。值得一读。
netty代码demo
netty+4G DTU
Netty实战-Netty
Java进阶技术-netty进阶之路
Netty在Android开发中的应用实战系列(一)——— 搭建服务端与客户端:https://azhon.blog.csdn.net/article/details/100569489 Netty在Android开发中的应用实战系列(二)——— Encoder | Decoder | Handler 的...
Netty进阶之路 跟着案例学Netty 整本书无密码,Netty进阶之路 跟着案例学Netty
作为Java语言领域最流行、表现最优异的NIO框架,Netty深受大家喜爱,但是长期以来除了 UserGuide 之外,国内鲜有 Netty 相关的系统性文章供广大 NIO 编程爱好者学习和参考。由于 Netty 源码的复杂性和 NIO 编程本身...