0

如果我有一个 RESTful 服务,该服务通过端点具有可发现的资源,例如:

要求:

GET http://acme.org/someInfo

回复:

HTTP/1.1 200 OK
Content-Length: ...
Content-Type: application/vnd.acme+xml
Date: Fri, 16 Dec 2012 12:40:00 GMT
Last-Modified: Tue, 1 Mar 2012 11:45:00 GMT

<someInfo xmlns="http://schemas.acme.org/someInfo" xmlns:dap="http://schemas.acme.org/dap">
    <dap:link rel="http://relations.acme.org/someInfo" uri="htp://acme.org/someInfo/foo" />
    <dap:link rel="http://relations.acme.org/someInfo" uri="htp://acme.org/someInfo/bar" />
    <dap:link rel="http://relations.acme.org/someInfo" uri="htp://acme.org/someInfo/baz" />
</someInfo>

然后有了这个响应,客户端可以跟随其中一个超媒体链接:

要求:

GET http://acme.org/someInfo/foo

回复:

HTTP/1.1 200 OK
Content-Length: ...
Content-Type: application/vnd.acme+xml
Date: Fri, 16 Dec 2012 12:45:00 GMT
Last-Modified: Wed, 28 Sep 2012 11:45:00 GMT

<fooInfo xmlns="http://schemas.acme.org/fooInfo">
...
</fooInfo>

第一个响应可能会不太频繁地更改(例如:很多个月),而第二个响应可能会稍微更频繁地更改(例如:每个月左右)。对于这种情况,什么是好的 HTTP 缓存策略?按日期,客户 ETag 比较,还有别的吗?

编辑:如果数据在一天左右的数量级上是陈旧的,那很好。再多的话可能会有问题。

4

1 回答 1

0

这是一个性能与一致性问题,实际上只能由业务部门来回答。

对于每个资源,您需要问两个问题:

  1. 如果资源发生变化而用户在 X 小时内没有看到这种变化,那么业务影响是什么?如果用户没有看到温度变化,反应堆会爆炸吗?
  2. 查看该资源的新版本需要多少费用?您是在 1Gbps 本地网络上,还是通过西伯利亚的手机访问它?

一旦您知道让这些数据保持最新的价值以及获取这些数据的成本,那么您就可以决定最佳的缓存策略。

于 2011-12-16T19:03:44.857 回答