【发布时间】:2017-06-14 03:57:43
【问题描述】:
我正在学习 ZeroMQ,并且刚刚完成了教程和一些示例。我使用 Node.js 作为我的主要环境(最终用 Python 代替了我的工人)。
试图弄清楚如何创建一个完全异步的消息传递系统,该系统将允许我的 API 将任务(通过 REQ 套接字)推送到路由器,让经销商将消息传递给一个工作人员,处理消息并将其结果发送回我的客户端(这是一个快速路由)。
我相信这个模式会像这样工作(还没有测试或正确实现代码,所以请将其作为概念大纲):
路由器.js
const zmq = require('zmq');;
const frontend = zmq.socket('router');
const backend = zmq.socket('dealer');
frontend.on('message', function() {
var args = Array.apply(null, arguments);
backend.send(args);
});
backend.on('message', function() {
var args = Array.apply(null, arguments);
frontend.send(args);
});
frontend.bindSync('tcp://*:5559');
backend.bindSync('tcp://*:5560');
client.js
var zmq = require('zmq'),
var express = require('express');
var app = express();
app.post('send', function(req, res) {
var client = zmq.socket('req');
// listen for responses from the server
client.on('message', function(data) {
console.log(data);
client.close();
});
// connect to the server port
client.connect('tcp://0.0.0.0:5454');
client.send('Request from ' + process.id);
});
app.listen('80');
worker.js
var zmq = require('zmq');
var server = zmq.socket('rep');
server.on('message', function(d){
server.send('Response from ' + process.id);
});
// bind to port 5454
server.bind('tcp://0.0.0.0:5454', function(err){
if (err){
console.error("something bad happened");
console.error( err.msg );
console.error( err.stack );
process.exit(0);
}
});
我不完全理解的是 ROUTER/DEALER 是否会处理将响应工作人员发送到正确的客户端。同样在这种情况下,经销商处理公平排队,因为我希望我的工作平均分配给工人。
我的客户端可以分布在许多不同的盒子(负载平衡器 API 服务器)中,我的路由器将在自己的服务器上,工作人员也将分布在多个盒子中。
【问题讨论】:
标签: zeromq