mysql - Capistrano "cap deploy:migrations"失败,因为它尝试运行所有迁移,而不仅仅是挂起的迁移

标签 mysql ruby-on-rails ruby-on-rails-3 capistrano mysql2

我尝试使用“cap deploy:migrations”进行部署,因为我有 3 个新的迁移需要在实时服务器上执行。结果是:

executing "cd /home/martin/public_html/project/releases/20110905131238; bundle exec rake RAILS_ENV=production  db:migrate"
    servers: ["50.56.82.190"]
    [50.56.82.190] executing command
 ** [out :: 50.56.82.190] ==  CreateUsers: migrating ====================================================
 ** [out :: 50.56.82.190] -- create_table(:users)
 ** [out :: 50.56.82.190] rake aborted!
 ** [out :: 50.56.82.190] An error has occurred, all later migrations canceled:
 ** [out :: 50.56.82.190] 
 ** [out :: 50.56.82.190] Mysql2::Error: Table 'users' already exists: CREATE TABLE `users` (`id` int(11) DEFAULT NULL auto_increment PRIMARY KEY, `name` varchar(255), `email` varchar(255), `created_at` datetime, `updated_at` datetime) ENGINE=InnoDB
 ** [out :: 50.56.82.190] 
 ** [out :: 50.56.82.190] Tasks: TOP => db:migrate
 ** [out :: 50.56.82.190] (See full trace by running task with --trace)
    command finished in 5816ms
failed: "sh -c 'cd /home/martin/public_html/project/releases/20110905131238; bundle exec rake RAILS_ENV=production  db:migrate'" on 50.56.82.190

通过之前的部署,我在实时服务器上创建了一个工作数据库。我创建了 3 个新的迁移(由于使用新的 gems carrierwave 和 rmagick 上传图像),我现在想部署它们。显然 cap deploy:migrations 尝试从第一个开始运行所有迁移,而不仅仅是挂起的迁移。

我的 deploy.rb 是:

require 'bundler/capistrano'
set :application, "otg.in"
set :domain, "otg.in"
set :user, "martin"
set :sudo_use, false
set :repository, "git@github.com:Martin118/otg.in.git"
set :local_repository,  '~/rails_projects/otg.in/.git'
set :port, 48000
set :deploy_to, "/home/martin/public_html/#{application}"
set :scm, :git
set :branch, "master"
default_run_options[:pty] = true
ssh_options[:forward_agent] = true

server "50.56.82.190", :app, :web, :db, :primary => true

after "deploy", "deploy:bundle_gems"
after "deploy:bundle_gems", "deploy:restart"
after "deploy:update_code", "deploy:migrate"
after "deploy", "deploy:cleanup"

# Passenger
namespace :deploy do
     task :bundle_gems do
    run "cd #{deploy_to}/current && bundle install vendor/gems"
  end
  task :start do ; end
  task :stop do ; end
  task :restart, :roles => :app, :except => { :no_release => true } do
    run "#{try_sudo} touch #{File.join(current_path,'tmp','restart.txt')}"
  end
end

require 'whenever/capistrano'

我运行 rails 3.0.8,cap deploy:check 给我“你似乎安装了所有必要的依赖项”。

有什么想法吗?或者您需要更多信息?

感谢您的帮助!

现场的 schema.rb 是:

ActiveRecord::Schema.define(:version => 20110130000344) do

  create_table "businesses", :force => true do |t|
    t.string   "business_name"
    t.string   "postal_code"
    t.string   "business_email"
    t.string   "phone"
    t.string   "fax"
    t.string   "web"
    t.text     "description"
    t.datetime "created_at"
    t.datetime "updated_at"
    t.integer  "user_id"
    t.text     "address"
    t.integer  "city_id"
    t.integer  "state_id"
  end

  create_table "cities", :force => true do |t|
    t.string   "name"
    t.datetime "created_at"
    t.datetime "updated_at"
    t.integer  "state_id"
  end

  create_table "states", :force => true do |t|
    t.datetime "created_at"
    t.datetime "updated_at"
    t.string   "name"
  end

  create_table "users", :force => true do |t|
    t.string   "name"
    t.string   "email"
    t.datetime "created_at"
    t.datetime "updated_at"
    t.string   "encrypted_password"
    t.string   "salt"
    t.boolean  "admin",              :default => false
  end

  add_index "users", ["email"], :name => "index_users_on_email", :unique => true

end

另一个更新:select * from schema_migrations;在我的开发数据库上给我:

+----------------+ |版本 | +----------------+ | 20110112163009 | | 20110113141953 | | 20110113192958 | | 20110114214158 | | 20110115002206 | | 20110119100832 | | 20110120134443 | | 20110127171331 | | 20110127171427 | | 20110127171921 | | 20110127172903 | | 20110127183252 | | 20110129201949 | | 20110129204159 | | 20110129205833 | | 20110130000344 | | 20110808142844 | | 20110809133339 | | 20110809142303 | | 20110809154349 | | 20110810092306 | | 20110810093531 | | 20110812085010 | +----------------+

但是用我得到的 MySQL workbench 检查这个(仍然是开发数据库):

错误:project_developmentschema_migrations:表数据不可编辑,因为没有为表定义主键

另外,生产数据库上的 select * from schema_migrations 只给我一个迁移(我尝试更新之前的最后一个迁移):

+----------------+ |版本 | +----------------+ | 0 | | 20110130000344 | +----------------+

有人知道这里发生了什么吗?

谢谢!

最佳答案

解决方案是手动将缺失的迁移添加到 schema_migrations 中。不知何故,这张表似乎丢失了一些数据。无论如何,通过添加已经使用“INSERT into schema_migrations (version) values ('2011....');”直接完成的迁移,然后 cap deploy:migrations 从新的开始顺利运行。

关于mysql - Capistrano "cap deploy:migrations"失败,因为它尝试运行所有迁移,而不仅仅是挂起的迁移,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7309774/

相关文章:

ruby-on-rails - 如何实现对对象属性执行 "directly"的方法?

ruby-on-rails - 如何对使用 attr_encrypted gem 加密的字段进行排序

ruby-on-rails - 在 rails 中使用命名空间时使用双 Controller ?

ruby-on-rails-3 - Rails 3.1 中带有时区的选择框

INSERT INTO 语句中的 PHP 语法错误。SQLExecDirect 中的 SQL 状态 37000

mysql - 如何将两个查询转换为 INT 并比较它们?

mysql 不想要变量分配后的结果

php - MySQL - mysql_fetch_assoc() 不给出一列

sql - rails 3 : Can't create relationship :has_one

ruby-on-rails - 在 Rails 3 中,如何在请求/响应周期完成后通过 Controller 调用一些代码?