gpt4 book ai didi

ruby-on-rails - 慢轨堆栈

转载 作者:行者123 更新时间:2023-12-02 07:20:49 25 4
gpt4 key购买 nike

当我运行时

rails server

rake -T

或者其他一些rails脚本,需要很多时间,大约1分钟。确定到底是什么如此慢的最佳方法是什么?如何提高速度?

Rails v 是 3.0.3,通过 ruby​​ 1.9.2 (RVM) - Linux 运行

最佳答案

这也困扰着我,因为我已经切换到 Rails 3。

关于你的第二个问题:通过深入研究框架,我发现初始化程序在实际开始执行其任务之前花费的时间大约是简单的 rake 或 Rails 调用的一半。

如果您将这些简单的时序线放入 $GEM_PATH/gems/railties-3.0.3/lib/rails/initialized.rb 中的初始化程序调用循环中(或者如果您喜欢):

def run_initializers(*args)
return if instance_variable_defined?(:@ran)
t0 = Time.now
initializers.tsort.each do |initializer|
t = Time.now
initializer.run(*args)
puts("%60s: %.3f sec" % [initializer.name, Time.now - t])
end
puts "%60s: %.3f sec" % ["for all", Time.now - t0]
@ran = true
end

编辑:或者,对于 Railties 4.2.1:

def run_initializers(group=:default, *args)
return if instance_variable_defined?(:@ran)
t0 = Time.now
initializers.tsort.each do |initializer|
t = Time.now
initializer.run(*args) if initializer.belongs_to?(group)
puts("%60s: %.3f sec" % [initializer.name, Time.now - t])
end
puts "%60s: %.3f sec" % ["for all", Time.now - t0]
@ran = true
end

...您可以跟进发生的情况。在我的系统(2.4 Core 2 Duo MacBook)上,初始化程序大约需要 7 秒。

有一些在我的系统上特别慢。当我在一秒内过滤掉所有内容时,我在系统上得到以下结果:

                load_active_support: 1.123 sec
active_support.initialize_time_zone: 1.579 sec
load_init_rb: 1.118 sec
set_routes_reloader: 1.291 sec

我确信有人(是我吗?)需要一些时间来开始并优化。

关于ruby-on-rails - 慢轨堆栈,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4461346/

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