Nginx Capistrano没有真正重新启动服务器?

Nginx Capistrano没有真正重新启动服务器?,nginx,capistrano,digital-ocean,Nginx,Capistrano,Digital Ocean,我使用Capistrano 2.15和Nginx在DigitalOcean水滴上运行 有时,特别是当我安装新的gems或运行迁移时,我需要硬重置我的drop以使更改生效 如果我在运行时只是在某个地方更改代码,则这不适用 cap deploy:restart 很好 另外,当我登录到我的机器并运行 service nginx restart 它无助于捕获新的迁移 deploy.rb require "rvm/capistrano" set :rvm_ruby_string, 'defaul

我使用Capistrano 2.15和Nginx在DigitalOcean水滴上运行

有时,特别是当我安装新的gems或运行迁移时,我需要硬重置我的drop以使更改生效

如果我在运行时只是在某个地方更改代码,则这不适用

cap deploy:restart 
很好

另外,当我登录到我的机器并运行

service nginx restart 
它无助于捕获新的迁移

deploy.rb

require "rvm/capistrano"

set :rvm_ruby_string, 'default'
set :rvm_type, :user

require "bundler/capistrano"

server "xx.xx.xx.xx", :web, :app, :db, primary: true

set :application, "xxx"
set :user, "deployer"
set :deploy_to, "/home/#{user}/apps/#{application}"
set :deploy_via, :remote_cache
set :use_sudo, false

set :scm, "git"
set :repository, "git@bitbucket.org:xxx/#{application}.git"
set :branch, "master"

default_run_options[:pty] = true
ssh_options[:forward_agent] = true

after "deploy", "deploy:cleanup" # keep only the last 5 releases

namespace :deploy do
  %w[start stop restart].each do |command|
    desc "#{command} unicorn server"
    task command, roles: :app, except: {no_release: true} do
      run "/etc/init.d/unicorn_#{application} #{command}"
    end
  end

  task :setup_config, roles: :app do
    sudo "ln -nfs #{current_path}/config/nginx.conf /etc/nginx/sites-enabled/#{application}"
    sudo "ln -nfs #{current_path}/config/unicorn_init.sh /etc/init.d/unicorn_#{application}"
    run "mkdir -p #{shared_path}/config"
    put File.read("config/database.example.yml"), "#{shared_path}/config/database.yml"
    puts "Now edit the config files in #{shared_path}."
  end
  after "deploy:setup", "deploy:setup_config"

  task :symlink_config, roles: :app do
    run "ln -nfs #{shared_path}/config/database.yml #{release_path}/config/database.yml"
  end
  desc "reload the database with seed data"
  task :seed do
    run "cd #{current_path}; bundle exec rake db:seed RAILS_ENV=#{rails_env}"
  end
  after "deploy:finalize_update", "deploy:symlink_config"

  desc "Make sure local git is in sync with remote."
  task :check_revision, roles: :web do
    unless `git rev-parse HEAD` == `git rev-parse origin/master`
      puts "WARNING: HEAD is not the same as origin/master"
      puts "Run `git push` to sync changes."
      exit
    end
  end
  before "deploy", "deploy:check_revision"

  desc "tail production log files" 
  task :tail_logs, :roles => :app do
    trap("INT") { puts 'Interupted'; exit 0; }
    run "tail -f #{shared_path}/log/unicorn.log" do |channel, stream, data|
      puts  # for an extra line break before the host name
      puts "#{channel[:host]}: #{data}" 
      break if stream == :err
    end
  end

end


