gpt4 book ai didi

java - 分布式系统

转载 作者:行者123 更新时间:2023-11-29 06:06:47 26 4
gpt4 key购买 nike

我正在寻求用 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)。

最佳答案

  • 问。如何区分客户端连接和工作器连接?
  • A.使用两个端口,一个监听来自工作人员的连接,一个监听来自客户端的连接。
  • 问。如何跟踪当前连接的工作人员数量?
  • A.有一个注册机制(可能在工作人员列表中),以便在工作人员每次连接/断开连接时进行注册/注销。

关于java - 分布式系统,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8272726/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com