ruby-on-rails – 使用Rails和Postgres,数据库锁不能正常工作

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – 使用Rails和Postgres,数据库锁不能正常工作前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在rails模型中有以下代码
foo = Food.find(...)
foo.with_lock do
  if bar = foo.bars.find_by_stuff(stuff)
    # do something with bar
  else
    bar = foo.bars.create!
    # do something with bar
  end
end

目标是确保创建的类型的Bar不会被创建两次.

在控制台上测试with_lock确认了我的期望.但是,在生产中,似乎在某些或所有情况下,锁未按预期工作,并且正在尝试使用冗余Bar – 因此,with_lock不会(总是?)导致代码等待轮到.

这可能会发生什么?

更新
很抱歉所有说“锁定foo不会帮助你”的人!我的例子最初没有查找条形码.这是现在修复的.

解决方法

锁定在查询缓存中的Rails应用程序中无法正常工作的原因.

如果您尝试在单个请求中多次在同一行上获取独占锁,则查询缓存会启动,因此后续锁定查询永远不会到达数据库本身.

在Github上The issue has been reported.

猜你在找的Ruby相关文章