функция не работает в производственном режиме - PullRequest
3 голосов
/ 19 марта 2010

Я использую гем rvideo для перекодирования файлов в формат .flv.

  class Video < ActiveRecord::Base
  include AASM
  aasm_column :status
  aasm_initial_state :initial

  aasm_state :initial
  aasm_state :converting, :exit => :transcode
  aasm_state :transfering , :exit => :send_s3
   aasm_state :completed
   aasm_state :failed

  aasm_event :convert do
   transitions :from => [:initial], :to => :converting
    end

   aasm_event :transfer do
   transitions :from => [:converting], :to => :transfering
    end

   aasm_event :complete do
    transitions :from => [:transfering], :to => :completed
   end

    aasm_event :error do
     transitions :from => [:initial, :converting, :transfering, :completed]
     end

   has_attached_file :asset, 
     :path => "uploads/:attachment/:id.:basename.:extension"

     def flash_path
    return self.asset.path + '.flv'
    end

    def flash_name
      return File::basename(self.asset.path)# + '.flv'
     end

    def flash_url
    return "#{AWS_HOST}/#{AWS_BUCKET}/#{self.flash_name}"
   end

  # transcode file
   def transcode
     begin
    RVideo::Transcoder.logger = logger
     file = RVideo::Inspector.new(:file => self.asset.path)
  command = "ffmpeg -i $input_file$ -y -s $resolution$ -ar 44100 -b 64k -r 15 -sameq  $output_file$"
    options = {
    :input_file => "#{RAILS_ROOT}/#{self.asset.path}",
    :output_file => "#{RAILS_ROOT}/#{self.flash_path}",
    :resolution => "320x200" 
  }


  transcoder = RVideo::Transcoder.new
  transcoder.execute(command, options)
  rescue RVideo::TranscoderError => e
    logger.error "Encountered error transcoding #{self.asset.path}"
    logger.error e.message
  end
 end

Входной файл добавляется в каталог ресурсов, но я никогда не получаю выходной файл. На странице просмотра Aasm висит на «конвертации».

1 Ответ

1 голос
/ 19 марта 2010

Это может звучать смешно, но что говорят журналы вашего сервера, когда он зависает? Это скорее всего проблема с сервером. На самом деле, похоже, что rvideo нужно много оперативной памяти, поэтому, если вы запускаете это на общем хосте, или какой-то фрагмент, который имеет только 256 оперативных памяти, или что-то еще, вам может понадобиться много больше.

Попробуйте запустить его в производственном режиме на компьютере разработчика.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...