Cómo implementar carriles 2.3.2 aplicación con Capistrano de la parte superior (para FastCGI)?
-
22-08-2019 - |
Pregunta
exención de responsabilidad:. Soy un novato a los carriles y Capistrano (pero un .NET C # desarrollador intermedio) tratando de aprender más
he estado tienen el tiempo más difícil conseguir un proceso de desarrollo Capistrano puesta a punto. Esto es lo que tengo hasta ahora para mi deploy.rb:
set :application, "MyAppName"
set :domain, "domainname"
set :user, "userid"
set :repository, "svn+ssh://#{user}@#{domain}/home/#{user}/svn/#{application}/trunk"
set :rails_env, :production
set :chmod755, %w(app config db lib public vendor script tmp public/dispatch.cgi public/dispatch.fcgi public/dispatch.rb)
set :deploy_to, "/home/#{user}/apps/#{application}"
set :use_sudo, false
set :deploy_via, :checkout
set :group_writable, false
default_run_options[:pty] = true
role :app, domain
role :web, domain
role :db, domain, :primary => true
aquí está mi Capfile:
load 'deploy' if respond_to?(:namespace) # cap2 differentiator
Dir['vendor/plugins/*/recipes/*.rb'].each { |plugin| load(plugin) }
load 'config/deploy'
namespace :deploy do
task :restart, :roles => :app do
run "#{current_path}/script/process/reaper --dispatcher=dispatch.fcgi"
end
desc "Set the proper permissions for directories and files on HostingRails accounts"
task :after_deploy do
run(chmod755.collect do |item|
"chmod 755 #{current_path}/#{item}"
end.join(" && "))
end
end
- Rails 2.3.2 no tiene el directorio de la escritura / proceso por lo que la tarea de reinicio no funciona en absoluto. ¿Cómo puedo solucionar esto?
- ¿Hay una manera de establecer la variable RAILS_ENV en environment.rb a la "producción" cuando se despliega la aplicación ( "set: RAILS_ENV,: producción" no lo hace) ?
- También, me estoy perdiendo nada más de estos 2 archivos?
Solución
Aquí está mi deploy.rb, que en realidad no se ha actualizado en mucho tiempo. Corro dos comandos sed para establecer el entorno dentro de mi: after_update_code tarea. Estoy seguro de que hay una manera más fácil de hacerlo, pero esta es mi método actual.
require 'erb'
before "deploy:setup", :db
after "deploy:update_code", "db:symlink"
after "deploy", "deploy:cleanup"
def prompt_with_default(var, default)
set(var) do
Capistrano::CLI.ui.ask "Enter #{var} [#{default}] : "
end
set var, default if eval("#{var.to_s}.empty?")
end
default_run_options[:pty] = true
set :rake, "/usr/local/bin/rake"
set :user, "your username"
set :application, "application name"
set :repository, "svn repository path"
set :host, "domain name"
set :db_host, "DB host name"
set :db_user, "DB user name"
set :db_prefix, "any DB name prefix your host might require"
set :rails_env, "production"
set :deploy_to, "/home/username/rails/#{host}" # your deployment directory
role :app, host
role :web, host
role :db, host, :primary => true
set :use_sudo, false
set :checkout, "export"
#
# TASKS
#
desc "Tasks to execute after code update"
task :after_update_code, :roles => [:app, :db, :web] do
# Make sure we're running in production
run "sed -i -e '/ENV.*RAILS_ENV/s/# //' #{release_path}/config/environment.rb"
run "sed -i -e '/ENV.*RAILS_ENV/s/production/#{rails_env}/' #{release_path}/config/environment.rb"
# Add banned IPs
deny_lines = []
File.readlines("#{release_path}/config/banned_ips").each {|ip|
deny_lines << "deny from #{ip}"
}
ip_ban_block = <<EOBAN
# Bannination
order allow,deny
#{deny_lines.join}
allow from all
EOBAN
run "sed -i -e 's/# BANNED IPS/#{ip_ban_block}/' #{release_path}/public/.htaccess"
run "chmod +x #{release_path}/script/runner"
run "chmod +x #{release_path}/script/process/reaper"
run "chmod +x #{release_path}/script/process/spawner"
run "chmod 755 #{release_path}/public/dispatch.*"
end
desc "Restarting after deployment"
task :after_deploy, :roles => [:app, :db, :web] do
run "cd #{current_path} && rake RAILS_ENV=production db:sessions:clear tmp:clear"
# fix permissions
run "dos2unix #{release_path}/public/dispatch.*"
run "dos2unix #{release_path}/public/.htaccess"
run "chmod -R 755 #{release_path}"
run "chmod -R 775 #{release_path}/log #{release_path}/tmp #{release_path}/script"
run "find #{release_path}/ | xargs touch"
run "touch #{deploy_to}/current/public/dispatch.fcgi"
end
desc "Restarting after rollback"
task :after_rollback, :roles => [:app, :db, :web] do
run "touch #{deploy_to}/current/public/dispatch.fcgi"
end
namespace :db do
desc "Create database yaml in shared path"
task :default do
prompt_with_default(:db_password, "")
db_config = ERB.new <<-EOF
base: &base
adapter: mysql
port: 3306
host: #{db_host}
username: #{db_user}
password: #{db_password}
development:
database: #{db_prefix}#{application}development
<<: *base
test:
database: #{db_prefix}#{application}test
<<: *base
production:
database: #{db_prefix}#{application}production
<<: *base
EOF
run "mkdir -p #{shared_path}/config"
put db_config.result, "#{shared_path}/config/database.yml"
end
desc "Make symlink for database yaml"
task :symlink do
run "ln -nfs #{shared_path}/config/database.yml #{release_path}/config/database.yml"
end
end
Una vez que configuro mi variables, tengo un script bash que corre:
svn export $svn_path . --force
cap deploy
Eso me piden mi contraseña dos veces. Una vez para la exportación desde SVN, y una vez como un mensaje para generar automáticamente mi database.yml en el camino compartido.
Otros consejos
actualizado mi respuesta, véase # 3 ...
No consumo FastCGI para el despliegue, pero algunas cosas que vienen a la mente:
- Las secuencias de comandos de proceso se han movido fuera de los carriles central y en un plugin , el cual se puede agarrar de GitHub.
-
En cuanto a mi archivo deploy.rb, es probable que tengas que pasar la variable de entorno RAILS_ENV en la secuencia de comandos a través de la línea de comandos, similar a:
run #{current_path}/script/process/reaper RAILS_ENV=#{rails_env} --dispatcher=dispatch.fcgi
- EDIT: En realidad, es un poco extraño tener sus tareas en el lugar de Capfile deploy.rb - aunque mirando este hilo en el Capistrano grupo de Google, no es mal visto por completo. Depende de usted / su equipo, supongo.
Espero que esto le apunta en la dirección correcta.