- 浏览: 26143 次
- 性别:
- 来自: 北京
文章分类
- 全部博客 (53)
- NIO (0)
- JAVA多线程 (1)
- JVM (1)
- IO (1)
- 设计模式 (27)
- netty (0)
- 设计原则 (1)
- netty源码 (0)
- linux (1)
- tcp (0)
- http (0)
- IP (0)
- 子网掩码 (0)
- 网关 (0)
- cipher (0)
- tomcat (0)
- servlet (0)
- cpu (0)
- JavaEvent (0)
- java锁 (1)
- 索引、缓存 (0)
- java锁,并发编程 (0)
- java并发编程 (0)
- java内存模型 (0)
- java并发包 (0)
- 微服务 (3)
- java数据结构 (0)
- java基础 (5)
- 钱 (0)
- 汇编 (0)
- JVM调优 (1)
- springmvc (3)
- 常见排序算法 (6)
- mongodb (0)
- springmvc注释解读英译汉 (2)
- JNI (0)
- MySQL (0)
- guava (0)
- 操作系统 (0)
Reactor设计模式
reactor设计模式,是一种基于事件驱动的设计模式。将一个或多个客户的服务请求分离(demultiplex)和调度(dispatch)给应用程序。
在Reactor模式中,有5个关键的参与者:
- 1.描述符(handle):由操作系统提供,用于识别每一个事件,如Socket描述符、文件描述符等。在Linux中,它用一个整数来表示。事件可以来自外部,如来自客户端的连接请求、数据等。事件也可以来自内部,如定时器事件。
- 2.同步事件分离器(demultiplexer):是一个函数,用来等待一个或多个事件的发生。调用者会被阻塞,直到分离器分离的描述符集上有事件发生。Linux的select函数是一个经常被使用的分离器。
- 3.事件处理器接口(event handler):是由一个或多个模板函数组成的接口。这些模板函数描述了和应用程序相关的对某个事件的操作。
- 4.具体的事件处理器:是事件处理器接口的实现。它实现了应用程序提供的某个服务。每个具体的事件处理器总和一个描述符相关。它使用描述符来识别事件、识别应用程序提供的服务。
- 5.Reactor 管理器(reactor):定义了一些接口,用于应用程序控制事件调度,以及应用程序注册、删除事件处理器和相关的描述符。它是事件处理器的调度核心。 Reactor管理器使用同步事件分离器来等待事件的发生。一旦事件发生,Reactor管理器先是分离每个事件,然后调度事件处理器,最后调用相关的模 板函数来处理这个事件
Reactor负责等待事件、分离事件和调度事件,实际上,Reactor管理器并没有被具体的 事件处理器调用,而是管理器调度具体的事件处理器,
图中的handle对应的是操作系统提供的句柄,例如I/O句柄,Event_Handler类持有这些句柄,
package com.jenny.model.callback.nioreactor; import java.io.IOException; import java.net.InetSocketAddress; import java.nio.channels.SelectionKey; import java.nio.channels.Selector; import java.nio.channels.ServerSocketChannel; import java.nio.channels.SocketChannel; import java.util.Iterator; /** * Created by jenny on 9/16/15. */ public class Reactor implements Runnable { private ServerSocketChannel serverSocketChannel = null; private Selector selector = null; public Reactor() { try { selector = Selector.open(); serverSocketChannel = ServerSocketChannel.open(); serverSocketChannel.configureBlocking(false); serverSocketChannel.socket().bind(new InetSocketAddress(8888)); SelectionKey selectionKey = serverSocketChannel.register(selector, SelectionKey.OP_ACCEPT); selectionKey.attach(new Acceptor()); System.out.println("服务器启动正常!"); } catch (IOException e) { System.out.println("启动服务器时出现异常!"); e.printStackTrace(); } } public void run() { while (true) { try { selector.select(); Iterator<SelectionKey> iter = selector.selectedKeys().iterator(); while (iter.hasNext()) { SelectionKey selectionKey = iter.next(); dispatch((Runnable) selectionKey.attachment()); iter.remove(); } } catch (IOException e) { e.printStackTrace(); } } } public void dispatch(Runnable runnable) { if (runnable != null) { runnable.run(); } } public static void main(String[] args) { new Thread(new Reactor()).start(); } class Acceptor implements Runnable { public void run() { try { SocketChannel socketChannel = serverSocketChannel.accept(); if (socketChannel != null) { System.out.println("接收到来自客户端(" + socketChannel.socket().getInetAddress().getHostAddress() + ")的连接"); new Handler(selector, socketChannel); } } catch (IOException e) { e.printStackTrace(); } } } }
package com.jenny.model.callback.nioreactor; import java.io.IOException; import java.nio.ByteBuffer; import java.nio.channels.SelectionKey; import java.nio.channels.Selector; import java.nio.channels.SocketChannel; /** * Created by jenny on 9/16/15. */ public class Handler implements Runnable { private static final int READ_STATUS = 1; private static final int WRITE_STATUS = 2; private SocketChannel socketChannel; private SelectionKey selectionKey; private int status = READ_STATUS; public Handler(Selector selector, SocketChannel socketChannel) { this.socketChannel = socketChannel; try { socketChannel.configureBlocking(false); selectionKey = socketChannel.register(selector, 0); selectionKey.interestOps(SelectionKey.OP_READ); selectionKey.attach(this); selector.wakeup(); } catch (IOException e) { e.printStackTrace(); } } public void run() { try { if (status == READ_STATUS) { read(); selectionKey.interestOps(SelectionKey.OP_WRITE); status = WRITE_STATUS; } else if (status == WRITE_STATUS) { process(); selectionKey.cancel(); System.out.println("服务器发送消息成功!"); } } catch (IOException e) { e.printStackTrace(); } } public void read() throws IOException { ByteBuffer buffer = ByteBuffer.allocate(1024); socketChannel.read(buffer); System.out.println("接收到来自客户端(" + socketChannel.socket().getInetAddress().getHostAddress() + ")的消息:" + new String(buffer.array())); } public void process() throws IOException { String content = "Hello World!"; ByteBuffer buffer = ByteBuffer.wrap(content.getBytes()); socketChannel.write(buffer); } }
Hollywood principle:"Don't call me; I'll call you."
发表评论
-
设计模式基础之类关系
2016-05-23 16:23 300类与类之间的表示关系 依赖关系 :简单的理解 ... -
设计模式之访问者模式Visitor
2016-05-19 09:24 514访问者模式 实现思路:向对象结构类中添加元素 ... -
gof23种设计模式之总结
2016-07-28 15:12 402总体来说设计模式分为三大类: 创建型模式:共五种: ... -
设计模式之备忘录模式memento
2016-05-17 14:06 300备忘录模式 就是保存某个对象内部状态的拷贝,这样以后就 ... -
设计模式之外观模式Facade
2016-05-17 14:07 324外观模式 核心 为子系统提供统一的入口,封装子 ... -
设计模式之桥接模式bridge
2016-05-17 14:07 358设计模式之桥接模式bridge 场景 商城系统中 ... -
设计模式之装饰者模式Decorator
2016-05-17 14:06 285装饰者模式 职责 动态的为一个对象增加新的功能 ... -
观察者模式与发布/订阅模式区别
2016-05-15 23:09 307观察者模式与发布/订阅模式区别 在翻阅资料的 ... -
设计模式之单例模式
2016-05-17 14:08 292单例模式 核心作用 保证一个类中只有一个实例,并 ... -
设计模式之创建者模式Builder
2016-05-18 09:27 265创建者模式 场景 我们要建造一个复杂的产品,比如 ... -
设计模式之适配器模式Adapter
2016-05-18 09:28 274适配器模式Adapter 什么是适配器模式? 将一个类 ... -
设计模式之原型模式
2016-05-18 09:28 330原型模式 通过new产生一个对象需要非常繁琐的数 ... -
设计模式之工厂模式
2016-05-18 09:27 286工厂模式 本质 实例化对象,用工厂方法代替new ... -
设计模式之观察者模式Observer
2016-05-18 09:29 335场景 网站上很多 ... -
设计模式之责任链模式
2016-05-19 09:25 339责任链模式 场景: 公司里面,报销个单据需要经过 ... -
设计模式之组合模式composite
2016-05-10 13:57 314组合模式 内容 把部分和整体的关系用树形结构来表示,从 ... -
设计模式之享元模式
2016-05-10 10:56 348场景: 内存属于稀缺资源,不要随便浪费。如果有很多个完全 ... -
设计模式之迭代器模式
2016-05-09 17:02 247迭代器模式 提供一种可以遍历聚合对象的方式,又称curs ... -
设计模式之中介者模式
2016-05-09 10:51 320中介者模式 假如没有总经理,下面三个部门,财务部、市 ... -
设计模式之中介者模式
2016-05-19 10:09 400中介者模式 假如没有总经理,下面六个个部门,财务部 ...
相关推荐
### Reactor设计模式详解 #### 一、引言 Reactor设计模式是一种广泛应用于网络编程中的行为模式,它主要用于处理并发服务请求。该模式通过分离事件处理与事件分发的功能来提高系统的可扩展性和可维护性。本文将...
Reactor模式是一种事件驱动的设计模式,主要用于解决高并发场景下的系统设计问题,而Java的NIO(Non-blocking Input/Output,非阻塞I/O)是Java平台提供的一种I/O模型,它支持基于事件的多路复用,为实现Reactor模式...
两种高性能IO设计模式(Reactor和Proactor)比较 在高性能服务器设计中,I/O设计模式扮演着至关重要的角色。常见的I/O设计模式有阻塞型、非阻塞同步型和非阻塞异步型。其中,非阻塞异步型I/O设计模式是性能最高、...
本文旨在详细介绍这些I/O模型,并着重解析Reactor模式与Proactor模式的设计思想及其应用场景。 #### 二、同步阻塞I/O (Blocking I/O) 同步阻塞I/O是最基本且最直观的I/O处理方式。在这种模式下,应用程序发出I/O...
Reactor模式是一种事件驱动的设计模式,它主要用于处理并发I/O操作,通过将I/O事件的处理与事件处理程序解耦,实现高效的异步处理。在高并发环境下,Reactor模式可以显著提升系统性能,因为它避免了线程阻塞等待I/O...
6. 策略模式:ACE的策略模式体现在其可插拔的策略接口上,如ACE_Selector和ACE_Reactor,它们可以根据需要选择不同的调度和事件处理策略。 7. 装饰者模式:ACE提供了一种动态地增加或修改对象功能的方法,例如,ACE...
.NET Reactor是一款功能强大的代码保护以及许可授权管理系统软件,主要用于开发人员保护其.NET软件程序,.NET Reactor支持所有支持.NET编译的程序开发语言。 .NET Reactor 4.9是目前最新版本,由大神yoza破解,亲测...
Reactor 和 Proactor 模式是两种常见的事件处理模式,在网络编程中广泛应用于设计高效、可靠的并发和网络应用程序。在本文中,我们将详细介绍 Reactor 和 Proactor 模式的概念、特点、优缺点,以及在网络编程中的...
分析常见高性能网络设计模式,涵盖了reactor, proactor。
"Observer(观察者)"和"Reactor(反应器)"是两种广泛应用于并发和事件驱动编程的设计模式。 Observer模式的核心在于定义了一对多的依赖关系,当一个对象(主题)的状态发生改变时,所有依赖于它的对象都会被自动...
Reactor模式是一种设计模式,常用于处理并发I/O事件。在多路复用I/O(如epoll、kqueue)中,Reactor模式是关键组成部分,它负责监听和分发事件到相应的处理器。Netty的Reactor模型主要由三部分组成:主线程...
Java编程方法论中,Spring Reactor、Reactor-Netty和Spring Webflux是现代Java开发中用于构建反应式应用程序的关键组件。Spring Reactor是响应式流(Reactive Streams)规范的实现,它提供了用于处理异步事件和数据...
在React框架中,Reactor是其核心库之一,专门用于构建响应式应用程序。本篇文章将详细解读Reactor 3的中文帮助文档,帮助用户理解非阻塞响应式框架的使用方法及其原理,尤其是Spring WebFlux底层实现的相关知识。 ...
赠送jar包:reactor-core-3.4.14.jar; 赠送原API文档:reactor-core-3.4.14-javadoc.jar; 赠送源代码:reactor-core-3.4.14-sources.jar; 赠送Maven依赖信息文件:reactor-core-3.4.14.pom; 包含翻译后的API文档...
赠送jar包:reactor-core-3.4.10.jar; 赠送原API文档:reactor-core-3.4.10-javadoc.jar; 赠送源代码:reactor-core-3.4.10-sources.jar; 赠送Maven依赖信息文件:reactor-core-3.4.10.pom; 包含翻译后的API文档...
dotNET Reactor 使用步骤图解 dotNET Reactor 是一个功能强大的.NET 保护工具,它可以帮助开发者保护他们的.NET 程序集免受反编译和逆向工程的攻击。下面是 dotNET Reactor 的使用步骤图解: 选择文件 dotNET ...
ACE Reactor是ACE库中的核心组件之一,它是事件驱动设计模式的一种实现,用于处理并发事件。在这个“ACE_Reactor.rar”压缩包中,包含的可能是关于如何使用ACE Reactor来构建服务器端程序的相关资料。 首先,我们来...