2

あるサーバーに接続し、別のサーバーにrsyncしてから、2番目のサーバーに接続して一連のコマンドを実行する必要があるコードがあります。しかし、必ず 2 回目の SSH 接続で'do_open_failed': open failed (1) (Net::SSH::ChannelOpenFailed)エラーがスローされます。ここで何か間違ったことをしていますか?最初の接続を適切に閉じて、2番目の接続を接続する方法はありますか?

Net::SSH.start(self.from_creds['host'], self.from_creds['user'], :password => self.from_creds['password']) do |ssh|
  channel = ssh.open_channel do |ch|
    ch.exec "/usr/bin/rsync -e ssh -varuzP --exclude=sys-export --delete #{self.from_creds['filepath']}/#{self.client_id}/ #{self.scp_to}/#{new_client_id}" do |ch, success|
      raise "could not execute command" unless success

      # "on_data" is called when the process writes something to stdout
      ch.on_data do |c, data|
        $stdout.print data
      end

      # "on_extended_data" is called when the process writes something to stderr
      ch.on_extended_data do |c, type, data|
        $stderr.print data
      end

      ch.on_close { puts "done!" }
    end
  end
  channel.wait
end
Net::SSH.start(self.to_creds['host'], self.to_creds['user'], :password => self.to_creds['password']) do |ssh1|
  # Do some other stuff here
  tmp_path = "#{self.to_creds['filepath']}/tmp/#{Time.now.to_i}"
  ssh1.exec "mkdir -p #{tmp_path}"
  ssh1.exec "cd #{self.to_creds['filepath']}/#{new_client_id}"
end
4

1 に答える 1