· 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