Netty 学习笔记(4) ------ EventLoopGroup
EventLoopGroup负责管理Channel的事件处理任务,继承自java.util.concurrent包下的Executor,所以其结构类似与线程池,管理多个EventLoop。
而一个EventLoop将由一个永远不会改变的Thread驱动,同时任务(Runnable或者Callable)可以直接提交给EventLoop实现。
另外,一个EventLoop可能会被指派用于服务多个Channel,Channel对应的I/O事件(或者说它绑定的ChannelHandler处理器)都由该EventLoop的Thread进行处理。
EventLoop分配
异步传输(NIOEventloopGroup)

EventLoopGroup负责为每个新创建的Channel分配一个EventLoop,目前使用轮询算法分配。一个EventLoop可以被分配给多个Channel。
一个Channel的生命周期都使用相同的EventLoop处理事件,这意味着在只涉及一个Channel状态变化的处理不用担心其线程安全问题。但是对于ThreaLocal要考虑多Channel共享问题。
同步传输(OIOEventLoopGroup)

同步传输与异步传输的区别在于一个EventLoop只能分配给一个Channel。
EventLoop处理任务流程

如果当前线程是EventLoop的线程,那么任务将被直接执行;如果不是,任务将会进入EventLoop的内部队列(每个EventLoop都有自己的队列,不同与线程池)。
由于Channel的事件都由特定的线程处理,所以长时间的任务或者阻塞任务不要放入EventLoop中处理,不然会阻塞该EventLoop上其他的任务。Netty的作者建议是使用一个专门的Executor处理。
参考资料
Netty in action
Netty 学习笔记(4) ------ EventLoopGroup的更多相关文章
- Netty学习笔记(二) 实现服务端和客户端
		
在Netty学习笔记(一) 实现DISCARD服务中,我们使用Netty和Python实现了简单的丢弃DISCARD服务,这篇,我们使用Netty实现服务端和客户端交互的需求. 前置工作 开发环境 J ...
 - Netty 学习笔记(1)通信原理
		
前言 本文主要从 select 和 epoll 系统调用入手,来打开 Netty 的大门,从认识 Netty 的基础原理 —— I/O 多路复用模型开始. Netty 的通信原理 Netty 底层 ...
 - Netty学习笔记-入门版
		
目录 Netty学习笔记 前言 什么是Netty IO基础 概念说明 IO简单介绍 用户空间与内核空间 进程(Process) 线程(thread) 程序和进程 进程切换 进程阻塞 文件描述符 文件句 ...
 - Netty学习笔记(二)——netty组件及其用法
		
1.Netty是 一个异步事件驱动的网络应用程序框架,用于快速开发可维护的高性能协议服务器和客户端. 原生NIO存在的问题 1) NIO的类库和API繁杂,使用麻烦:需要熟练掌握Selector.Se ...
 - Netty学习笔记(六) 简单的聊天室功能之WebSocket客户端开发实例
		
在之前的Netty相关学习笔记中,学习了如何去实现聊天室的服务段,这里我们来实现聊天室的客户端,聊天室的客户端使用的是Html5和WebSocket实现,下面我们继续学习. 创建客户端 接着第五个笔记 ...
 - Netty学习笔记(一)
		
学习圣思园Netty笔记,个人理解 2.netty宏观理解-本节内容: 1.阶段性事件驱动,一个请求分为若干阶段处理,每个阶段根据情况合理分配线程去处理,各阶段间通信采用异步事件驱动方式. 2.net ...
 - Netty学习笔记(一):接收nodejs模拟表单上传的文件
		
好久不写博客了,也好久不写代码了,这两天临时遇上一个事情,觉得不难,加上觉得手有些生,就动手做了一下,结果遇上了不少坑,有新坑,有老坑,痛苦无比,现在总算差不多了,赶紧记录下来,希望以后不再重复这种痛 ...
 - Netty学习笔记(三) 自定义编码器
		
编写一个网络应用程序需要实现某种编解码器,编解码器的作用就是讲原始字节数据与自定义的消息对象进行互转.网络中都是以字节码的数据形式来传输数据的,服务器编码数据后发送到客户端,客户端需要对数据进行解码, ...
 - 2018/1/19 Netty学习笔记(一)
		
这段时间学了好多好多东西,不过更多是细节和思想上的,比如分布式事物,二次提交,改善代码质量,还有一些看了一些源码什么的; 记录一下真正的技术学习,关于Netty的学习过程; 首先说Netty之前先说一 ...
 
随机推荐
- Redis持久性——RDB和AOF
			
Redis持久性 Redis提供了不同的持久性选项: RDB持久性以指定的时间间隔执行数据集的时间点快照. AOF持久性记录服务器接收的每个写入操作,将在服务器启动时再次播放,重建原始数据集.使用与R ...
 - vwware虚拟机网卡的三种模式
			
这里在虚拟机中必须要保证右上角的两个勾选上 三种模式:简单一个比如宿主机器直接连接路由器上网,那虚拟机和宿主机器是一定的可以上外网,相当于虚拟机直接连接在路由器上面,虚拟机需要配置可以上外网的IP地址 ...
 - 一起玩转微服务(12)——揭密starter
			
介绍 Spring Boot的starter主要用来简化依赖用的,对于企业级开发中的与第三方的集成,可以通过一段简单的配置来完成,这样开发人员无需再对包依赖的问题头疼.Spring Boot为我们提供 ...
 - vue环境配置脚手架搭建,生命周期,钩子
			
Vue项目环境搭建 """ node ~~ python:node是用c++编写用来运行js代码的 npm(cnpm) ~~ pip:npm是一个终端应用商城,可以换国内 ...
 - Python实用笔记 (12)函数式编程——高阶函数
			
函数式编程的一个特点就是,允许把函数本身作为参数传入另一个函数,还允许返回一个函数! Python对函数式编程提供部分支持.由于Python允许使用变量,因此,Python不是纯函数式编程语言. 变量 ...
 - 如何去除List集合中重复的元素
			
1.通过循环进行删除 public static void removeDuplicate(List list) { for ( int i = 0 ; i < list.size() - 1 ...
 - Django迁移命令无法生成mysql表
			
数据库迁移问题:在执行python manage.py makemigrations迁移命令之后,正常输出并生成迁移文件,但执行python manage.py migrate之后显示,No migr ...
 - (八十九)c#Winform自定义控件-自定义滚动条(treeview、panel、datagridview、listbox、listview、textbox)
			
官网 http://www.hzhcontrols.com/ 前提 入行已经7,8年了,一直想做一套漂亮点的自定义控件,于是就有了本系列文章. GitHub:https://github.com/kw ...
 - 二、web自动化快速使用
			
1.启动浏览器 from selenium import webdriver # 启动谷歌浏览器,依赖:先安装好chromedriver.exe驱动 # 方式1.当chrome.driver放在p ...
 - 【树形DP】洛谷P2585 [ZJOI2006] 三色二叉树
			
[树形DP]三色二叉树 标签(空格分隔): 树形DP [题目] 一棵二叉树可以按照如下规则表示成一个由0.1.2组成的字符序列,我们称之为"二叉树序列S": 0 该树没有子节点 1 ...