Reactor Pattern and Non-blocking IO

·        Java server class with multiple client connections: one-to-one ratio of threads to clients, therefore enormous thread overhead, resulted in performance problems and lack of scalability. The main problem is blocking I/O calls. html

·         JDK 1.4 supports non-blocking I/O calls (java.nio and java.nio.channels). These packages were designed principally according to Reactor design pattern (Using Design Patterns to Develop Reusable Object-Oriented Communication Software by Douglas C. Schmidt). java

 

 

The actors in Reactor pattern are: react

• Handles, which identify resources (such as network connections, open files, and synchronization api

objects) that are managed by an operating system. session

• Reactor, which defines an interface for registering, removing, and dispatching Event Handler app

objects. An implementation of the Reactor interface provides a set of application-independent ide

event demultiplexing and dispatching mechanisms. These mechanisms dispatch application-specific spa

Event Handler in response to events occurring on one or more Handles. scala

• Event Handler, which specifies an interface used by the Reactor to dispatch callback methods orm

defined by objects that are pre-registered to handle certain types of events (such as input events,

output events, and signals).

• Concrete Event Handler, which implements the customized callback method(s) that process events

in an application-specific manner.

 

Using Reactor in Communication Software

 

Example

相關文章
相關標籤/搜索