开发者社区> 问答> 正文

在gem / submodule中使用capistrano运行`rails db:migrate`

我有一个rails 5.2 app。我正在尝试使用Capistrano进行部署。

该应用程序有一个gem依赖子模块,其中包含此项目所需的所有模型和迁移。这个子模块取决于其中的其他ruby.gemspec。

因此,我需要rails db:migrate在子模块根目录中运行,而不是父项目根目录。

我已将以下内容添加到deploy.rb:

desc 'Runs rake db:migrate if migrations are set'
task :migrate => [:set_rails_env] do

on primary fetch(:migration_role) do
  within "#{release_path}/PATH/TO/SUBMODULE" do
    with rails_env: fetch(:rails_env) do
      execute :rake, "db:migrate"
    end
  end
end

end

before :starting, :migrate
的Gemfile:

gem 'dependency', path: 'PATH/TO/SUBMODULE'
gem 'capistrano-git-with-submodules', '~> 2.0'
group :development do
gem 'capistrano', require: false
gem 'capistrano-rvm', require: false
gem 'capistrano-rails', require: false
gem 'capistrano-bundler', require: false
gem 'capistrano3-puma', require: false
end
当我尝试运行此任务时,收到一条错误消息:

DEBUG [b4c1cf18] [31mCould not find aasm-5.0.2 in any of the sources[0m
DEBUG [b4c1cf18]
DEBUG [b4c1cf18] [33mRun bundle install to install missing gems.[0m
DEBUG [b4c1cf18]
在部署父项目时使用的gem集(包含所有父模块和子模块gems)似乎不在路径中,或者在运行此任务时不可用。

我可以在没有迁移的情况下运行父项目,因此我知道父项目正在运行时加载所有正确的gem集。只是没有在这个任务期间。

我不太确定Capistrano是如何工作的,我怎么能确保ruby在运行时可用于此任务?

展开
收起
小六码奴 2019-04-09 17:11:25 2843 0
1 条回答
写回答
取消 提交回答
  • 需要3件事:

    1. execute :bundle前execute :rake, :"db:migrate"

    提供第二个参数来within "#{release_path}/PATH/TO/SUBMODULE"制作它within "#{release_path}/PATH/TO/SUBMODULE", release_path- 无法找到关于此的文档,只有这个PR:https://github.com/capistrano/bundler/pull/84

    符号链接秘密引擎,因此它不会阻止任何任务运行:

    task :symlink_secrets do
        on roles(:app) do
          execute "rm -rf #{release_path}/PATH/TO/SUBMODULE/spec/dummy/config/secrets.yml"
          execute "ln -nfs ~/secrets.yml #{release_path}/PATH/TO/SUBMODULE/spec/dummy/config/secrets.yml"
        end 
    end
    2019-07-17 23:33:01
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
Borgaonkar-New-Adventures-In-Spying-3G-And-4G-Users-Locate-Track-And-Monitor 立即下载
Three steps to clustering your MySQL Environment——MNC、MGC与MIC 立即下载
Monitoring the Dynamic Resource Usage of Scala and Python Spark Jobs in Yarn 立即下载