如何使用ActiveRecord 3.1无需停机时删除列?

时间:2012-09-20 17:59:03

标签: ruby-on-rails ruby ruby-on-rails-3 activerecord

使用ActiveRecord运行应用程序时从表中删除列会导致错误,因为ActiveRecord会缓存列名称。

其他版本的ActiveRecord的解决方法是覆盖模型中的#columns方法,并在迁移之前过滤掉已弃用的列名称(基本上 - 从AR隐藏这些列)。这很有效,因为所有与列名相关的方法都基于#columns调用

在ActiveRecord 3.1中,表结构的缓存被移动到ConnectionPool,所有与列名相关的值(例如coluumns_hash)都被独立缓存(3.2使用ModelSchema.columns使其再次工作)

ActiveRecord 3.1中是否有任何方法(除了深入破解具体适配器)以实现安全的列丢失?

2 个答案:

答案 0 :(得分:3)

TST Media的Luke Ludwig提供了一个解决方案here。基本上它们“覆盖正在删除其列的类的ActiveRecord :: Base.columns方法。”

(适用于3.1以外的所有解决方案)

答案 1 :(得分:1)

如果您有多个应用程序服务器,以便您可以一次停用一个服务器而不停机,则以下内容将起作用:

  1. 删除用户修改要删除的列的功能。
  2. 一次重启一个应用程序。
  3. 启动一个新数据库,该数据库是现有数据库的主 - 主。
  4. 停止从新数据库复制。
  5. 将列放在新数据库服务器上。
  6. 一次一个地重新配置每个应用程序服务器以使用新的数据库服务器并重新启动。
  7. 重新启用新数据库的复制。
  8. 原始服务器恢复后,重新配置应用程序以再次使用该数据库服务器(适用的重新启动)。
  9. 停止复制并关闭新数据库服务器。