加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – Rails add_index算法::在迁移过程中,同时仍导

发布时间:2020-12-17 02:10:00 所属栏目:百科 来源:网络整理
导读:为了防止在我们迁移到生产站点期间出现数据库事务错误,我们遵循了 https://github.com/LendingHome/zero_downtime_migrations中概述的建议(特别是 https://robots.thoughtbot.com/how-to-create-postgres-indexes-concurrently-in概述),但是在特别大的表上创
为了防止在我们迁移到生产站点期间出现数据库事务错误,我们遵循了 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

解决方法

事实证明,该问题与该迁移无关,但之前的一个问题是在向同一个表中添加新列的同一批次中运行.

因为我们在表中添加了一个列,所以我们在Active Record https://github.com/rails/rails/issues/12330中遇到了这个错误,这实际上导致事务中的所有ActiveRecord操作由于过时的PreparedStatement而失败,直到服务器重新启动.

从现在开始,我们将在迁移中使用该问题中描述的变通方法.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读