namespace :assets do

  task :symlink, roles: :web do
    run ("rm -rf #{latest_release}/public/assets &&
          mkdir -p #{latest_release}/public &&
          mkdir -p #{shared_path}/assets &&
          ln -s #{shared_path}/assets #{latest_release}/public/assets")
  end
end

namespace :uploads do

    desc <<-EOD
      Creates the upload folders unless they exist
      and sets the proper upload permissions.
    EOD
    task :setup, :except => { :no_release => true } do
      dirs = [File.join(shared_path,'uploads' )]

      run "#{try_sudo} mkdir -p #{dirs.join(' ')} && #{try_sudo} chmod g+w #{dirs.join(' ')}"
    end 

    desc <<-EOD
      [internal] Creates the symlink to uploads shared folder
      for the most recently deployed version.
    EOD
    task :symlink, :except => { :no_release => true } do
      run "rm -rf #{release_path}/public/uploads"
      run "ln -nfs #{shared_path}/uploads #{release_path}/public/uploads"
    end

    desc <<-EOD
      [internal] Computes uploads directory paths
      and registers them in Capistrano environment.
    EOD
    task :register_dirs do
      set :uploads_dirs,    %w(public/uploads)
      set :shared_children, fetch(:shared_children) + fetch(:uploads_dirs)
    end

    after       "deploy:finalize_update", "uploads:symlink"
    on :start,  "uploads:register_dirs"

  end
要求“rvm/capistrano”
set:rvm_ruby_字符串“default”
设置:rvm_类型,:用户
需要“捆绑机/capistrano”
服务器“xx.xx.xx.xx”,:web,:app,:db,主服务器:true
集合:应用程序,“xxx”
集合:用户,“部署者”
设置:将_部署到“/home/#{user}/apps/#{application}”
set:deploy\u via,:remote\u缓存
设置:使用_sudo,false
设置:scm,“git”
集合:存储库,“git@bitbucket.org:xxx/#{application}.git“
集合:分支,“主”
默认运行选项[:pty]=真
ssh_选项[:转发_代理]=真
在“部署”之后,“部署:清理”#只保留最后5个版本
名称空间:deploydo
%w[启动-停止-重新启动]。每个do |命令|
desc“#{command}unicorn服务器”
任务命令,角色::app,除了:{no_release:true}do
运行“/etc/init.d/unicorn_35;{application}{command}”
结束
结束
任务:设置配置,角色::应用程序do
sudo“ln-nfs{current#u path}/config/nginx.conf/etc/nginx/sites enabled/#{application}”
sudo“ln-nfs{current#u path}/config/unicorn_init.sh/etc/init.d/unicorn#{application}”
运行“mkdir-p{shared_path}/config”
放置File.read(“config/database.example.yml”),“#{shared_path}/config/database.yml”
放置“现在编辑#{shared_path}中的配置文件。”
结束
在“部署:设置”之后,“部署:设置\u配置”
任务:符号链接配置,角色::应用程序do
运行“ln-nfs{shared_path}/config/database.yml{release_path}/config/database.yml”
结束
desc“用种子数据重新加载数据库”
任务:种子做什么
运行“cd#{current_path};bundle exec rake db:seed RAILS_ENV=#{RAILS_ENV}”
结束
在“deploy:finalize\u update”之后,“deploy:symlink\u config”
desc“确保本地git与远程git同步。”
任务:检查修订,角色::web do
除非`git rev parse HEAD`=`git rev parse origin/master`
放置“警告:头部与原点/主控点不同”
将“运行`git push`以同步更改。”
出口
结束
结束
在“部署”之前,“部署:检查修订”
描述“尾部生产日志文件”
任务:tail_日志,:roles=>:app do
陷阱(“INT”){put'Interupted';退出0;}
运行“tail-f#{shared_path}/log/unicorn.log”do |通道、流、数据|
将#置于主机名之前,以获得额外的换行符
放置“#{channel[:host]}:#{data}”
如果流==中断:错误
结束
结束
结束
名称空间:资产做什么
任务:符号链接,角色::web do
运行(“rm-rf{最新发布版}/public/assets&&
mkdir-p{最新发布版}/public&&
mkdir-p{shared_path}/assets&&
ln-s{共享路径}/assets{最新版本}/public/assets”)
结束
结束
名称空间:上传可以吗
desc true}do
dirs=[File.join(共享路径,'uploads')]
运行“{try_sudo}mkdir-p#{dirs.join(“”)}&&{try_sudo}chmod g+w#{dirs.join(“”)}”
结束
desc true}do
运行“rm-rf{release_path}/public/uploads”
运行“ln-nfs{shared_path}/uploads{release_path}/public/uploads”
结束

desc部署时使用cap:deploy

你用独角兽还是乘客

请将代码粘贴到deploy.rb unicorn.rb(如果您使用unicorn)和unicorn_init.sh(或您创建符号链接的sh文件)中


最后一个问题是您在fork之后使用的fork之前的问题?(零停机部署?

您的问题是什么?您定义了哪些其他任务(即部署时:重新启动)?在没有任何代码/配置的情况下,我们如何复制它?嗨,matanco。是的,我使用cap:deploywithunicorn和nginx。我粘贴了deploy.rb,没有使用before_fork/after_fork,我使用了两个额外的任务:tail_日志、用于资产和上传的符号链接以及database.yml