- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我目前正在运行一个 AWS EC2 Ubuntu 服务器,该服务器从 Postgres RDS 数据库实例中获取数据。在特定页面的 View 函数中使用的 SQL 查询之一有很多连接,运行速度很慢。我试图减少查询并删除一些可能有点不必要的连接,但它仍然需要比预期更长的时间来加载(至少 6 秒)。我目前正在研究潜在的缓存策略以帮助加快页面服务。
我考虑过使用物化 View ,但是原始 View 函数获取的数据平均每 30 秒更新一次,我担心实现触发器或常规 cron 作业来刷新 MatView 这通常需要它对数据库造成的损失,并且可能不是定期更新和更改的数据的最佳策略(除非有人可以建议另一种更新 MatView 中的行的方法,该方法不涉及运行看起来与原始查询非常相似的查询)
到目前为止,我已经在 Elasticache 实例上测试了 Redis,对其工作方式印象深刻,但我也被推荐查看 Nginx 和 Varnish 缓存策略。
我有点困惑哪种缓存策略最适合这种情况。与在 EC2 实例上实现 Nginx/Varnish 相比,Elasticache 实例上的 Redis/Memcached 是否有点过于重量级?在 Nginx 缓存中尝试缓存经常更改的数据是否被认为是一个坏主意?
最佳答案
粗略地说,您会使用像 Redis 或 Elasticache 这样的低级缓存来缓存原始数据(例如 SQL 查询的结果);而您将使用更高级别的缓存(如 Nginx 或 Varnish)来缓存显示数据的整个 HTML 页面。因此,哪个合适在某种程度上取决于您的用例。如果您有一个包含慢速数据的简单页面(或页面片段),并且该内容对所有用户显示相同,那么高级缓存可能是合适的。如果内容受到许多小的调整和重新格式化,这会使整个页面缓存非常零散,那么较低级别的缓存将是合适的。
实际上,这些技术并没有与高/低分离紧密相关:您可以将整个页面存储在 Redis 中,而将单个数据片段存储在 Varnish 中,所以并没有那么简单。但总的来说,在决定如何缓存它之前先决定要缓存什么。
即使您已经决定要缓存什么内容,选择正确的技术也将取决于很多考虑因素。 AWS 上的 Elasticache 具有完全托管的优势,因此可以节省您的维护费用,但运行成本可能最高(至少在小/中型规模上)。带有文件系统后端的 Nginx 缓存可能是最快和最便宜的实现方式,但不会很好地扩展(并且随着规模的增加重构会很尴尬)。 Varnish 和 Redis 可能最好作为单独的 EC2 实例实现,因此请介于两者之间。
关于postgresql - 经常更新的最佳缓存策略数据(Redis/Memcached vs Nginx/Varnish vs Materialized view),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52482719/
我一生都找不到有关 Varnish (版本 3)对象可能属性的任何文档。 我们知道(从谷歌搜索中,varnish 文档只是咕哝,让你更加沮丧)例如,请求对象具有 url 属性(req.url),并且它
我们公司最近决定开始使用 Varnish HTTP 加速器。我们选择这个解决方案的最重要原因是因为我们是一家专门构建网络商店的公司 (Magento Enterprise) => Magento 有一
我们最近将Varnish放在了Drupal的前面,因为服务器承受着沉重的负担,总体而言,我们感到非常满意。 剩下的唯一问题是,有时我们在缓存的数据中会有一个无限的重定向循环。我们通过HTTP监控发现了
我正在设置连接到2个后端服务器(Magento 2应用程序)的Varnish 5实例。 我正在使用新的Varnish 5功能来加载多个VCL文件。为了使事情现在变得非常简单,我将在示例中使用1个后端服
我有一台 Vanilla 的Debian DigitalOcean机器,我正在尝试遵循《 Varnish 书》中的“开发人员”类(class)。我必须the first exercise, Insta
我已经为我的网站配置了Varnish,并且由于网站性能出色,但是没有人知道有任何Varnish监视工具可以查看Varnish中存储的内容以及与Memcached或APC监视工具类似的东西。 谢谢, -
我正在寻找 Varnish 高可用性设置的最佳设置。 具有多个 Varnish 实例的标准设置,每个实例都有自己的缓存存储,因此每个实例都在后端执行自己的请求。 即使使用 Varnish_Storag
我已经经历了这个 article 。有人可以帮我澄清以下有关 Varnish 各种日志位置的疑问吗? 根据 varnish 电子书 varnishncsa -显示 Varnish 访问日志和 varn
在不停机的情况下以编程方式向 Varnish director 添加或删除单个后端服务器的最佳方法是什么?我一直在寻找这方面的一个很好的例子,但找不到。 我希望能够根据需要扩展和缩减我的后端服务器。
我已经安装了 Apache 和 Tomcat,想在它们前面安装 Varnish,静态到 Apache,动态到 Tomcat(所有/static/* url 到 Apache,应该由 Varnish 缓
我目前正在做一个基于 Varnish 的项目。 我们写 vcl和 vmod .但是项目需要检查请求体。 如何在 VCL 中获取帖子请求正文或 vmod与 C function ? 最佳答案 你几乎可以
我习惯跑 varnishadm -T localhost:6082 debug.health 检查后端健康状态,但如何详细检查探测失败的原因(例如超时、错误的 http 状态代码)? 最佳答案 在 V
我正在尝试设置我的第一个 Varnish 缓存服务器,我有几个问题想问任何有经验的人。 1.) 我将 Varnish 作为独立服务器运行。我还需要在同一台服务器上安装 Apache 吗?最终,Varn
抱歉,我是 Varnish 的新手。 我正在我的 /etc/varnish/mysite.vlc 中尝试一堆东西,但无法让它工作。 我想将特定网址重定向到另一个网址。例子:如果有人访问 http://
我有这个: if (bereq.http.X-Path ~ "[a-z0-9]+\.(js|css)$") { set beresp.http.Cache-Control =
我想将Varnish用作“智能”代理,并且几乎可以正常工作。这个想法是,某些请求应通过Varnish传递,到达后端并返回,所有其他请求应返回“synt”消息,表明特定响应不包含任何结果。 这与Varn
我们将Varnish Cache用作许多客户的前端,并在任何后端出现问题时通过宽限期处理过时的内容。 我们现在确实有一个失败的后端,并且我们想增加宽限期(在生病的时候),这可能吗?我尝试在文档中进行挖
我们想要建立一个 Varnish 级联,以便我们进行1级和2级缓存。这意味着应要求 -1级 Varnish 的工艺和路线 -通往的 Varnish 等级2 - 应用 问题:如果应用程序现在在内容中添加
我在vcl中使用循环导演。我想查看所有缓存未命中URL和后端IP。现在在做sudo varnishtop -i BereqURL它只显示网址而不是后端IP的去向 54.42 BereqURL
是否可以设置 Varnish 以定期重建整个 field ?我在 Varnish 后面有一个播放应用程序。该应用程序生成了超过2,000页的网站号,其中大多数是产品页。是否可以将Varnish设置为从
我是一名优秀的程序员,十分优秀!