ffmpeg.exe зависает - PullRequest
       5

ffmpeg.exe зависает

1 голос
/ 11 августа 2011

Я использую Asp.Net C # Framework 4 и в настоящее время разрабатываю приложение для конвертации видео.Я также использую ffmpeg для конвертирования всех загруженных форматов в flv.Сначала я конвертирую загруженный файл в mpg, а затем в flv из-за проблем, с которыми я столкнулся при попытке преобразования напрямую в flv из mp4.Но ffmpeg зависает, как только завершается процесс преобразования в файл mpg.Когда я запускаю диспетчер задач и проверяю список процессов, он просто стоит без использования ресурсов процессора.Когда я заканчиваю процесс ffmpeg непосредственно из диспетчера задач, происходит другой процесс, который конвертируется из mpg в flv и превью-файл (jpg) и работает плавно.Из-за зависания первого процесса второй процесс не может запуститься, когда я пытаюсь загрузить файл из формы загрузки файлов моей веб-страницы.Я ценю любой ответ с этого момента.Вот мой код:

        string duration = "00:00:00";

        //converting video
        Process ffmpeg;
        ffmpeg = new Process();

        // convert to mpg 1st
        ffmpeg.StartInfo.Arguments = " -i \"" + Server.MapPath("static/user/vid/") + videolink + "\" -f mpeg -b 300k -ac 2 -ab 128k -ar 44K \"" + Server.MapPath("static/user/vid/") + mpglink + "\"";
        ffmpeg.StartInfo.FileName = Page.MapPath("bin/ffmpeg.exe");
        ffmpeg.StartInfo.CreateNoWindow = true;
        ffmpeg.StartInfo.UseShellExecute = false;
        ffmpeg.StartInfo.RedirectStandardOutput = true;
        ffmpeg.StartInfo.RedirectStandardError = true;
        ffmpeg.Start();

        ffmpeg.WaitForExit();
        ffmpeg.Close();


        // mpg 2 flv
        ffmpeg = new Process();
        ffmpeg.StartInfo.Arguments = " -i \"" + Server.MapPath("static/user/vid/") + mpglink + "\" -f flv -s 624x352 \"" + Server.MapPath("static/user/vid/") + flvlink + "\"";
        ffmpeg.StartInfo.FileName = Page.MapPath("bin/ffmpeg.exe");
        ffmpeg.StartInfo.CreateNoWindow = true;
        ffmpeg.StartInfo.UseShellExecute = false;
        ffmpeg.StartInfo.RedirectStandardOutput = true;
        ffmpeg.StartInfo.RedirectStandardError = true;
        ffmpeg.Start();

        ffmpeg.BeginOutputReadLine();
        string error = ffmpeg.StandardError.ReadToEnd();
        ffmpeg.WaitForExit();

        try
        {
            duration = error.Substring(error.IndexOf("Duration: ") + 10, 8);
        }
        catch
        {
        }

        if (ffmpeg.ExitCode != 0)
        {
            ltrUpload.Text = "<div class=\"resultbox-negative\" id=\"divResult\">Problem occured during upload process. Error code: " + error + "<br>" + "</div>";
            return;
        }
        ffmpeg.Close();


        // generate preview image
        ffmpeg.StartInfo.Arguments = " -i \"" + Server.MapPath("static/user/vid/") + flvlink + "\" -s 624x352 -ss 00:00:03 -an -vframes 1 -f image2 -vcodec mjpeg \"" + Server.MapPath("static/user/vid/") + flvlink.Replace(".flv", ".jpg") + "\"";
        ffmpeg.StartInfo.FileName = Page.MapPath("bin/ffmpeg.exe");
        ffmpeg.StartInfo.CreateNoWindow = true;
        ffmpeg.StartInfo.UseShellExecute = false;
        ffmpeg.StartInfo.RedirectStandardOutput = true;
        ffmpeg.StartInfo.RedirectStandardError = true;
        ffmpeg.Start();
        ffmpeg.WaitForExit();
        ffmpeg.Close();

        // deleting original file and mpg
        FileInfo fi = new FileInfo(Server.MapPath("static/user/vid/") + videolink);
        if (fi.Exists) fi.Delete();
        fi = new FileInfo(Server.MapPath("static/user/vid/") + mpglink);
        if (fi.Exists) fi.Delete();

Ответы [ 2 ]

3 голосов
/ 17 марта 2015

Я знаю, что это очень старый вопрос, но если кто-то попадет сюда из-за поиска в Google, ответ будет следующим:

