the ftyp error is when the mp4frag node receives Buffer, but not the correct type. Most likely you changed a setting in mp4frag node, causing it to reset its internal buffer, while still feeding the mp4 buffer from the exec node or ffmpeg-spawn node. mp4 is tricky because it is not like a stream of individual jpegs, but a slightly more complicated file type and the buffer has to be received in the correct order. It gives out an error message each time it is given the incorrect buffer, thus it was fed probably 100's of pieces, none of which it could use. The mp4frag node was in its correct state, but the ffmpeg streaming mp4 buffer must be restarted. Thats why I show the example of using the return code from exec to trigger a reset so that mp4frag can get ready for when you start ffmpeg again. I get that same error too because I forget to turn off ffmpeg before tweaking the mp4frag settings and if node-red is not set to restart the entire flow, then errorrrrrrrrs... That debug to console message will eventually go away before the release. deploy -> modified flows
might help avoid this issue when tweaking settings.
2nd thought on that is that I might have to output the error so that it can be handled and used to restart the ffmpeg process. Although, that error should probably never happen on its own.
Thats a tricky thing to answer. Only 1 mp4 should be created each time a start command is given to mp4frag. When the mp4 gets output, the sinlge video arrives in many many pieces.
Please try to following flow (after tweaking ffmpeg to work with your camera source or use whats there) and see if you can create mp4 videos. delete what you dont need, but look closely at the mp4frag node and how it can output mp4 and remastered with ffmpeg to fix timestamps or saved as-is. I was able to override the default limits in settings.js and create longer videos.
[{"id":"93d74c4e.4c8fe","type":"ffmpeg-spawn","z":"5967c855.68b978","name":"","outputs":6,"migrate":2e-9,"cmdPath":"","cmdArgs":"[\"-version\"]","cmdOutputs":5,"killSignal":"SIGTERM","msgOutput":"split","x":340,"y":380,"wires":[["96b432b8.72f38","8715a99e.626858","c5674070.e26ec"],["96b432b8.72f38"],["a03a1b22.1f27a8"],["22984340.c40eac"],["45912098.31d65"],[]]},{"id":"96b432b8.72f38","type":"mp4frag","z":"5967c855.68b978","name":"","migrate":1e-9,"hlsPlaylistSize":"20","hlsPlaylistExtra":"10","basePath":"abc","x":640,"y":280,"wires":[["379420d.31038e"],["d4600315.dbc7d","97c44c17.d56ce"]]},{"id":"143a363a.17fc7a","type":"inject","z":"5967c855.68b978","name":"stop default","props":[{"p":"action","v":"{\"command\":\"stop\"}","vt":"json"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payloadType":"str","x":121,"y":453,"wires":[["93d74c4e.4c8fe"]]},{"id":"e90ee3ed.da535","type":"delay","z":"5967c855.68b978","name":"delay","pauseType":"delayv","timeout":"1","timeoutUnits":"milliseconds","rate":"1","nbRateUnits":"1","rateUnits":"second","randomFirst":"1","randomLast":"5","randomUnits":"seconds","drop":false,"x":450,"y":55,"wires":[["93d74c4e.4c8fe"]]},{"id":"c5674070.e26ec","type":"function","z":"5967c855.68b978","name":"restart","func":"const { status, code, signal, killed } = msg.payload;\n\n\nif (status === 'close' && killed === false) {\n return { action: { command: 'start' }, delay: 5000 };\n}\n\nreturn;","outputs":1,"noerr":0,"initialize":"","finalize":"","x":330,"y":55,"wires":[["e90ee3ed.da535"]]},{"id":"ccf3b2e6.7f78f","type":"inject","z":"5967c855.68b978","name":"stop SIGKILL","props":[{"p":"action","v":"{\"command\":\"stop\",\"signal\":\"SIGKILL\"}","vt":"json"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","x":121,"y":561,"wires":[["93d74c4e.4c8fe"]]},{"id":"2db4e64d.d4022a","type":"inject","z":"5967c855.68b978","name":"stop SIGTERM","props":[{"p":"action","v":"{\"command\":\"stop\",\"signal\":\"SIGTERM\"}","vt":"json"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payloadType":"str","x":131,"y":597,"wires":[["93d74c4e.4c8fe"]]},{"id":"1d5155f9.0f929a","type":"debug","z":"5967c855.68b978","name":"","active":true,"tosidebar":true,"console":false,"tostatus":false,"complete":"true","targetType":"full","statusVal":"","statusType":"auto","x":1339,"y":400,"wires":[]},{"id":"a03a1b22.1f27a8","type":"function","z":"5967c855.68b978","name":"errors","func":"const { payload } = msg;\n\nreturn { payload: payload.toString() };","outputs":1,"noerr":0,"initialize":"","finalize":"","x":1219,"y":400,"wires":[["1d5155f9.0f929a"]]},{"id":"22984340.c40eac","type":"function","z":"5967c855.68b978","name":"progress","func":"const props = msg.payload.toString().split('\\n');\n\nconst progress = {};\n\nprops.forEach(item => {\n \n const [name, value] = item.split('=');\n \n if (name && value) {\n \n progress[name] = value;\n\n }\n \n});\n\nconst color = progress['progress'] === 'continue' ? 'green' : 'red';\n\nconst message = `fps: ${progress['fps']}, bitrate: ${progress['bitrate']}`;\n\nnode.status({ fill: color, shape: 'dot', text: message });\n\nreturn { payload: progress };","outputs":1,"noerr":0,"initialize":"","finalize":"","x":1210,"y":498,"wires":[["21bb6347.11389c"]]},{"id":"21bb6347.11389c","type":"debug","z":"5967c855.68b978","name":"","active":false,"tosidebar":true,"console":false,"tostatus":false,"complete":"true","targetType":"full","statusVal":"","statusType":"auto","x":1340,"y":498,"wires":[]},{"id":"7f035cf8.c1f6d4","type":"function","z":"5967c855.68b978","name":"filename","func":"const { payload } = msg;\n\nif (Buffer.isBuffer(payload)) {\n\n msg.filename = context.get('filename');\n \n return msg;\n}\n\nconst { status } = payload;\n\nif (status === 'spawn') {\n\n context.set('filename', `videos/abc/p/${Date.now()}.mp4`);\n\n \n} else if (status === 'close') {\n \n context.set('filename', undefined);\n\n}\n\nreturn;","outputs":1,"noerr":0,"initialize":"// Code added here will be run once\n// whenever the node is deployed.\n\ncontext.set('filename', undefined);","finalize":"// Code added here will be run when the\n// node is being stopped or re-deployed.\n\ncontext.set('filename', undefined);","x":1084,"y":198,"wires":[["fb03fea0.c6e59"]]},{"id":"d4600315.dbc7d","type":"ffmpeg-spawn","z":"5967c855.68b978","name":"","outputs":2,"migrate":2e-9,"cmdPath":"","cmdArgs":"[\"-f\",\"mp4\",\"-i\",\"pipe:0\",\"-c:v\",\"copy\",\"-c:a\",\"copy\",\"-f\",\"mp4\",\"-movflags\",\"+faststart+empty_moov\",\"pipe:1\"]","cmdOutputs":1,"killSignal":"SIGTERM","msgOutput":"split","x":923,"y":198,"wires":[["7f035cf8.c1f6d4"],["7f035cf8.c1f6d4"]]},{"id":"fb03fea0.c6e59","type":"file","z":"5967c855.68b978","name":"","filename":"","appendNewline":false,"createDir":true,"overwriteFile":"false","encoding":"none","x":1214,"y":198,"wires":[["9c69a6cf.45c9c8"]]},{"id":"1b3c5f.f19183a1","type":"inject","z":"5967c855.68b978","name":"write start default","props":[{"p":"action","v":"{\"subject\":\"write\",\"command\":\"start\",\"keyframe\":-1,\"timeLimit\":500000,\"sizeLimit\":250000000}","vt":"json"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","x":131,"y":59,"wires":[["96b432b8.72f38"]]},{"id":"9c69a6cf.45c9c8","type":"debug","z":"5967c855.68b978","name":"","active":false,"tosidebar":true,"console":false,"tostatus":false,"complete":"true","targetType":"full","statusVal":"","statusType":"auto","x":1334,"y":198,"wires":[]},{"id":"97c44c17.d56ce","type":"function","z":"5967c855.68b978","name":"filename","func":"const { payload, action } = msg;\n\nif (Buffer.isBuffer(payload)) {\n\n msg.filename = context.get('filename');\n \n return msg;\n}\n\nif (typeof action === 'object') {\n const { command } = action;\n \n if (command === 'start') {\n \n context.set('filename', `videos/abc/r/${Date.now()}.mp4`);\n \n } else if (command === 'stop') {\n \n context.set('filename', undefined);\n \n }\n}\n\nreturn;","outputs":1,"noerr":0,"initialize":"// Code added here will be run once\n// whenever the node is deployed.\n\ncontext.set('filename', undefined);","finalize":"// Code added here will be run when the\n// node is being stopped or re-deployed.\n\ncontext.set('filename', undefined);","x":1085,"y":298,"wires":[["9c6dad2f.e4165"]]},{"id":"9c6dad2f.e4165","type":"file","z":"5967c855.68b978","name":"","filename":"","appendNewline":false,"createDir":true,"overwriteFile":"false","encoding":"none","x":1215,"y":298,"wires":[["92473934.4b74b8"]]},{"id":"92473934.4b74b8","type":"debug","z":"5967c855.68b978","name":"","active":false,"tosidebar":true,"console":false,"tostatus":false,"complete":"true","targetType":"full","statusVal":"","statusType":"auto","x":1335,"y":298,"wires":[]},{"id":"45912098.31d65","type":"pipe2jpeg","z":"5967c855.68b978","name":"","x":934,"y":595,"wires":[["e382fb4.ce83a08"]]},{"id":"e382fb4.ce83a08","type":"image","z":"5967c855.68b978","name":"jpeg preview","width":"200","data":"payload","dataType":"msg","thumbnail":false,"active":true,"pass":false,"outputs":0,"x":1084,"y":595,"wires":[]},{"id":"e27f974a.0ef868","type":"comment","z":"5967c855.68b978","name":"start args","info":"","x":111,"y":106,"wires":[]},{"id":"36953f1b.fdbac","type":"comment","z":"5967c855.68b978","name":"- - - - - daemonize - - - - -","info":"","x":390,"y":20,"wires":[]},{"id":"d9f21b53.703b28","type":"comment","z":"5967c855.68b978","name":"- - - - - - - - - - jpegs - - - - - - - - - -","info":"","x":1013,"y":560,"wires":[]},{"id":"8b84ea34.3465f8","type":"comment","z":"5967c855.68b978","name":"- - - - - progress logs - - - - -","info":"","x":1269,"y":463,"wires":[]},{"id":"e1ae8181.29ed6","type":"comment","z":"5967c855.68b978","name":"- - - - - error logs - - - - -","info":"","x":1277,"y":365,"wires":[]},{"id":"4220195.ce45ae8","type":"comment","z":"5967c855.68b978","name":"- - - - - - - - - save raw mp4 files - - - - - - - - - -","info":"","x":1204,"y":263,"wires":[]},{"id":"1640592.c4917a7","type":"comment","z":"5967c855.68b978","name":"- - - - - - - - - - - - - - - - - save processed mp4 files - - - - - - - - - - - - - - - - - ","info":"","x":1113,"y":163,"wires":[]},{"id":"ec9153b3.c3be6","type":"comment","z":"5967c855.68b978","name":"stop ffmpeg","info":"","x":121,"y":417,"wires":[]},{"id":"2e0fa25d.f5878e","type":"comment","z":"5967c855.68b978","name":"- output mp4 -","info":"","x":130,"y":24,"wires":[]},{"id":"fd12ad4d.89379","type":"comment","z":"5967c855.68b978","name":"- view mp4 -","info":"","x":650,"y":140,"wires":[]},{"id":"42cda3a1.8f558c","type":"inject","z":"5967c855.68b978","name":"start args","props":[{"p":"action","v":"{\"command\":\"start\",\"args\":[\"-loglevel\",\"fatal\",\"-nostats\",\"-f\",\"hls\",\"-http_multiple\",\"1\",\"-re\",\"-i\",\"https://weather-lh.akamaihd.net/i/twc_1@92006/index_1200_av-p.m3u8?sd=10&rebase=on\",\"-c:v\",\"copy\",\"-c:a\",\"aac\",\"-f\",\"mp4\",\"-movflags\",\"+frag_keyframe+empty_moov+default_base_moof\",\"pipe:1\",\"-progress\",\"pipe:3\",\"-f\",\"image2pipe\",\"-vf\",\"select='eq(pict_type,PICT_TYPE_I)',scale=trunc(iw/4):-2\",\"-vsync\",\"vfr\",\"pipe:4\"]}","vt":"json"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payloadType":"str","x":112,"y":141,"wires":[["93d74c4e.4c8fe"]]},{"id":"6b35f3b5.48ffcc","type":"inject","z":"5967c855.68b978","name":"restart args","props":[{"p":"action","v":"{\"command\":\"restart\",\"args\":[\"-loglevel\",\"fatal\",\"-nostats\",\"-f\",\"hls\",\"-http_multiple\",\"1\",\"-re\",\"-i\",\"https://dcunilive30-lh.akamaihd.net/i/dclive_1@535229/master.m3u8\",\"-c:v\",\"copy\",\"-c:a\",\"aac\",\"-f\",\"mp4\",\"-movflags\",\"+frag_keyframe+empty_moov+default_base_moof\",\"pipe:1\",\"-progress\",\"pipe:3\",\"-f\",\"image2pipe\",\"-vf\",\"select='eq(pict_type,PICT_TYPE_I)',scale=trunc(iw/4):-2\",\"-vsync\",\"vfr\",\"pipe:4\"]}","vt":"json"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payloadType":"str","x":121,"y":277,"wires":[["93d74c4e.4c8fe"]]},{"id":"4ebc8cba.dedf34","type":"comment","z":"5967c855.68b978","name":"restart args","info":"","x":121,"y":242,"wires":[]},{"id":"9c2eceaf.c223b","type":"inject","z":"5967c855.68b978","name":"restart args","props":[{"p":"action","v":"{\"command\":\"restart\",\"args\":[\"-loglevel\",\"error\",\"-nostats\",\"-f\",\"hls\",\"-http_multiple\",\"1\",\"-re\",\"-i\",\"https://travelxp-travelxp-1-au.samsung.wurl.com/manifest/playlist.m3u8\",\"-c:v\",\"copy\",\"-c:a\",\"aac\",\"-f\",\"mp4\",\"-movflags\",\"+frag_keyframe+empty_moov+default_base_moof\",\"pipe:1\",\"-progress\",\"pipe:3\",\"-f\",\"image2pipe\",\"-vf\",\"select='eq(pict_type,PICT_TYPE_I)',scale=trunc(iw/4):-2\",\"-vsync\",\"vfr\",\"pipe:4\"]}","vt":"json"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payloadType":"str","x":121,"y":313,"wires":[["93d74c4e.4c8fe"]]},{"id":"ac4cc611.cee8f8","type":"inject","z":"5967c855.68b978","name":"start args","props":[{"p":"action","v":"{\"command\":\"start\",\"args\":[\"-loglevel\",\"fatal\",\"-nostats\",\"-f\",\"hls\",\"-http_multiple\",\"1\",\"-re\",\"-c:v\",\"h264_mmal\",\"-i\",\"https://weather-lh.akamaihd.net/i/twc_1@92006/index_1200_av-p.m3u8?sd=10&rebase=on\",\"-c:v\",\"copy\",\"-c:a\",\"aac\",\"-f\",\"mp4\",\"-movflags\",\"+frag_keyframe+empty_moov+default_base_moof\",\"pipe:1\",\"-progress\",\"pipe:3\",\"-f\",\"image2pipe\",\"-vf\",\"fps=fps=2,scale=trunc(iw/4):-2\",\"-vsync\",\"vfr\",\"pipe:4\"]}","vt":"json"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","payloadType":"str","x":112,"y":177,"wires":[["93d74c4e.4c8fe"]]},{"id":"76df19c4.773f28","type":"exec","z":"5967c855.68b978","command":"top -b -d 5 -p","addpay":true,"append":"","useSpawn":"true","timer":"","oldrc":false,"name":"top -b -d 5 -p <pid>","x":844,"y":78,"wires":[["f0d2c43b.fe4c78"],[],[]]},{"id":"f0d2c43b.fe4c78","type":"function","z":"5967c855.68b978","name":"%CPU, %MEM","func":"const { payload } = msg;\n\nif (typeof payload === 'string') {\n \n const lines = payload.toString().trim().split(/[\\n]+/);\n \n if (lines.length >= 2) {\n \n const labels = lines[lines.length - 2].trim().split(/[\\s]+/);\n\n const values = lines[lines.length - 1].trim().split(/[\\s]+/);\n \n const payload = {};\n \n for (let i = 0; i < labels.length; ++i) {\n payload[labels[i]] = values[i] || '0.0';\n }\n\n const message = `%CPU ${payload['%CPU']}, %MEM ${payload['%MEM']}`;\n\n node.status({ fill: 'green', shape: 'dot', text: message });\n\n return { payload };\n }\n\n}\n\nnode.status({});\n\nreturn null;","outputs":1,"noerr":0,"initialize":"","finalize":"","x":1045,"y":70,"wires":[["b933f67e.c39d78"]]},{"id":"b933f67e.c39d78","type":"debug","z":"5967c855.68b978","name":"","active":false,"tosidebar":true,"console":false,"tostatus":false,"complete":"true","targetType":"full","statusVal":"","statusType":"auto","x":1197,"y":70,"wires":[]},{"id":"8715a99e.626858","type":"function","z":"5967c855.68b978","name":"status pid","func":"const { payload = {} } = msg;\n\nconst { status, pid } = payload;\n\nconst timeout = context.get('timeout');\n\nclearTimeout(timeout);\n\nif (status === 'spawn') {\n \n const timeout = setTimeout(()=> node.send({ payload: pid }), 100);\n \n context.set('timeout', timeout);\n \n} else if (status === 'close') {\n \n return { payload: 'kill', kill: 'SIGTERM'};\n \n} else {\n \n return null;\n}","outputs":1,"noerr":0,"initialize":"// Code added here will be run once\n// whenever the node is deployed.\n\ncontext.set('timeout', undefined);","finalize":"// Code added here will be run when the\n// node is being stopped or re-deployed.\n\nconst timeout = context.get('timeout');\n\nclearTimeout(timeout);\n\ncontext.set('timeout', undefined);","x":664,"y":74,"wires":[["76df19c4.773f28"]]},{"id":"379420d.31038e","type":"ui_mp4frag","z":"5967c855.68b978","d":true,"name":"","group":"","order":1,"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":651,"y":175,"wires":[[]]},{"id":"f4c762bc.e407d","type":"comment","z":"5967c855.68b978","name":"- - - - - - - - - - - - - - - - - - - - - - use top to get cpu and mem - - - - - - - - - - - - - - - - - - - - - -","info":"","x":924,"y":31,"wires":[]},{"id":"c7c78a8d.180f48","type":"inject","z":"5967c855.68b978","name":"stop SIGINT","props":[{"p":"action","v":"{\"command\":\"stop\",\"signal\":\"SIGINT\"}","vt":"json"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","x":121,"y":525,"wires":[["93d74c4e.4c8fe"]]},{"id":"781251e2.1e719","type":"inject","z":"5967c855.68b978","name":"stop SIGHUP","props":[{"p":"action","v":"{\"command\":\"stop\",\"signal\":\"SIGHUP\"}","vt":"json"}],"repeat":"","crontab":"","once":false,"onceDelay":0.1,"topic":"","x":121,"y":489,"wires":[["93d74c4e.4c8fe"]]}]
When you say continuously, do you mean 1 endless video that may be 24 hours durations, or multiple videos made back to back 24/7? i am thinking you want to have continous recording that never stops, but broken into invidual videos that are possibly a couple minutes duration. If that is that case, ffmpeg can already do that without needing any complicated mp4frag nodes for that.