为了防止在我们迁移到生产站点期间出现数据库事务错误,我们遵循了
https://github.com/LendingHome/zero_downtime_migrations中概述的建议(特别是
https://robots.thoughtbot.com/how-to-create-postgres-indexes-concurrently-in概述),但是在特别大的表上创建索引时,甚至是索引的“并发”方法创建锁定了表并导致任何ActiveRecord在该表上创建或更新导致其各自的事务因PG :: InFailedsqlTransaction异常而失败.
以下是迁移看起来像我们正在运行Rails 4.2(使用ActiveRecord 4.2.7.1):
class AddTypeIndexToModel < ActiveRecord::Migration disable_ddl_transaction! def change add_index :model,:model_type_id,algorithm: :concurrently end end
解决方法
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。