[beta testing] nodes for live streaming mp4

I am scared !!! I have already lost the desktop when upgrading from Stretch to Buster. If my Flow doesn't work anymore, I'm lost :sweat_smile:
Too much want to try, I'm crazy :crazy_face: let's go

Actually, I just deleted the #socket_io_3x branches. I am currently in the process of updating some things. Hang tight for a moment.

toooooo laaaaate ! :nerd_face:

The functionality was pushed into the master branches of those 2 mp4frag nodes. Leave off the #socket_io_3x and you should be ok.

i'm here :

image
no movement

like this ? :
npm install kevinGodell/node-red-contrib-mp4frag kevinGodell/node-red-contrib-ui-mp4frag kevinGodell/node-red-dashboard

1 Like

yes. i just pushed a quick fix. should be there for you

1 Like

image
no news, turn and turn and ...

1 Like

Installing the dashboard from GitHub takes a loooooong time. Trust me. I already did it like 100 times today and it was painful every time.

if i try this from @krambriw ? :

without the #socket_io_3x ?

[EDIT] moving now

Update Finished but black screen :
image
image


with this exec command :

ffmpeg -loglevel quiet -rtsp_transport tcp -i rtsp://192.168.1.9:554/user=xxxxxx_password=xxxxxxx_channel=0_stream=0.sdp?real_stream -c:a aac -c:v copy -f mp4 -movflags +frag_every_frame+empty_moov+default_base_moof -min_frag_duration 500000 pipe:1
1 Like

Node-red-restart
??

1 Like

i already do ... i re do

1 Like

image
the stream is running but nothing to display . i will delete nodes and re-create.

1 Like

the ui_mp4frag works with .m3u8 adress
image

but combined with mp4frag to stream IP camera : nop
image
image

it's too late here, see you tomorow .bye

1 Like

Atleast the server side is still producing video. Thats good. I wonder if you might have other nodes that are locked to socket.io v2. A couple ways to check:

  1. Run this command in the .node-red directory, npm ls socket.io
  2. Open the browser debug, specifically the network tab
    A. check the socket.io.js version loaded by clicking on the listed entry
    B. check the url of the ws connection to /mp4frag/socket.io/, should have EIO=4 in it

I just reinstalled many times and can't get it to break using the France news 24 feed using the same ffmpeg parameters that you posted, although that video is more stable by using the other movflag frag_keyframe vs frag_every_frame.

Absolutely latest instructions:

  1. change to node-red dir cd .node-red

  2. verify what libs are dependent on socket io npm ls socket.io

  3. uninstall dashboard and both mp4frag nodes npm uninstall node-red-dashboard node-red-contrib-mp4frag node-red-contrib-ui-mp4frag

  4. install replacement libs npm install kevinGodell/node-red-dashboard kevinGodell/node-red-contrib-mp4frag kevinGodell/node-red-contrib-ui-mp4frag

  • restart node-red-stop && node-red-start to be able to see console output or

  • restart node-red-restart

  1. Open debug console of preferred browser and go to network tab

  2. Find ws connections to /mp4frag/socket.io/ and verify that EIO=4

If somehow this does not work, you should be able to easily uninstall this patched version of node-red-dashboard and reinstall the original

  1. npm uninstall node-red-dashboard at which point the mp4frag nodes will complain about their missing peer dependencies

  2. npm install node-red-dashboard to get back the original

  3. restart server

yesterday , i uninstalling and reinstalling mp4frag and node-red-dashboard, and restart NR.
today I did this:
I deleted all the old mp4frag and ui_mp4frag nodes (socket.io v2) in my flow, i add new (v3), restart NR, and I still find some again :

image


i got the EIO=4, but not found socket.io.js version ?

Found this :
image

I think i wil desinstall and reinstal again.

1 Like

This is a simple France24 test :
image

