gpt4 book ai didi

ruby-on-rails - Ruby on Rails - 如何缓存 API 服务响应的结果?

转载 作者:行者123 更新时间:2023-12-04 21:59:33 26 4
gpt4 key购买 nike

我有一个 RoR 3.2.3网站。它调用了 flickr.com 的 Web 服务获取我的照片列表。但这并不重要。

最重要的是,它每次都会发出一个请求——每次访问者访问我的网站时,它都会调用 flickr.com 的 Web 服务。获取照片列表。显然我想缓存 flickr 的响应大约 5 小时。就我而言,这就足够了。

那么我该怎么做呢?什么是好的或最好的方法,或者只是一般的方法?也许你有一个链接如何制作?

附言我使用 免关税 heroku.com的平面图5Mb 支持 PostgreSQL数据库。但是,如果有必要,我可以迁移到其他主机。

最佳答案

Memcached 是一个不错的选择。 Heroku 有 it built-in for free (5mb)。可以找到设置指南 here

$ heroku addons:add memcache
$ vim Gemfile
gem 'dalli'
$ vim config/environments/production.rb
config.cache_store = :dalli_store
$ heroku console
Rails.cache.stats

然后你可以将你昂贵的 API 请求包装到 Rails.cache 块中,见下面的代码:
class Flickr
def self.cached_request
Rails.cache.fetch "photos", :expires_in => 5.minutes do
flickr.photos.getRecent
end
end
end

然后要使用缓存,只需运行
Flickr.cached_request

它将触发 API 请求并将它们缓存 5 分钟。

关于ruby-on-rails - Ruby on Rails - 如何缓存 API 服务响应的结果?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11308101/

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