一直在考虑在Amazon Cloudfront上缓存我的JSON。
问题是,在更新JSON时手动清除缓存可能需要15分钟。
有没有办法将简单的JSON值存储在类似CDN的http缓存中 -
更新
回应AdamKG的观点:
如果它正在“更新”,那么它不是静态的:D写一个新版本和 告诉您的服务器使用新的URL。
我的实际想法是每次html页面更改时缓存新的CloudFront网址。这是我最初的重点。
我想要JSON的原因是存储最新CloudFront网址的版本号。这样我可以进行AJAX调用以发现要加载的版本,然后进行第二次AJAX调用以实际加载内容。这样我就不需要使CloudFront内容过期,我只是重定向加载它的ajax。
但后来我遇到了需要缓存的JSON问题。我不希望人们每次想要看到单个JSON版本号时都会击中Heroku发电机。我知道memcache和机架可以帮助我提高速度,但这是一个我不想要的问题。
我有过一些想法:
答案 0 :(得分:4)
一种方法是使用资产到期,类似于Rails静态资产过期的方式。 Rails为文件名添加了哈希签名,因此application.js
之类的内容变为application-abcdef1234567890.js
。然后,每次用户请求您的页面时,如果application.js已更新,则脚本标记具有新地址。
以下是我设想你这样做的方法:
User → CloudFront (CDN) → Your App (Origin)
用户请求http://www.example.com/
。该页面包含元标记
<meta content="1231231230" name="data-timestamp" />
基于您上次更新JSON资源的时间。如果您使用Rails,则可以从<%= Widget.order(updated_at: :desc).pluck(:updated_at).first.to_i %>
之类的内容生成。
然后,在您的应用程序的JavaScript中,获取时间戳并将其用于您的JSON URL。
var timestamp = $('meta[name=data-timestamp]').attr('content');
$.get('http://cdn.example.com/data-' + timestamp + '.json', function(data, textStatus, jqXHR) {
blah(data);
});
对CloudFront的第一个请求将在/data/data-1231231230.json
点击您的原始服务器,该服务器可以永久生成和缓存。每次更新JSON时,用户都会获得一个新的URL来查询CDN。
由于您提到实际页面是您要大量缓存的内容,因此您可以选择几个选项。如果您真的想在服务器前放置CloudFront,那么您唯一真正的选择是每次主页更新时发送失效请求。您可以免费每月无效1,000次,之后每1000次无效5次。此外,CloudFront失效并不快,在页面更新之前您仍会有延迟。
另一种选择是将您的内容缓存在Memcached中并从您的dynos中提供。我将根据您的询问历史假设您正在使用Ruby on Rails或其他Ruby框架(但如果您不是,请澄清)。这需要安装Rack::Cache。 Heroku上的说明用于缓存资产,但这也适用于动态内容。接下来,每次更新页面时都要使用Rack :: Cache的invalidate
方法。是的,你的dyno将处理一些负载,但它将是一个简单的Memcached查找和响应。
您的服务器布局如下所示:
用户→CloudFront(CDN)→Rack :: Cache→您的应用程序(源)在cdn.example.com上 用户→Rack :: Cache→您的应用程序(Origin)在www.example.com
上当您提供图片,CSS和JavaScript等静态资源时,请使用cdn.example.com域。这将通过CloudFront路由请求,并且它们将被缓存很长一段时间。对您的应用程序的请求将直接发送到您的Heroku dyno,可缓存的部分将由Rack :: Cache存储和检索。