różnica między pub-sub i push-pull w zeroMq

Te dwa zdjęcia pochodzą z http://zguide.zeromq.org/page:all .

Jaka jest różnica między tymi dwoma wzorami, jeśli zignorujemy sink we wzorze push-pull ? Czy jest różnica w tym, jak wiadomość otrzymuje transfer, jeśli tak, to jaka jest różnica ?

Author: Community, 2013-07-23

1 answers

Różnica polega na tym, że gniazdo PUBwysyła tę samą wiadomość do wszystkich Abonentów, podczas gdy PUSHwykonuje round-robin wśród wszystkich podłączonych gniazd PULL.

W twoim przykładzie, jeśli wyślesz tylko jedną wiadomość z katalogu głównego, wszyscy subskrybenci otrzymają ją (z wyjątkiem powolnych subskrybentów itp.), ale tylko 1 robotnik.

Wzorzec pub/sub jest używany do szerokiego rozpowszechniania wiadomości według tematów. Wzór push / pull jest tak naprawdę mechanizmem pipelining. Twój przykład push / pull wydaje się próbować równoważenia obciążenia, co jest w porządku, ale req / rep może być lepiej dostosowany do tego z powodu innych problemów.

Wygląda na to, że" problemy " są opisane w tej samej części przewodnika 0MQ, z którego otrzymałeś obrazek: przykład wentylatora push/pull

 60
Author: SteveLove,
Warning: date(): Invalid date.timezone value 'Europe/Kyiv', we selected the timezone 'UTC' for now. in /var/www/agent_stack/data/www/doraprojects.net/template/agent.layouts/content.php on line 54
2013-10-02 18:00:56