2016-04-05 7 views
0

Ich möchte capistrano verwenden, um meine Webanwendung auf meinem vps bereitzustellen. Leider habe ich einige Fehler bekommen:Capistrano, Debian 8 systemctl

DEBUG [6de1d411] Running [ -L /var/www/myapp/releases/20160405125654/log ] as [email protected] 
DEBUG [6de1d411] Command: [ -L /var/www/myapp/releases/20160405125654/log ] 
DEBUG [6de1d411] Finished in 0.005 seconds with exit status 0 (successful). 
DEBUG [cf28b01d] Running [ -L /var/www/myapp/releases/20160405125654/tmp/pids ] as [email protected] 
DEBUG [cf28b01d] Command: [ -L /var/www/myapp/releases/20160405125654/tmp/pids ] 
DEBUG [cf28b01d] Finished in 0.005 seconds with exit status 1 (failed). 
DEBUG [c7f0b156] Running [ -d /var/www/myapp/releases/20160405125654/tmp/pids ] as [email protected] 
DEBUG [c7f0b156] Command: [ -d /var/www/myapp/releases/20160405125654/tmp/pids ] 
DEBUG [c7f0b156] Finished in 0.005 seconds with exit status 1 (failed). 

Was habe ich gelesen, sind diese fehlgeschlagenen Test ok, da es nur Existenz von Symlinks und Verzeichnisse überprüft. Aber folgendes ist irgendwie das Spiel Brecher:

INFO [c1b0c10e] Finished in 0.007 seconds with exit status 0 (successful). 
INFO [e895fd13] Running /usr/bin/env sudo /etc/init.d/nginx reload as [email protected] 
DEBUG [e895fd13] Command: (export RBENV_ROOT="$HOME/.rbenv" RBENV_VERSION="2.2.3" ; /usr/bin/env sudo /etc/init.d/nginx reload) 
DEBUG [e895fd13] Reloading nginx configuration (via systemctl): nginx.service 
DEBUG [e895fd13] . 
INFO [e895fd13] Finished in 0.037 seconds with exit status 0 (successful). 
INFO [1a822f12] Running /usr/bin/env service unicorn_myapp_production restart as [email protected] 
DEBUG [1a822f12] Command: (export RBENV_ROOT="$HOME/.rbenv" RBENV_VERSION="2.2.3" ; /usr/bin/env service unicorn_myapp_production restart) 
DEBUG [1a822f12] /usr/bin/env: service 
DEBUG [1a822f12] : No such file or directory 
(Backtrace restricted to imported tasks) 
cap aborted! 
SSHKit::Runner::ExecuteError: Exception while executing as [email protected]: service exit status: 127 
service stdout: Nothing written 
service stderr: /usr/bin/env: service: No such file or directory 

Offensichtlich Debian jessie setzt auf systemctl statt service, da

/usr/bin/env service 

ist wirklich nicht existiert. Nein, ich möchte das Standardverhalten zu überschreiben, indem das Hinzufügen

namespace :unicorn do 

    task :defaults do 
    on roles :app do 
     set :unicorn_user, fetch(:unicorn_user, deploy_user) 
    end 
    end 

    desc 'Setup Unicorn initializer' 
    task :setup_initializer do 
    on roles :app do 
     next if file_exists? unicorn_initd_file 
     sudo_upload! template('unicorn_init.erb'), unicorn_initd_file 
     execute :chmod, '+x', unicorn_initd_file 
     sudo 'update-rc.d', '-f', fetch(:unicorn_service), 'defaults' 
    end 
    end 

    desc 'Setup Unicorn app configuration' 
    task :setup_app_config do 
    on roles :app do 
     next if file_exists? fetch(:unicorn_config) 
     execute :mkdir, '-pv', File.dirname(fetch(:unicorn_config)) 
     upload! template('unicorn.rb.erb'), fetch(:unicorn_config) 
    end 
    end 

    %w[start stop restart].each do |command| 
    desc "#{command} unicorn" 
    task command do 
     on roles :app do 
     # execute :service, fetch(:unicorn_service), command 
     # run "#{sudo} systemctl #{command} unicorn_#{application}" 
     sudo "/etc/init.d/unicorn_#{fetch(:unicorn_service)} #{command}" 
     end 
    end 
    end 

    before :setup_initializer, :defaults 

end 

zu /myapp/config/deploy.rb. Aber capistrano ignoriert diese Einstellungen. Wie kann ich sicherstellen, dass eine Debian-8-spezifische Konfiguration geladen wird?

Antwort

0

Ich bin nicht vertraut mit Einhorn, aber ich nehme an, Sie verwenden etwas, das die Cap-Aufgaben definiert, die Sie dann überschreiben möchten? Wenn dies der Fall ist, müssten Sie bei Capistrano 3 die ursprüngliche Aufgabe löschen, bevor Sie sie neu definieren. Was Sie gerade tun, erweitert derzeit die Aufgaben. Sie müssten Rake::Task["task_name"].clear etwas wie dieses verwenden:

namespace :unicorn do 
    %w[start stop restart].each do |command| 
    Rake::Task["unicorn:#{command}"].clear 

    desc "#{command} unicorn" 
    task command do 
     on roles :app do 
     # execute :service, fetch(:unicorn_service), command 
     # run "#{sudo} systemctl #{command} unicorn_#{application}" 
     sudo "/etc/init.d/unicorn_#{fetch(:unicorn_service)} #{command}" 
     end 
    end 
    end 
end 
+1

Dies beantwortet die Frage, aber löst das Problem nicht. Diese Lösung scheint einfach zu sein: Byebye Debian, Hello Ubuntu. – wieschoo