Kaynağa Gözat

Optimized transcoder args

Toby Chui 1 yıl önce
ebeveyn
işleme
77e7ecced6
1 değiştirilmiş dosya ile 15 ekleme ve 7 silme
  1. 15 7
      mod/media/transcoder/transcoder.go

+ 15 - 7
mod/media/transcoder/transcoder.go

@@ -12,6 +12,7 @@ import (
 	"log"
 	"net/http"
 	"os/exec"
+	"time"
 )
 
 type TranscodeOutputResolution string
@@ -27,25 +28,30 @@ const (
 func TranscodeAndStream(w http.ResponseWriter, r *http.Request, inputFile string, resolution TranscodeOutputResolution) {
 	// Build the FFmpeg command based on the resolution parameter
 	var cmd *exec.Cmd
+
+	transcodeFormatArgs := []string{"-f", "mp4", "-vcodec", "libx264", "-preset", "superfast", "-g", "60", "-movflags", "frag_keyframe+empty_moov+faststart", "pipe:1"}
+	var args []string
 	switch resolution {
 	case "360p":
-		cmd = exec.Command("ffmpeg", "-i", inputFile, "-vf", "scale=-1:360", "-f", "mp4", "-vcodec", "libx264", "-preset", "fast", "-movflags", "frag_keyframe+empty_moov", "pipe:1")
+		args = append([]string{"-i", inputFile, "-vf", "scale=-1:360"}, transcodeFormatArgs...)
 	case "720p":
-		cmd = exec.Command("ffmpeg", "-i", inputFile, "-vf", "scale=-1:720", "-f", "mp4", "-vcodec", "libx264", "-preset", "fast", "-movflags", "frag_keyframe+empty_moov", "pipe:1")
+		args = append([]string{"-i", inputFile, "-vf", "scale=-1:720"}, transcodeFormatArgs...)
 	case "1080p":
-		cmd = exec.Command("ffmpeg", "-i", inputFile, "-vf", "scale=-1:1080", "-f", "mp4", "-vcodec", "libx264", "-preset", "fast", "-movflags", "frag_keyframe+empty_moov", "pipe:1")
+		args = append([]string{"-i", inputFile, "-vf", "scale=-1:1080"}, transcodeFormatArgs...)
 	case "":
 		// Original resolution
-		cmd = exec.Command("ffmpeg", "-i", inputFile, "-f", "mp4", "-vcodec", "libx264", "-preset", "fast", "-movflags", "frag_keyframe+empty_moov", "pipe:1")
+		args = append([]string{"-i", inputFile}, transcodeFormatArgs...)
 	default:
 		http.Error(w, "Invalid resolution parameter", http.StatusBadRequest)
 		return
 	}
+	cmd = exec.Command("ffmpeg", args...)
 
 	// Set response headers for streaming MP4 video
 	w.Header().Set("Content-Type", "video/mp4")
 	w.Header().Set("Transfer-Encoding", "chunked")
-	w.Header().Set("Cache-Control", "no-cache")
+	w.Header().Set("Cache-Control", "public, max-age=3600, s-maxage=3600, must-revalidate")
+	w.Header().Set("Accept-Ranges", "bytes")
 
 	// Get the command output pipe
 	stdout, err := cmd.StdoutPipe()
@@ -74,8 +80,10 @@ func TranscodeAndStream(w http.ResponseWriter, r *http.Request, inputFile string
 	// Monitor client connection close
 	go func() {
 		<-r.Context().Done()
+		time.Sleep(300 * time.Millisecond)
 		cmd.Process.Kill() // Kill the FFmpeg process when client disconnects
-		close(done)
+		done <- struct{}{}
+		//close(done)
 	}()
 
 	// Copy the command output to the HTTP response in a separate goroutine
@@ -97,7 +105,7 @@ func TranscodeAndStream(w http.ResponseWriter, r *http.Request, inputFile string
 
 	go func() {
 		if err := cmd.Wait(); err != nil {
-			log.Printf("FFmpeg process failed: %v", err)
+			log.Printf("FFmpeg process exited: %v", err)
 			return
 		}
 	}()