1

语境

  • 我有一个应用程序可以对 Ruby 中的文本进行耗时的处理。
  • 当用户提交文本时,会派生一个后台进程来处理该文本。
  • 这个过程不断输出文本的新部分,因为它们已被处理。
  • 同时,用户被重定向到将输出处理后的文本的页面。

我的问题是:给定 PID,客户端的 Javascript 如何与服务器上运行的进程通信?那可能吗?我是否需要将每个后台进程包装在其自己的 servlet 中,该 servlet 在其自己的端口上运行?

4

4 回答 4

2

它无法访问进程空间。您需要一个 HTTP 接口来执行此操作。您可以使用长轮询来执行此操作。服务器可以定期输出文本,客户端脚本可以长时间轮询它。

在此处查看长轮询示例: 如何实现基本的“长轮询”?

于 2012-04-15T18:02:00.127 回答
2

考虑使用 websocket。在我的 Zend 应用程序中,我编写了一个将数据包发送到 JS 的代理脚本。另一种方法是让 setTimeout 每隔 x 秒询问一次 http 服务器,如果进程已经完成。

于 2012-04-15T18:02:34.313 回答
1

最简单的方法是使用PusherPubNub或类似方法,因此您可以将代码推送到包含 PID 的频道,并且客户端可以订阅相同的频道。这样您就不需要设置 HTTP 应用程序。

于 2012-04-15T18:05:01.457 回答
1

这是我最终使用的策略:

  • 创建一个小的 Sinatra servlet 来管理不同的作业。
  • 收到的每个作业请求都分配有一个作业 ID,并在分离的分叉进程中启动。
  • 分叉的进程使用用作堆栈的数组设置 DRb 服务。
  • 然后它在将作业 ID 与 DRb URI 相关联的 servlet 上执行“GET”请求。
  • 随着进程在后台继续执行,它会将元素添加到堆栈中。
  • 可以轮询主线程以返回堆栈中的下一个元素。
    • 在 servlet 中建立与远程数组的连接,并从堆栈中移动一个元素。
    • 轮询一直持续到堆栈上没有更多元素要添加并且没有更多元素要返回给客户端为止。
  • 当堆栈为空时,进程终止。

有什么想法吗?

于 2012-04-17T04:52:16.373 回答