我希望在Java中创建一个分布式框架,并且需要一些帮助来整理客户端/管理器/工作者的实现,如下面的伪代码所述。
Manager
BEGIN
WHILE(true)
RECEIVE message FROM client
IF (worker_connections > 0) THEN
FOR (i=0;i<worker_connections;i++)
SEND message TO worker[i]
FOR (i=0;i<worker_connections;i++)
RECIEVE result[i] FROM worker[i]
SEND merge(result[]) TO client
ELSE
SEND "No workers available" TO client
END IF
END WHILE
END
Client
BEGIN
RECEIVE message FROM user
SEND message TO manager
RECEIVE message FROM manager
END
Worker
BEGIN
WHILE(true)
RECEIVE message FROM manager
result = doSomething(message)
SEND result TO manager
END WHILE
END到目前为止,我已经按照伪代码中的描述实现了客户端,但是我在管理器/工作部分遇到了问题,所以目前客户端只是收到没有工作程序可用的消息。管理器可以接受多个连接,每个连接都作为一个线程运行,但是我如何区分客户端连接和辅助连接?如何跟踪当前连接的工作人员的数量?
客户端、管理器和工作者是不同机器的代表,但我只在一台机器上进行开发(用Java)。
发布于 2011-11-26 02:03:41
发布于 2012-03-04 11:53:51
问:管理器可以接受多个连接,每个连接都作为一个线程运行,但是我如何区分客户端连接和工作者连接?
我猜你可以定义一些协议,我指的是消息的格式/语义,msg类型可能会有所帮助。此外,对于分布式系统,FIFO不能被保险存储,我想你应该使用一些机制,如序列号,逻辑时钟来处理请求和响应之间的匹配。
问:如何跟踪当前连接的工作人员数量?
首先,可以考虑登录和注销,但是并不总是可能的,特别是注销;第二,使用超时连接错误,因为发送后崩溃,可以有一些阈值,或"getResult“消息;第三,对于DS,我认为你最好应用一些选举算法,以确保始终有worker。
https://stackoverflow.com/questions/8272726
复制相似问题