草庐IT

performance

全部标签

ruby-on-rails - 如何在 Ruby on Rails 中启用压缩?

我在这里发了一个类似的问题ServingCompressedAssetsinHerokuwithRack-Zippy但决定放弃该服务,因为我无法让它工作。我在我的网站上运行了PageSpeedInsights以确定网站的速度。我收到的最重要的建议是启用压缩。Compressingresourceswithgzipordeflatecanreducethenumberofbytessentoverthenetwork.Enablecompressionforthefollowingresourcestoreducetheirtransfersizeby191.2KiB(74%reduct

ruby - 为什么 Ruby 方法调用特别慢(与其他语言相比)?

我正在尝试阅读有关Ruby性能的信息,并遇到了thisSOthread,其中一个答案提到“方法调用,Ruby中最常见的操作之一,特别慢。”Anotherthread提到“它对方法进行“后期查找”,以提供灵active。这会减慢它的速度。它还必须记住每个上下文的名称以允许eval,因此它的框架和方法调用速度较慢。”有人可以更详细地解释为什么Ruby方法调用特别慢,并详细说明第二个线程吗?我不完全确定延迟查找是什么或为什么它很慢,而且我不知道每个上下文的名称是什么意思或它与框架和方法调用的关系。我(可能不正确)的理解是,由于可以在运行时添加或修改方法,Ruby解释器永远不会“记住”如何运行

Ruby Array concat 与 + 速度?

我对Ruby的数组concat()与+操作进行了小型性能测试,concat()速度太快了。但是我不清楚为什么concat()这么快?有人可以帮忙吗?这是我使用的代码:t=Time.nowar=[]foriin1..10000ar=ar+[4,5]endputs"Timefor+"+(Time.now-t).to_st=Time.nowar=[]foriin1..10000ar.concat([4,5])endputs"Timeforconcat"+(Time.now-t).to_s 最佳答案 根据Rubydocs,不同之处在于:数组

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

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

ruby-on-rails - 哪个更快 : MRI Ruby or JRuby?

如果我使用RubyonRails,我应该安装MRI/YARVRuby还是JRuby?哪个更快? 最佳答案 最近的基准测试将JRuby置于领先地位,其次是MagLev、Rubinius,然后是MRI。基准测试很棘手。RubyBenchmarkSuite最常用于对Ruby进行基准测试。如果您删除任何实现失败的基准测试,您将得到下图。请注意,我使用的是几何平均数。这是一个更好的平均性能指标,因为它规范了异常值和机器规范。您可以运行的最佳基准将特定于您的应用。如果您正在寻找整体性能,您可能希望使用真正的线程,因此Rubinius或JRuby

ruby-on-rails - 如何调试慢速 Rails 应用程序启动时间?

我们的Rails应用程序在加载后速度很快,但启动速度非常慢。控制台、乘客等都需要将近10秒才能启动。似乎比应该的要长得多。我应该使用什么工具或方法来磨练最慢的部分?通常的嫌疑人是什么? 最佳答案 我知道这是一个老问题,但我最近遇到了加载时间的问题,这是我的gem分支,它帮助我找到了最慢的gem,这个gem的好处是它可以通过Rails控制台加载,并运行所有初始化程序。https://github.com/mark-ellul/Bumbler 关于ruby-on-rails-如何调试慢速Ra

Ruby 基准测试模块 : meanings of "user", "system"和 "real"?

试验Ruby的基准模块...>>Benchmark.bm(7){|b|b.report('Report:'){s='';10000.times{s+='a'}}}usersystemtotalrealReport:0.1500000.0100000.160000(0.156361)“用户”、“系统”、“真实”的含义是什么? 最佳答案 这些时间与Unixtime命令或其他典型基准测试工具报告的时间相同:user:执行用户空间代码(即:您的代码)所花费的时间,system:执行内核代码所花费的时间和真实:执行代码所花费的“真实”时间(即

ruby-on-rails - Rails 开发服务器很慢,需要很长时间才能加载一个简单的页面

关于Rails在开发模式下运行缓慢的类似帖子也有,但这些帖子中的解决方案都没有对我产生任何影响。我试过安装可以提高性能的gem并修改配置文件,但都没有成功。我刚开始使用Rails,所以我正在运行“Rails入门”指南中的启动应用程序,这是一个小博客。我已经按照推荐安装了Ruby1.9.3和Rails3.2.13。我在OS/X10.7.5上运行。当加载教程应用的起始页时,实际上只有1行文本和1个链接,需要20-40秒。对任何页面的每个后续请求都需要20-40秒。然而,当我查看服务器日志时,Rails所做的任何事情似乎都不会花费很长时间。日志中的事件之间的时间一直在占用。作为Rails的初

ruby - Ruby 2.0 中的垃圾收集器调整

我想知道用于ruby​​1.9.x的GC调优在2.0中是否仍然与GC的新实现相关。如果是这样,我们可以在新版本上配置什么新东西吗?我说的是以下设置RUBY_HEAP_MIN_SLOTS=600000RUBY_GC_MALLOC_LIMIT=59000000RUBY_HEAP_FREE_MIN=100000 最佳答案 这些GC调优参数有些困惑。REE(它是Ruby1.8.7的一个分支)introduceditsownparametersfirst,后来Ruby(从1.9.2开始)引入了它自己的(类似的)参数。Ruby1.9.3使它们可

ruby - Ruby 中数组和哈希的性能

我有一个程序可以存储一个类的多个实例,比如说多达10,000个或更多。类实例有几个我不时需要的属性,但其中最重要的一个是ID。classDocumentattr_accessor:iddef==(document)document.id==self.idendend现在,存储数千个此类对象的最快方法是什么?我曾经将它们全部放入一个文档数组中:documents=Array.newdocuments现在另一种方法是将它们存储在哈希中:documents=Hash.newdoc=Document.newdocuments[doc.id]=doc#etc在我的应用程序中,我主要需要查明文档是