Rails时间戳不使用正确的时区

Max*_*ams 14 timezone datetime ruby-on-rails

我对rails中的时区感到有点困惑.我希望我的rails应用程序在我的模型中的updated_at和created_at中设置的时间戳使用英国夏令时(如美国的夏令时).我改变了我的环境.rb说

  config.time_zone = 'London'
Run Code Online (Sandbox Code Playgroud)

我的应用程序所在的ubuntu服务器似乎在时间上使用BST:例如,在命令行中,如果我输入'date',我会得到当前时间(不是一小时的偏移量).在rails控制台中,我看到以下内容:

>> time = Time.now
=> Wed Oct 27 16:29:17 +0100 2010
>> time.zone
=> "BST"
Run Code Online (Sandbox Code Playgroud)

一切都很好.但是,如果我创建一个新的AR模型对象并保存它,时间戳是从一小时前开始的.所以,看起来这是使用UTC.现在,我可以看到这里的逻辑:由于时间戳可能在模型逻辑中使用,您希望它们基于不变的尺度时间,即UTC.但是,这是一个奇怪的行为,我不明白:

#change a record and save it
>> someobj.save
=> true
#object's updated_at is one hour ago
>> someobj.updated_at
=> Wed, 27 Oct 2010 15:34:22 UTC +00:00
>> Time.now
=> Wed Oct 27 16:34:31 +0100 2010
#however, Time.now - object's updated at is just a few seconds.
>> Time.now - someobj.updated_at
=> 15.305549
Run Code Online (Sandbox Code Playgroud)

因此,在进行减法之前,updated_at将转换为当前时区.

我想在当前时区显示日期的原因仅在于视图中的状态报告等:如果有人更新某些内容,我希望他们看到它在1分钟前更新,而不是"一小时前".

谁能让我不相信?干杯,最大

编辑:通过使用调整时区的'time_ago_in_words'帮助程序解决了我在状态中显示正确时间的直接问题.我仍然希望有人来解释时间戳发生了什么:)

tad*_*man 40

默认情况下,时间戳以UTC格式存储,这可能是最好的方法.如果您从一个服务器环境移动到另一个服务器环境,您不希望所有时间都因为您切换时区而转移.

如果您想知道当地时区的时间戳,您只需要这样询问:

someobj.updated_at.localtime
Run Code Online (Sandbox Code Playgroud)