我安装了rvm(ruby版本管理器)并且成功了,但是我得到了WARNING:Youhave'~/.profile'file,youmightwanttoloadit,todothataddthefollowinglineto'/Users/myname/.bash_profile':source~/.profile我是开发、终端和所有爵士乐的新手!但迟到总比不到好?!我进入了终端:'/Users/myname/.bash_profile'然后得到下面一行-bash:/Users/myname/.bash_profile:Permissiondeniedmyname-MacBook-Pr
我正在寻找一些与1.9.3兼容的工具,这些工具可以为我提供一些关于Rails程序在开发中使用的内存的真实世界使用数据。在一个完美的世界中,它将能够按类分解内存使用情况,或者以某种方式告诉我们可以调整哪些内容。请仅在您使用过并认可该工具的情况下推荐该工具。 最佳答案 我在ruby-prof上取得了成功.它有多种获取配置文件数据的方法,并提供大量信息,一开始可能有点让人不知所措。它确实为我解决了一个问题,并帮助我消除了我正在处理的事情的主要瓶颈(我从一个方法内部调用require,该方法在一个紧密的循环中被调用......紧缩!).
在观看了railscast(http://railscasts.com/episodes/368-miniprofiler)之后,我正在使用rack-mini-profiler。我将它添加到我的Gemfile中:gem'rack-mini-profiler'使用bundler安装它并使用“railss”启动我的开发环境。分析工作正常,它显示在网页的左上角,但它恰好分析了所有静态文件(js、css、图像等)。它似乎也有10行的限制,因此隐藏了实际请求。是否可以配置它以避免分析静态文件? 最佳答案 好的,这是我的做法:使用了0.0.18
我想弄清楚分析Sinatra应用程序的最佳方法是什么。我想要一个解决方案,它可以为我提供路径中所有方法的时间概况,包括haml的呈现。有人介绍过Sinatra应用程序吗?有什么指点吗? 最佳答案 这是一种有效的技术,不确定它是否是最好的。require'sinatra'require'profiler'get'/'doProfiler__.start_profiledo_it_fastdo_it_slowdo_it_fastProfiler__.stop_profileProfiler__.print_profile(STDOUT)
我使用多个Rails应用程序,一些在Rails3.2/Ruby2.0上,一些在Rails2.3/Ruby1.8.7上。他们的共同点是,随着他们的成长和添加更多的依赖项/gem,他们需要越来越长的时间来启动。开发、测试、生产、控制台,无所谓;有些需要60多秒。首先分析导致加载时间如此缓慢的原因,其次改善加载时间的首选方法是什么? 最佳答案 有几种情况会导致这种情况。过多的GC遍数和一般的VM缺点-请参阅thisanswer以获得全面的解释。Ruby许多遗留gem必须迭代才能加载文件。如果您使用的是bundler,请尝试bundlecl
我需要分析通常使用bundleexecrspecspec/运行的测试套件并生成GIF图像。运行perftools.rb的命令是什么?以便它与bundler一起正常工作? 最佳答案 我也不得不四处挖掘才能得到这个。这是我做的将其放入spec_helper.rb:config.before:suitedoPerfTools::CpuProfiler.start("/tmp/rspec_profile")endconfig.after:suitedoPerfTools::CpuProfiler.stopend运行你的rspec运行ppro
除了ruby-prof和核心Benchmark类,您还使用什么来分析您的Ruby代码?特别是,您如何找到代码中的瓶颈?几乎感觉我需要使用自己的小工具来弄清楚所有时间都花在了我的代码中。我知道ruby-prof提供了这个,但坦率地说,输出非常困惑,并且不容易找出您自己代码的哪些实际block是问题的根源(它告诉您调用了哪些方法虽然是最多的时间)。所以我并没有真正从中得到我想要的那么多,也没有真正能够利用它。也许我做错了?有其他选择吗?Google搜索没有为我带来任何结果。 最佳答案 要真正深入研究您的代码,请尝试stackpr
我正在研究不同的优化技术,我发现了这篇文章AnalyzingCodeforEfficiency?相信对调用堆栈进行采样比使用分析器更有效的人。基本思想是,如果您查看调用堆栈,您会看到您的应用程序最有可能花费大部分时间的地方,然后在那里进行优化。这当然很有趣,而且他显然是这方面的专家,但我不知道如何在ruby中查看调用堆栈。在调试器中,我可以说“信息堆栈”,但似乎只显示一行。编辑:我看到MikeDunlavey的评论:“我只想指出,如果你在调试器下运行,手动中断它,并显示调用堆栈......”我只是不确定如何手动中断它并隐藏调用堆栈。 最佳答案
关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于StackOverflow来说是偏离主题的,因为它们往往会吸引自以为是的答案和垃圾邮件。相反,describetheproblem以及迄今为止为解决该问题所做的工作。关闭9年前。Improvethisquestion我一直在寻找Rails的分析工具。我目前正在玩和测试ruby-prof和railsbench,但我对要使它们正常工作所需的大量调整和修改感到有点沮丧。虽然我不介意(太多)调整,但我想知道是否有其他更直接、更易于使用的工具来分析Rai
我在我的一个程序中运行了ruby-profiler。我试图弄清楚每个字段的含义。我猜一切都是CPU时间(而不是挂钟时间),这太棒了。我想了解“---”代表什么。那里有某种堆栈信息吗?调用a/b是什么意思?ThreadID:81980260TotalTime:0.28%total%selftotalselfwaitchildcallsName--------------------------------------------------------------------------------0.280.000.000.285/6FrameParser#receive_data