[{"id":"86424745.4b9c48","type":"inject","z":"31914bf3.119024","name":"stop","props":[{"p":"payload"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payload":"http://f.m3u8","payloadType":"str","x":100,"y":400,"wires":[["33c56355.a3ac1c"]]},{"id":"33c56355.a3ac1c","type":"ui_button","z":"31914bf3.119024","name":"stop","group":"a90d6a68.8dc3b8","order":3,"width":1,"height":1,"passthru":true,"label":"","tooltip":"","color":"","bgcolor":"","icon":"stop","payload":"stop","payloadType":"str","topic":"","x":260,"y":400,"wires":[["b7321b3b.b98fb8"]]},{"id":"8779ad9.08e7e5","type":"ui_button","z":"31914bf3.119024","name":"france24","group":"a90d6a68.8dc3b8","order":4,"width":1,"height":1,"passthru":true,"label":"news","tooltip":"","color":"","bgcolor":"","icon":"","payload":"http://f24hls-i.akamaihd.net/hls/live/221192-b/F24_FR_LO_HLS/master_900.m3u8","payloadType":"str","topic":"","x":270,"y":430,"wires":[["b7321b3b.b98fb8"]]},{"id":"929c2d49.4cf99","type":"exec","z":"31914bf3.119024","command":"ffmpeg -i http://f24hls-i.akamaihd.net/hls/live/221147/F24_EN_HI_HLS/master_2000.m3u8 -c:v copy -f mp4  -movflags +frag_keyframe+empty_moov+default_base_moof pipe:1","addpay":false,"append":"","useSpawn":"true","timer":"","oldrc":false,"name":"France 24","x":440,"y":500,"wires":[["10d9625d.b6c35e"],[],["10d9625d.b6c35e"]]},{"id":"5ff09174.7d234","type":"inject","z":"31914bf3.119024","name":"Start stream","props":[{"p":"payload"}],"repeat":"","crontab":"","once":false,"onceDelay":"1","topic":"","payload":"true","payloadType":"bool","x":120,"y":480,"wires":[["51de2ba.1631ed4"]]},{"id":"660f8eb.53e927","type":"inject","z":"31914bf3.119024","name":"Stop stream","props":[{"p":"payload"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payload":"false","payloadType":"bool","x":120,"y":510,"wires":[["51de2ba.1631ed4"]]},{"id":"51de2ba.1631ed4","type":"switch","z":"31914bf3.119024","name":"","property":"payload","propertyType":"msg","rules":[{"t":"true"},{"t":"false"}],"checkall":"true","repair":false,"outputs":2,"x":271,"y":480,"wires":[["929c2d49.4cf99"],["33ee1e61.f21cf2"]]},{"id":"33ee1e61.f21cf2","type":"function","z":"31914bf3.119024","name":"stop","func":"msg = {\n    kill:'SIGHUP',\n    payload : 'SIGHUP'  \n}\n\nreturn msg;","outputs":1,"noerr":0,"initialize":"","finalize":"","x":270,"y":510,"wires":[["929c2d49.4cf99"]]},{"id":"10d9625d.b6c35e","type":"mp4frag","z":"31914bf3.119024","name":"france24","hlsPlaylistSize":4,"hlsPlaylistExtra":0,"basePath":"10d9625d.b6c35e","x":600,"y":500,"wires":[["4239fc28.bf8034"]]},{"id":"4239fc28.bf8034","type":"ui_mp4frag","z":"31914bf3.119024","name":"testv3","group":"a90d6a68.8dc3b8","order":8,"width":6,"height":4,"readyPoster":"","errorPoster":"","hlsJsConfig":"{\"liveDurationInfinity\":true,\"liveBackBufferLength\":5,\"maxBufferLength\":10,\"manifestLoadingTimeOut\":1000,\"manifestLoadingMaxRetry\":10,\"manifestLoadingRetryDelay\":500}","retry":true,"play":true,"unload":true,"threshold":0.5,"players":["socket.io","hls.js","hls","mp4"],"x":890,"y":500,"wires":[[]]},{"id":"b7321b3b.b98fb8","type":"ui_mp4frag","z":"31914bf3.119024","name":"streamv3","group":"a90d6a68.8dc3b8","order":9,"width":6,"height":4,"readyPoster":"","errorPoster":"","hlsJsConfig":"{\"liveDurationInfinity\":true,\"liveBackBufferLength\":5,\"maxBufferLength\":10,\"manifestLoadingTimeOut\":1000,\"manifestLoadingMaxRetry\":10,\"manifestLoadingRetryDelay\":500}","retry":true,"play":true,"unload":true,"threshold":0.5,"players":["socket.io","hls.js","hls","mp4"],"x":900,"y":430,"wires":[[]]},{"id":"aeb3f58a.db6308","type":"inject","z":"31914bf3.119024","name":"Start stream","props":[{"p":"payload"}],"repeat":"","crontab":"","once":false,"onceDelay":"1","topic":"","payload":"true","payloadType":"bool","x":120,"y":430,"wires":[["8779ad9.08e7e5"]]},{"id":"bc01d4e.4b1b728","type":"comment","z":"31914bf3.119024","name":"working","info":"","x":780,"y":430,"wires":[]},{"id":"ba6bddb3.69cfb","type":"comment","z":"31914bf3.119024","name":"NOT working","info":"","x":760,"y":500,"wires":[]},{"id":"a90d6a68.8dc3b8","type":"ui_group","name":"videoTest","tab":"250de740.57ee78","order":14,"disp":true,"width":"6","collapse":true},{"id":"250de740.57ee78","type":"ui_tab","name":"Dashboard","icon":"dashboard","order":1,"disabled":false,"hidden":false}]

The parameters i've posted concerne the RTSP IP camera (but not working).
reminder : i always got socket.io@2.3.0 in npm ls socket.io

1 Like

Your flow worked fine for me, maybe we should compare versions. I have now 2 RPi3B+ running the same without problem

I remember having exactly your problem when I made the first attempt. I suspected the "node-red-node-ui-table" node because I saw similar unmet peer dependency. After I uninstalled it, eventually re-installed Kevins sw, restarted node-red, maybe rebooted and then it worked

pi@raspberrypi:~/.node-red $ npm ls socket.io
node-red-project@0.0.1 /home/pi/.node-red
└─┬ node-red-dashboard@2.24.2-beta (github:kevinGodell/node-red-dashboard#7ba4a3c36f034960959c119c50fcf3b4fdd0d964)
  └── socket.io@3.0.3


EDIT: I use this for streaming the same, it makes a smoother flow I think

ffmpeg -re -i http://f24hls-i.akamaihd.net/hls/live/221147/F24_EN_HI_HLS/master_2000.m3u8 -c:v copy -f mp4  -movflags +rtphint+frag_every_frame+empty_moov+default_base_moof -min_frag_duration 500000 pipe:1

1 Like