Mina: Sem cache para empacotador

Criado em 24 set. 2016  ·  3Comentários  ·  Fonte: mina-deploy/mina

Estou usando este script (ele é atualizado do mina 0.3)

require 'mina/bundler'
require 'mina/rails'
require 'mina/git'
require 'mina/rbenv'

set :shared_dirs, %w(log public/uploads node_modules)
set :current_path, 'current'
set :term_mode, nil

task :environment do
  invoke :'rbenv:load'
end

task setup: :environment do
  command %[mkdir -p "#{fetch(:shared_path)}/log"]
  command %[chmod g+rx,u+rwx "#{fetch(:shared_path)}/log"]

  command %[mkdir -p "#{fetch(:shared_path)}/public/uploads"]
  command %[chmod g+rx,u+rwx "#{fetch(:shared_path)}/public/uploads"]
  command %[mkdir -p "#{fetch(:shared_path)}/node_modules"]
  command %[chmod g+rx,u+rwx "#{fetch(:shared_path)}/node_modules"]
end

desc 'Deploys the current version to the server.'
task deploy: :environment do
  deploy do
    invoke :'git:clone'
    invoke :'deploy:link_shared_paths'
    invoke :'bundle:install'
    invoke :'rails:db_migrate'
    invoke :'npm_install'
    invoke :'rails:assets_precompile'
    invoke :'deploy:cleanup'

    on :launch do
      command "mkdir -p #{fetch(:current_path)}/tmp/"
      command "touch #{fetch(:current_path)}/tmp/restart.txt"
    end
  end
end

task :restart do
  command "touch #{fetch(:current_path)}/tmp/restart.txt"
end

task :logs do
  command 'echo "Contents of the log file are as follows:"'
  command "tail -f #{fetch(:current_path)}/log/#{fetch(:rails_env)}.log"
end

task :npm_install do
  command 'npm install --production'
end

O problema é - bundle install está baixando todas as joias do zero sempre que a implantação é concluída. Estava funcionando bem na versão 0.3.

Alguma ideia do que estou fazendo de errado?

Comentários muito úteis

Ok, descobri o que era um problema. Na versão 1, precisamos anexar a shared_dirs em vez de criar a tabela inteira. Então eu fiz:

set :shared_dirs, fetch(:shared_dirs, []).push('log').push('public/uploads').push('node_modules')

e está funcionando agora

Todos 3 comentários

Ok, descobri o que era um problema. Na versão 1, precisamos anexar a shared_dirs em vez de criar a tabela inteira. Então eu fiz:

set :shared_dirs, fetch(:shared_dirs, []).push('log').push('public/uploads').push('node_modules')

e está funcionando agora

Obrigado! Eu estava tendo o mesmo problema!

Não pretendo seguir um tópico fechado, mas você também pode fazer algo assim:

shared_dires = %w{log public/uploads node_modules}
set :shared_dirs, fetch(:shared_dirs, []).push(*shared_dirs)
Esta página foi útil?
0 / 5 - 0 avaliações