【发布时间】:2012-06-28 06:49:51
【问题描述】:
在我的应用程序中,我的用户将对患者记录资源执行 CRUD 操作。通常,在创建患者记录后,它只会被用户读取。但是,在极少数情况下,两个(或更多)用户决定出于某种原因想要编辑该共享资源,解决此问题的最佳方法是什么?
我一直在阅读有关乐观和悲观锁定的文章,但我仍然不清楚这是否仅适用于更新操作,还是每次有人尝试读取资源时都会发生锁定?
我在想的是,是否有一种方法可以在 rails 中查看两个或多个用户何时在同一页面上,从而通知第二个用户进入编辑页面另一个用户已经在使用该资源,并且因此,只需等待第一个用户完成后再继续。
你会如何处理这个问题?谢谢!
【问题讨论】:
-
您没有提及您的数据库,但对于 postgresql:“行级锁不影响数据查询;它们仅阻止同一行的写入者。”
-
乐观锁和悲观锁都这样吗?
-
是的。但请注意,读取锁定的记录可能会产生误导,因为用户可能正在读取锁定释放后随后由另一个用户更改的数据。 Postgresql 具有“可重复读取”的概念来防止这种情况发生,但是您将编写纯 sql 来完成此操作,因为我不确定 ActiveRecord 是否支持 postgresql。开发符合并发标准的数据库应用程序并非易事。
标签: ruby-on-rails-3 concurrency locking multi-user