草庐IT

Redis过期策略和内存淘汰机制

全部标签

ruby - 方法调用中是否有内存约定?

我想避免在方法调用中重新计算一个值。到目前为止,我一直在这样做:defsome_method@some_method||=begin#lot'sofcodeendend但它最终变得非常丑陋。在一些代码中,我看到了如下内容:defsome_method@some_method||=some_method!endprivatedefsome_method!#lot'sofcodeend我不喜欢最后的爆炸(!),所以我想到了这个:defsome_method@some_method||=_some_methodendprivatedef_some_method#lot'sofcodeend在

ruby - 如何在 Ruby 中内存可能返回 true、false 或 nil 的方法?

显然||=不会起作用defx?@x_query||=expensive_way_to_calculate_xend因为如果结果为false或nil,那么expensive_way_to_calculate_x将被反复运行。目前我知道的最好方法是将值放入数组:defx?return@x_query.firstif@x_query.is_a?(Array)@x_query=[expensive_way_to_calculate_x]@x_query.firstend是否有更传统或更有效的方法来做到这一点?更新我意识到除了false之外,我还想记住nil-这一直追溯到https://rail

ruby-on-rails - 我怎样才能找到 Heroku 上的内存泄漏?

我有一个Rails3.2.8应用程序在HerokuCedar上运行,使用Ruby1.9.3。该应用程序启动时运行良好,但在连续使用一天左右后,我开始在我的日志中看到R14错误。一旦出现内存错误,它们就永远不会消失,即使应用闲置几个小时也是如此。垃圾收集器不应该过一段时间就清理不用的对象,减少内存负载吗?这似乎在Heroku上没有发生。通常,在运行一些包含几千行数据的报告后,内存使用量开始逐渐增加,尽管结果是分页的。如何找到内存泄漏?像bleak_house这样的插件已经过时或不能在Heroku环境中正常运行。我可以调整GC设置以使其更具攻击性吗? 最佳答案

ruby-on-rails - 找到Ruby on Rails内存泄漏的任何好方法吗?

我的项目正在发生内存泄漏,部署后,它的内存在10分钟内从500MB增加到1800MB。我试过很多工具,但没有一个是好用的。我使用了jprofiler,它显示了调用堆栈,内存分配,哪个类/方法被调用过多…以图表的形式,非常容易阅读和分析。我真的很喜欢这个。这样地:像这样:我已经找到这个工具:https://github.com/tenderlove/heap-analyzer,但我还没有使用。那么,有什么好的方法/工具可以找到ruby/rails内存泄漏吗?我试过mini_profiler,但没有达到预期的效果。谢谢! 最佳答案 您还

ruby-on-rails - 如何使控制台中的 View 缓存片段过期?

有点像Rails.cache.delete('site_search_form')好像不行。这可能吗?谢谢。 最佳答案 ActionController::Base.new.expire_fragment(key) 关于ruby-on-rails-如何使控制台中的View缓存片段过期?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/756888/

ruby-on-rails - 为什么 ruby​​ 中的内存分析如此困难?

或者更确切地说,为什么没有更好的工具来分析ruby​​中的内存,特别是Rails应用程序?最近,我们的Rails应用程序(托管在heroku上)开始在workerdynos中发现大量R14错误。这意味着我们的内存不足。将测功机提高到2倍(512mb->1GB)只能暂时缓解问题,让我相信某处存在内存泄漏。自然地,我的下一步是找到一个可以帮助我发现泄漏源的良好分析工具。也许我只是不知道可用的工具,或者我只是不知道如何使用我拥有的工具。我的愿望是我可以安装一个gem,然后运行关于内存使用统计的报告。由于我的内存问题与运行延迟作业的workerdynos隔离,因此点击端点获取报告并不可行。我看

ruby - 为什么这个 Ruby 程序不将堆内存返回给操作系统?

我试图了解从Ruby堆分配的内存何时返回给操作系统。我知道Ruby永远不会返回分配给它的堆内存,但我仍然不确定堆外内存的行为。即那些不适合40字节RVALUE的对象。考虑以下分配一些大字符串然后强制进行主要GC的程序。require'objspace'STRING_SIZE=250defprint_stats(msg)puts'-------------------'putsmsgputs'-------------------'puts"RSS:#{`ps-eorss,pid|grep#{Process.pid}|grep-vgrep|awk'{print$1,"KB";}'`}"p

ruby-on-rails - has_many 同时尊重 factory_girl 中的构建策略

情况#ModelsclassUser:user)do|u|u.items{|items|[items.association(:item),items.association(:item)]}endFactory.define(:item)do|i|i.color"red"endFactory.define(:item_with_user,:parent=>:user)do|i|i.association(:user)end问题如果您运行@user=Factory(:user_with_items),则@user.items包含这两个项目。问题是这些项目未与数据库中的用户相关联。如果你

ruby-on-rails - 覆盖 database.yml 的策略?

在我的环境中,部署服务器具有database.yml中的大部分连接信息。即他们知道自己是开发、测试还是生产服务器,知道各自的数据库连接信息。例如,我可以将此信息封装在一个服务器类中,以便我可以检索信息:Server["environment"]#=>productionServer["db_host"]#=>db5.example.comServer["db_password"]#=>[adecryptedpassword]等等。我想部署一个Rails应用程序并让它根据服务器设置自动配置。执行此操作的最佳方法是什么?一种方法是在我的database.yml中使用Erb::adapter

ruby-on-rails - 何时在 Ruby on Rails 中使用内存

2008年7月中旬,Memoization被添加到Rails核心。用法演示是here.关于何时应该内存方法,以及每个方法的性能影响,我还没有找到任何好的例子。Thisblogpost,例如,建议通常根本不应该使用内存。对于可能具有巨大性能影响的内容,除了提供简单教程之外似乎没有其他资源。有没有人见过在自己的项目中使用memoization?哪些因素会让您考虑内存方法?在我自己做了更多研究之后,我发现在Rails核心中使用记忆化的次数非常多。这是一个例子:http://github.com/rails/rails/blob/1182658e767d2db4a46faed35f0b1075