【发布时间】:2012-09-18 20:08:44
【问题描述】:
我的 Rails 3.1 应用程序使用了一个引擎,我想知道对该引擎的访问是否是线程安全的。
我在引擎中有 /lib/mymodule.rb,它看起来像这样:
module MyModule
def self.my_method()
begin
data = WebResource.find(:all) # Where WebResource < ActiveResource::Base
rescue
data = nil
end
return data
end
end
然后在我的视图/控制器中,我这样调用这个方法:
MyModule::WebResource.headers[:some_id] = cookies[:some_id]
MyModule::my_method()
在我的主应用程序中,我有线程安全!配置选项集。我知道线程安全!启用后,每个控制器针对每个请求都存在于它自己的线程中。
但是,这个模块是线程安全的吗?我怀疑这个模块对于所有请求只有一个副本,所以它不是本质上是线程安全的,并且需要使用 Mutex 之类的手动同步。具体来说,我有代码为 ActiveResource 类 WebResource 的 HTTP 请求 outside 设置标头。这会导致线程问题吗?
【问题讨论】:
标签: ruby-on-rails ruby-on-rails-3 thread-safety rails-engines