diff options
-rwxr-xr-x | bin/istream.sh | 26 | ||||
-rw-r--r-- | bin/session.php | 61 | ||||
-rw-r--r-- | bin/utils.php | 19 |
3 files changed, 74 insertions, 32 deletions
diff --git a/bin/istream.sh b/bin/istream.sh index b8535c7..bd08092 100755 --- a/bin/istream.sh +++ b/bin/istream.sh @@ -55,23 +55,29 @@ fi $FFMPEGPREFIX | $FFPATH -i "$STREAM" -deinterlace -f mpegts -acodec libmp3lame -ab $ARATE -ac 2 -s $XY -vcodec libx264 -b $VRATE -flags +loop \ -cmp \+chroma -partitions +parti4x4+partp8x8+partb8x8 -subq 5 -trellis 1 -refs 1 -coder 0 -me_range 16 -keyint_min 25 \ -sc_threshold 40 -i_qfactor 0.71 -bt $VRATE -maxrate $VRATE -bufsize $VRATE -rc_eq 'blurCplx^(1-qComp)' -qcomp 0.6 \ - -qmin 10 -qmax 51 -qdiff 4 -level 30 -g 30 -async 2 -threads 4 - 2>$FFMPEGLOG >./fifo) & + -qmin 10 -qmax 51 -qdiff 4 -level 30 -g 30 -async 2 -threads 4 - 2>$FFMPEGLOG 1>./fifo) & # Store ffmpeg pid -PID=$! -if [ ! -z "$PID" ] +FFPID=$! +if [ ! -z "$FFPID" ] then - 2>/dev/null echo `\ps ax --format pid,ppid | grep "$PID$" | awk {'print $1'}` > ./ffmpeg.pid + SPID=`\ps ax --format pid,ppid | grep "$FFPID$" | awk {'print $1'}`; + if [ ! -z "$SPID" ] + then + 2>/dev/null echo $SPID > ./ffmpeg.pid + fi fi # Now start segmenter -(trap "rm -f ./segmenter.pid" EXIT HUP INT TERM ABRT; 2>/dev/null $SEGMENTERPATH ./fifo $SEGDUR stream stream.m3u8 $HTTP_PATH$SESSION/ $SEGWIN) & +(trap "rm -f ./segmenter.pid; cat ./fifo" EXIT HUP INT TERM ABRT; 2>/dev/null $SEGMENTERPATH ./fifo $SEGDUR stream stream.m3u8 $HTTP_PATH$SESSION/ $SEGWIN) & # Store segmenter pid -PID=$! -if [ ! -z "$PID" ] +SEGPID=$! +if [ ! -z "$SEGPID" ] then - 2>/dev/null echo `\ps ax --format pid,ppid | grep "$PID$" | awk {'print $1'}` > ./segmenter.pid + SPID=`\ps ax --format pid,ppid,cmd | grep "$SEGPID$" | grep segmenter | awk {'print $1'}`; + if [ ! -z "$SPID" ] + then + 2>/dev/null echo $SPID > ./segmenter.pid + fi fi - - diff --git a/bin/session.php b/bin/session.php index e52b6e4..e854058 100644 --- a/bin/session.php +++ b/bin/session.php @@ -197,11 +197,11 @@ function sessiondeletesingle($session) $cmd = ""; // First kill ffmpeg - if (file_exists($ram ."ffmpeg.pid")) + if (is_pid_running($ram ."ffmpeg.pid")) $cmd .= " kill `cat " .$ram ."ffmpeg.pid`; rm " .$ram ."ffmpeg.pid; "; // Then kill segmenter - if (file_exists($ram ."segmenter.pid")) + if (is_pid_running($ram ."segmenter.pid")) $cmd .= " kill `cat " .$ram ."segmenter.pid`; rm " .$ram ."segmenter.pid; "; addlog("Sending session kill command: " .$cmd); @@ -236,10 +236,10 @@ function getstreamingstatus($session) if (count(glob($path . '/*.ts')) < 2) { - if (!file_exists($path .'/segmenter.pid')) + if (!is_pid_running($path .'/ffmpeg.pid') || !is_pid_running($path .'/segmenter.pid')) { $status['status'] = "error"; - $status['message'] = "<b>Error: segmenter did not start correclty</b>"; + $status['message'] = "<b>Error: streaming could not start correclty</b>"; } else { @@ -256,25 +256,23 @@ function getstreamingstatus($session) $status['message'] = "<b>Vid: requesting " .$url ."</b>"; break; } + } - $status['message'] .= "<br>"; + $status['message'] .= "<br>"; - - $status['message'] .= "<br> * FFmpeg: "; - if (file_exists($path .'/ffmpeg.pid')) - $status['message'] .= "<i>running</i>"; - else - $status['message'] .= "<i>stopped</i>"; - $status['message'] .= "<br> * Segmenter: "; - if (file_exists($path .'/segmenter.pid')) - { - $status['message'] .= "<i>running</i> ("; - $status['message'] .= count(glob($path . '/*.ts')) ."/2)</i>"; - } - else - $status['message'] .= "<i>stopped</i>"; - + $status['message'] .= "<br> * FFmpeg: "; + if (is_pid_running($path .'/ffmpeg.pid')) + $status['message'] .= "<i>running</i>"; + else + $status['message'] .= "<i>stopped</i>"; + $status['message'] .= "<br> * Segmenter: "; + if (is_pid_running($path .'/segmenter.pid')) + { + $status['message'] .= "<i>running</i> ("; + $status['message'] .= count(glob($path . '/*.ts')) ."/2)</i>"; } + else + $status['message'] .= "<i>stopped</i>"; } else { @@ -284,7 +282,7 @@ function getstreamingstatus($session) $status['message'] .= "<br> * Quality: <i>" .$mode ."</i>"; $status['message'] .= "<br> * Status: "; - if (file_exists($path .'/segmenter.pid')) + if (is_pid_running($path .'/segmenter.pid')) $status['message'] .= "<i>encoding...</i>"; else $status['message'] .= "<i>fully encoded</i>"; @@ -330,6 +328,25 @@ function sessiongetstatus($session, $prevmsg) $status['status'] = "error"; $status['message'] = "Error: session could not start"; + + $status['message'] .= "<br>"; + + $status['message'] .= "<br> * FFmpeg: "; + + if (is_pid_running('../ram/' .$session .'/ffmpeg.pid')) + $status['message'] .= "<i>running</i>"; + else + $status['message'] .= "<i>stopped</i>"; + $status['message'] .= "<br> * Segmenter: "; + + if (is_pid_running('../ram/' .$session .'/segmenter.pid')) + { + $status['message'] .= "<i>running</i> ("; + $status['message'] .= count(glob('../ram/' .$session .'/*.ts')) ."/2)</i>"; + } + else + $status['message'] .= "<i>stopped</i>"; + addlog("Returning status: " .$status['message']); return $status; } @@ -382,7 +399,7 @@ function sessiongetlist() $newsession['name'] = "Error: " .$newsession['name']; // Check if encoding - if (file_exists('../ram/' .$session .'/segmenter.pid') && ($status['status'] != "error")) + if (is_pid_running('../ram/' .$session .'/segmenter.pid') && ($status['status'] != "error")) $newsession['encoding'] = 1; else $newsession['encoding'] = 0; diff --git a/bin/utils.php b/bin/utils.php index 2324032..a1489c8 100644 --- a/bin/utils.php +++ b/bin/utils.php @@ -182,4 +182,23 @@ if (!function_exists('json_encode')) } } +function is_pid_running($pidfile) +{ + // Check file + if (!file_exists($pidfile)) + return 0; + + // Check if pid has a pid inside + exec('cat ' .$pidfile, $output); + if (!is_numeric($output[0])) + return 0; + + // Check if pid is running + exec('ps `cat ' .$pidfile .'`', $output); + if(count($output) < 2) + return 0; + + return 1; +} + ?> |