当前位置: 首页 > news >正文

句容本地网站黄石下陆区建设局网站

句容本地网站,黄石下陆区建设局网站,一条龙网站建设,成都基金品牌设计NioEventLoop介绍 NioEventLoop继承SingleThreadEventLoop,核心是一个单例线程池,可以理解为单线程,这也是Netty解决线程并发问题的最根本思路--同一个channel连接上的IO事件只由一个线程来处理,NioEventLoop中的单例线程池轮询事件队列,有新的IO事件或者用户提交的task时便执…NioEventLoop介绍 NioEventLoop继承SingleThreadEventLoop,核心是一个单例线程池,可以理解为单线程,这也是Netty解决线程并发问题的最根本思路--同一个channel连接上的IO事件只由一个线程来处理,NioEventLoop中的单例线程池轮询事件队列,有新的IO事件或者用户提交的task时便执行对应的handler逻辑进行处理; NioEventLoop循环执行三件事: 响应selector中的IO事件检查任务队列中是否有用户提交的任务检查定时任务是否到期,到期则移交至任务队列中 首先,一个NioEventLoop聚合一个selector对象,这个selector对象就是JDK NIO中的selector对象(Netty可以配置选择是否对JDK 中的selector优化,优化主要是对selectionkeys集合优化,后续详细解释),通过代码可以看到,NioEventLoop的构造器里完成了selector的创建----(具体的selector创建Netty通过继承了jdk的SelectorProvider来实现的) ,先看一下NioEventLoop的构造方法,NioEventLoop只提供了一个构造方法-- NioEventLoop(NioEventLoopGroup parent, Executor executor, SelectorProvider selectorProvider,SelectStrategy strategy, RejectedExecutionHandler rejectedExecutionHandler,EventLoopTaskQueueFactory queueFactory) {super(parent, executor, false, newTaskQueue(queueFactory), newTaskQueue(queueFactory),rejectedExecutionHandler);this.provider ObjectUtil.checkNotNull(selectorProvider, selectorProvider);this.selectStrategy ObjectUtil.checkNotNull(strategy, selectStrategy);final SelectorTuple selectorTuple openSelector();this.selector selectorTuple.selector;this.unwrappedSelector selectorTuple.unwrappedSelector;}构造函数中主要完成了selector的创建,选择器的实现策略,任务队列的创建, 先大概说一下run()方法的逻辑-- 调用selector.select方法获取就绪IO事件的个数判断是否有task---非定时任务更新下一次定时任务的执行时间处理selectedKeys---处理IO事件执行任务--- 获取到期的定时任务根据配置控制任务异步任务执行时间空轮训问题的处理 看一下具体实现-- 首先获取IO就绪IO事件的个数 strategy selectStrategy.calculateStrategy(selectNowSupplier, hasTasks()); calculateStrategy方法 -- 如果当前有任务,则返回selectNow()方法的值---就绪的selected keys 个数如果没有任务则返回-1; 然后看一下strategy为-1 的时候-- //返回-1的时候表示没有任务,此时计算 case SelectStrategy.SELECT:long curDeadlineNanos nextScheduledTaskDeadlineNanos();if (curDeadlineNanos -1L) {curDeadlineNanos NONE; // nothing on the calendar}nextWakeupNanos.set(curDeadlineNanos);try { //如果还是没有任务就需要重新计算一下就绪IO事件的个数,所以第一步在没有任务的时候直接将strategy赋值为-1是为了给处理定时任务留机会;if (!hasTasks()) {strategy select(curDeadlineNanos);}} finally {//他的更新只是为了阻止不必要的选择器唤醒所以lazySet的使用是可以的没有比赛条件nextWakeupNanos.lazySet(AWAKE);} taskQueue中没有任务的时候获取定时任务中最近要生效的任务时间,然后再执行一次select方法; 之后根据ioRation(ioRation默认为50)来处理channel的IO事件和执行taskQueue中的任务;这里分三种情况: ioRation为100的时候,处理所有的IO事件并执行taskQueue中的所有任务; if (ioRatio 100) {try {if (strategy 0) {processSelectedKeys();}} finally {// Ensure we always run tasks.ranTasks runAllTasks();}} ioRation小于100并且有就绪的IO事件的时候,先处理所有的就绪IO事件,然后以处理IO事件的时间作为基准分配异步任务的执行时间 else if (strategy 0) {final long ioStartTime System.nanoTime();try {processSelectedKeys();} finally {// Ensure we always run tasks.final long ioTime System.nanoTime() - ioStartTime;ranTasks runAllTasks(ioTime * (100 - ioRatio) / ioRatio);}} ioRation小于100且没有就绪IO事件的时候只执行一个异步任务 else {ranTasks runAllTasks(0); // This will run the minimum number of tasks} 最后,判断是否发生了select是否发生了空轮训--   if (ranTasks || strategy 0) {if (selectCnt MIN_PREMATURE_SELECTOR_RETURNS logger.isDebugEnabled()) {logger.debug(Selector.select() returned prematurely {} times in a row for Selector {}.,selectCnt - 1, selector);}selectCnt 0;} else if (unexpectedSelectorWakeup(selectCnt)) { // Unexpected wakeup (unusual case)selectCnt 0;} 至此,一次Eventloop循环就处理完了,总结一下--- Eventloop是Netty运行的核心逻辑,主要处理三件事--IO读写事件,用户提交的异步任务,处理JDK中的空轮训问题;核心逻辑体现在run()方法中;run()方法首先根据异步任务队列中是否有任务需要执行来决定是否需要处理定时任务;如果有异步任务需要处理则同时获取就绪IO事件的个数;如果没有异步任务则计算定时任务的处理时间---处理完定时任务如果还是没有任务提交则轮询IO事件根据配置控制时间执行IO事件和异步任务;
http://www.w-s-a.com/news/709155/

相关文章:

  • 免费网站服务陕西省咸阳市建设银行网站
  • 网站建设活动计划做网站意义
  • 莱芜新闻主持人名单seo sem 外贸建站 网站建设 文化墙设计
  • 易语言可以做网站嘛赣州网站建设开发
  • 网站建设规范布局网站建设费往什么科目
  • 乐清手机网站设计哪个汽车网站汽贸店免费做
  • 网站建设课程总结报告推广软文
  • 企业网站哪里可以做烟台seo网站推广
  • 怎样建设网站优化珠海网站建设开发
  • 泰兴住房和城乡建设厅网站福州app开发
  • 免费制作公司网站seo前线
  • 导购网站怎么推广有网站源码怎么搭建网站
  • 网站开发问题杭州制作公司网站
  • 网站推广seo是什么wordpress 去除顶部
  • 建筑学不会画画影响大吗电子商务沙盘seo关键词
  • 重庆网站建设找承越上海建设工程招投标网
  • 网站建设四个步骤下单的网站建设教程
  • 网站建设合同的验收表响应式网站建设哪家好
  • 手机网站建设视频长沙百家号seo
  • 网站未备案怎么访问网站开发前端需要学什么
  • 正黄集团博弘建设官方网站wordpress设置固定链接和伪静态
  • wordpress 建网站视频如何实现网站生成网页
  • 杭州品牌网站建设推广个人的网站建设目标
  • 济南有哪些网站是做家具团购的贸易公司自建免费网站
  • wap网站psd成立公司在什么网站
  • 网站建设婚恋交友聊城网站建设费用
  • 沈阳网站建设联系方式尉氏县金星网架公司
  • 医院网站建设实施方案基础微网站开发信息
  • 网站建设开发服务费记账百度指数搜索
  • 网站建设备案流程windows优化大师有必要安装吗