Вам также необходимо прочитать перенаправленный вывод ошибок первого процесса ffmpeg, даже если он вам не нужен. Это приведет к взаимоблокировке, если вы не прочитаете перенаправленный вывод ошибок, потому что ваша программа будет ожидать завершения процесса, но процесс ожидает чтения заполненного выходного потока ошибок. Вы можете посмотреть это здесь .

    // convert to mpg 1st
    ffmpeg.StartInfo.Arguments = " -i \"" + Server.MapPath("static/user/vid/") + videolink + "\" -f mpeg -b 300k -ac 2 -ab 128k -ar 44K \"" + Server.MapPath("static/user/vid/") + mpglink + "\"";
    ffmpeg.StartInfo.FileName = Page.MapPath("bin/ffmpeg.exe");
    ffmpeg.StartInfo.CreateNoWindow = true;
    ffmpeg.StartInfo.UseShellExecute = false;
    ffmpeg.StartInfo.RedirectStandardOutput = true;
    ffmpeg.StartInfo.RedirectStandardError = true;
    ffmpeg.Start();

    // Use asynchronous read operations on at least one of the streams.
    // Reading both streams synchronously would generate another deadlock.
    ffmpeg.BeginOutputReadLine();
    string tmpErrorOut = ffmpeg.StandardError.ReadToEnd();

    ffmpeg.WaitForExit();
    ffmpeg.Close();

Таким образом, вам придется читать перенаправленные сообщения об ошибках и потоки вывода, как вы это делали со вторым процессом ffmpeg.

То же самое относится и к генерации изображения для предварительного просмотра!

0 голосов
/ 08 ноября 2011
private bool ReturnVideo(string fileName)
{
  string html = string.Empty;
  //rename if file already exists

  int j = 0;
  string AppPath;
  string inputPath;
  string outputPath;
  string imgpath;
  AppPath = Request.PhysicalApplicationPath;
  //Get the application path
  inputPath = AppPath + "Upload\\Videos\\OriginalVideo";
  //Path of the original file
  outputPath = AppPath + "Upload\\Videos\\ConvertVideo";
  //Path of the converted file
  imgpath = AppPath + "Upload\\Videos\\Thumbs";
  //Path of the preview file
  string filepath = Server.MapPath("../Upload/Videos/OriginalVideo/" + fileName);
  while (File.Exists(filepath))
  {
    j = j + 1;
    int dotPos = fileName.LastIndexOf(".");
    string namewithoutext = fileName.Substring(0, dotPos);
    string ext = fileName.Substring(dotPos + 1);
    fileName = namewithoutext + j + "." + ext;
    filepath = Server.MapPath("../Upload/Videos/OriginalVideo/" + fileName);
  }
  try
  {
    this.fileuploadImageVideo.SaveAs(filepath);
  }
  catch
  {
    return false;
  }
  string outPutFile;
  outPutFile = "../Upload/Videos/OriginalVideo/" + fileName;
  int i = this.fileuploadImageVideo.PostedFile.ContentLength;
  System.IO.FileInfo a = new System.IO.FileInfo(Server.MapPath(outPutFile));
  while (a.Exists == false)
  { }
  long b = a.Length;
  while (i != b)
  { }

  string cmd = " -i \"" + inputPath + "\\" + fileName + "\" \"" + outputPath + "\\" + fileName.Remove(fileName.IndexOf(".")) + ".flv" + "\"";
  ConvertNow(cmd);
  ViewState["fileName"] = fileName.Remove(fileName.IndexOf(".")) + ".wmv";
  string imgargs = " -i \"" + inputPath + "\\" + fileName.Remove(fileName.IndexOf(".")) + ".wmv" + "\" -f image2 -ss 1 -vframes 1 -s 280x200 -an \"" + imgpath + "\\" + fileName.Remove(fileName.IndexOf(".")) + ".jpg" + "\"";
  ConvertNow(imgargs);

  return true;
}

private void ConvertNow(string cmd)
{
  string exepath;
  string AppPath = Request.PhysicalApplicationPath;
  //Get the application path
  exepath = AppPath + "ffmpeg.exe";
  System.Diagnostics.Process proc = new System.Diagnostics.Process();
  proc.StartInfo.FileName = exepath;
  //Path of exe that will be executed, only for "filebuffer" it will be "wmvtool2.exe"
  proc.StartInfo.Arguments = cmd;
  //The command which will be executed
  proc.StartInfo.UseShellExecute = false;
  proc.StartInfo.CreateNoWindow = true;
  proc.StartInfo.RedirectStandardOutput = false;
  proc.Start();

  while (proc.HasExited == false)
  { }
}

if (fileuploadImageVideo.HasFile)
{
  ReturnVideo(this.fileuploadImageVideo.FileName.ToString());

  string filename = fileuploadImageVideo.PostedFile.FileName;
  fileuploadImageVideo.SaveAs(Server.MapPath("../upload/Video/"+filename));
  objfun.Video = filename ;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...