Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

reactor vs proactor

Could anyone explain the difference between reactor-pattern and proactor-pattern? I know that in reactor-pattern the operations are synchronous and in proactor they're asynchronous and also that in reactor the operation is done by the handler which is handed over to the client by the reactor. (correct me if i am wrong)

Also Which of these pattern is used in case of fail safe and which is used in fail fast?

like image 324
vishnu viswanath Avatar asked Aug 08 '12 07:08

vishnu viswanath


2 Answers

In reactor pattern you will poll device for readiness to do something, while in proactor you do something and poll for its completion.

The good examples for reactor pattern are: epoll(Linux), kqueue(MacOS, FreeBSD), select(Linux, MacOS, Windows) approaches. The good example for proactor pattern is Windows IOCP approach.

like image 147
Aqua Avatar answered Nov 04 '22 18:11

Aqua


Referencing Fail fast or fail safe? as well as wiki articles I would say that proactor is fail-safe and reactor is fail-fast. Proactor having a completion handler gives it a more "safe" approach. A synchronous environment such as reactor will have large fail if one task fails while blocking a large amount of resources. Hope this helps.

like image 3
Matthew Hammel Avatar answered Nov 04 '22 18:11

Matthew Hammel