1

我有一个与 RESTful 服务器交互的 PHP 客户端应用程序。客户端上的每个 PHP Goat 实例都需要根据服务器上的 /goat 请求中的信息(例如 /goat/35、/goat/36 等)进行自我初始化。它通过 cURL 向其对应的 URL 发送 HTTP 请求来实现这一点。每个页面加载处理 30 多个山羊对象相当于 30 多个 HTTP 请求,每个请求需要 0.25 秒 - 正如我的山羊所说的那样,这是 baaaad。在内存中延迟加载和缓存响应会有所帮助,但还不够。

foreach ($goats as $goat) {
   $goat->getName() // goat needs to hit the REST API
}

这种技术的优点是我的山羊都是聪明的和封装的。缺点是性能很差。山羊不知道如何排队他们的 HTTP 请求,一只山羊不知道是否有其他山羊需要发起请求,等等。我想另一种选择是在外部构建山羊:

$urls = array('http://', 'http://', ...);  // array of goat URLs
$result = fancy_pipelined_http_request_queue($urls);
foreach ($result as $xml) {
   $goat->buildSelfFromXML($xml);
}

我确信这是一个众所周知的 OO/REST 困境,有更高级的解决方法,我只是不知道去哪里找。有任何想法吗?

4

1 回答 1

1

如果您愿意,可以使用非阻塞套接字。这涉及到一些编码来切换到它们,因为您需要将 curl 踢到一边。但这可能会提高性能,因为您将真正能够同时执行请求。

请参阅socket_set_blocking / stream_set_blocking函数。

于 2009-09-23T06:52:10.110 回答