FFmpeg enables Viseron to read frames from cameras.
FFmpeg can be quite complex to work with, but in most cases the automatically generated commands will fit your needs.
Hardware acceleration is available on a wide variety of systems.
Configuration
Configuration example
ffmpeg:
camera:
camera_one:
name: Camera 1
host: 192.168.XX.X
port: 554
path: /Streaming/Channels/101/
username: !secret camera_one_user
password: !secret camera_one_pass
substream:
path: /Streaming/Channels/102/
stream_format: rtsp
port: 554
mjpeg_streams:
my_stream:
width: 100
height: 100
draw_objects: true
rotate: 45
mirror: true
objects:
draw_objects: true
draw_zones: true
draw_motion: true
draw_motion_mask: true
draw_object_mask: true
recorder:
idle_timeout: 5
frame_timeout: 10
Camera identifier. Valid characters are lowercase a-z, numbers and underscores.
Path to the camera stream, eg /Streaming/Channels/101/
.
Port for the camera stream,
IP or hostname of camera.
Name of the MJPEG stream. Used to build the URL to access the stream.
Valid characters are lowercase a-z, numbers and underscores.
Frame will be rezied to this width. Required if height is set.
Frame will be rezied to this height. Required if width is set.
If set, found objects will be drawn.
If set, detected motion will be drawn.
If set, configured motion masks will be drawn.
If set, configured object masks will be drawn.
If set, configured zones will be drawn.
Degrees to rotate the image. Positive/negative values rotate clockwise/counter clockwise respectively
If set, mirror the image horizontally.
URL to the still image. If this is omitted, the camera stream will be used to get the image.
Username for authentication.
Only applicable if url
is set.
Password for authentication.
Only applicable if url
is set.
Authentication method to use.
Only applicable if url
is set.
Number of seconds between refreshes of the still image in the frontend.
Width of the still image, if different from the stream width.
Height of the still image, if different from the stream height.
Tiers are used to move files between different storage locations. When a file reaches the max age or max size of a tier, it will be moved to the next tier. If the file is already in the last tier, it will be deleted.
Path to store files in. Cannot be /tmp
or /tmp/viseron
.
Poll the file system for new files. Much slower than non-polling but required for some file systems like NTFS mounts.
Move/delete files to the next tier when Viseron shuts down. Useful to not lose files when shutting down Viseron if using a RAM disk.
How often to check for files to move to the next tier.
Days between checks for files to move/delete.
Hours between checks for files to move/delete.
Minutes between checks for files to move/delete.
Seconds between checks for files to move/delete.
Retention rules for continuous recordings.
Minimum size of files to keep in this tier.
Min size in GB. Added together with min_mb
.
Min size in MB. Added together with min_gb
.
Maximum size of files to keep in this tier.
Max size in GB. Added together with max_mb
.
Max size in MB. Added together with max_gb
.
Maximum age of files to keep in this tier.
Minimum age of files to keep in this tier.
Retention rules for event recordings.
Minimum size of files to keep in this tier.
Min size in GB. Added together with min_mb
.
Min size in MB. Added together with min_gb
.
Maximum size of files to keep in this tier.
Max size in GB. Added together with max_mb
.
Max size in MB. Added together with max_gb
.
Maximum age of files to keep in this tier.
Minimum age of files to keep in this tier.
Snapshots are images taken when events are triggered or post processors finds anything. Snapshots will be taken for object detection, motion detection, and any post processor that scans the image, for example face and license plate recognition.
Default tiers for all domains, unless overridden in the domain configuration.
Tiers are used to move files between different storage locations. When a file reaches the max age or max size of a tier, it will be moved to the next tier. If the file is already in the last tier, it will be deleted.
Minimum size of files to keep in this tier.
Min size in GB. Added together with min_mb
.
Min size in MB. Added together with min_gb
.
Maximum size of files to keep in this tier.
Max size in GB. Added together with max_mb
.
Max size in MB. Added together with max_gb
.
Maximum age of files to keep in this tier.
Minimum age of files to keep in this tier.
Path to store files in. Cannot be /tmp
or /tmp/viseron
.
Poll the file system for new files. Much slower than non-polling but required for some file systems like NTFS mounts.
Move/delete files to the next tier when Viseron shuts down. Useful to not lose files when shutting down Viseron if using a RAM disk.
How often to check for files to move to the next tier.
Days between checks for files to move/delete.
Hours between checks for files to move/delete.
Minutes between checks for files to move/delete.
Seconds between checks for files to move/delete.
Override the default snapshot tiers for face recognition. If not set, the default tiers will be used.
Tiers are used to move files between different storage locations. When a file reaches the max age or max size of a tier, it will be moved to the next tier. If the file is already in the last tier, it will be deleted.
Minimum size of files to keep in this tier.
Min size in GB. Added together with min_mb
.
Min size in MB. Added together with min_gb
.
Maximum size of files to keep in this tier.
Max size in GB. Added together with max_mb
.
Max size in MB. Added together with max_gb
.
Maximum age of files to keep in this tier.
Minimum age of files to keep in this tier.
Path to store files in. Cannot be /tmp
or /tmp/viseron
.
Poll the file system for new files. Much slower than non-polling but required for some file systems like NTFS mounts.
Move/delete files to the next tier when Viseron shuts down. Useful to not lose files when shutting down Viseron if using a RAM disk.
How often to check for files to move to the next tier.
Days between checks for files to move/delete.
Hours between checks for files to move/delete.
Minutes between checks for files to move/delete.
Seconds between checks for files to move/delete.
Override the default snapshot tiers for object detection. If not set, the default tiers will be used.
Tiers are used to move files between different storage locations. When a file reaches the max age or max size of a tier, it will be moved to the next tier. If the file is already in the last tier, it will be deleted.
Minimum size of files to keep in this tier.
Min size in GB. Added together with min_mb
.
Min size in MB. Added together with min_gb
.
Maximum size of files to keep in this tier.
Max size in GB. Added together with max_mb
.
Max size in MB. Added together with max_gb
.
Maximum age of files to keep in this tier.
Minimum age of files to keep in this tier.
Path to store files in. Cannot be /tmp
or /tmp/viseron
.
Poll the file system for new files. Much slower than non-polling but required for some file systems like NTFS mounts.
Move/delete files to the next tier when Viseron shuts down. Useful to not lose files when shutting down Viseron if using a RAM disk.
How often to check for files to move to the next tier.
Days between checks for files to move/delete.
Hours between checks for files to move/delete.
Minutes between checks for files to move/delete.
Seconds between checks for files to move/delete.
Override the default snapshot tiers for license plate recognition. If not set, the default tiers will be used.
Tiers are used to move files between different storage locations. When a file reaches the max age or max size of a tier, it will be moved to the next tier. If the file is already in the last tier, it will be deleted.
Minimum size of files to keep in this tier.
Min size in GB. Added together with min_mb
.
Min size in MB. Added together with min_gb
.
Maximum size of files to keep in this tier.
Max size in GB. Added together with max_mb
.
Max size in MB. Added together with max_gb
.
Maximum age of files to keep in this tier.
Minimum age of files to keep in this tier.
Path to store files in. Cannot be /tmp
or /tmp/viseron
.
Poll the file system for new files. Much slower than non-polling but required for some file systems like NTFS mounts.
Move/delete files to the next tier when Viseron shuts down. Useful to not lose files when shutting down Viseron if using a RAM disk.
How often to check for files to move to the next tier.
Days between checks for files to move/delete.
Hours between checks for files to move/delete.
Minutes between checks for files to move/delete.
Seconds between checks for files to move/delete.
Override the default snapshot tiers for motion detection. If not set, the default tiers will be used.
Tiers are used to move files between different storage locations. When a file reaches the max age or max size of a tier, it will be moved to the next tier. If the file is already in the last tier, it will be deleted.
Minimum size of files to keep in this tier.
Min size in GB. Added together with min_mb
.
Min size in MB. Added together with min_gb
.
Maximum size of files to keep in this tier.
Max size in GB. Added together with max_mb
.
Max size in MB. Added together with max_gb
.
Maximum age of files to keep in this tier.
Minimum age of files to keep in this tier.
Path to store files in. Cannot be /tmp
or /tmp/viseron
.
Poll the file system for new files. Much slower than non-polling but required for some file systems like NTFS mounts.
Move/delete files to the next tier when Viseron shuts down. Useful to not lose files when shutting down Viseron if using a RAM disk.
How often to check for files to move to the next tier.
Days between checks for files to move/delete.
Hours between checks for files to move/delete.
Minutes between checks for files to move/delete.
Seconds between checks for files to move/delete.
A list of FFmpeg input arguments.
A list of FFmpeg hardware acceleration arguments.
Sets RTSP transport protocol. Change this if your camera doesn't support TCP.
A list of FFmpeg filter arguments. These filters are applied before Viseron receives the image for processing.
Only change this if the decoder you are using does not support nv12
, as nv12
is more efficient.
A timeout in seconds. If a frame has not been received in this time period FFmpeg will be restarted.
Lowest value: 1
Highest value: 60
A raw FFmpeg command to use instead of the generated one. This is useful if you want to use sources that Viseron does not support. This is an advanced option and should only be used if you know what you are doing.
See
Raw command for more information.
Username for the camera stream.
Password for the camera stream.
A valid list of FFmpeg arguments. These are applied before the input_args
.
Substream to perform image processing on. Very effective for reducing system load.
Path to the camera stream, eg /Streaming/Channels/101/
.
Port for the camera stream,
A list of FFmpeg input arguments.
A list of FFmpeg hardware acceleration arguments.
Sets RTSP transport protocol. Change this if your camera doesn't support TCP.
A list of FFmpeg filter arguments. These filters are applied before Viseron receives the image for processing.
Only change this if the decoder you are using does not support nv12
, as nv12
is more efficient.
A timeout in seconds. If a frame has not been received in this time period FFmpeg will be restarted.
Lowest value: 1
Highest value: 60
A raw FFmpeg command to use instead of the generated one. This is useful if you want to use sources that Viseron does not support. This is an advanced option and should only be used if you know what you are doing.
See
Raw command for more information.
Sets the loglevel for FFmpeg.
Should only be used in debugging purposes.
Valid values:
quiet
panic
fatal
error
warning
info
verbose
debug
trace
FFmpeg sometimes print errors that are not fatal, but are preventing Viseron from reading the stream.
If you get errors like
Error starting decoder pipe!
, see
recoverable errors below.
Sets the loglevel for FFprobe.
Should only be used in debugging purposes.
Valid values:
quiet
panic
fatal
error
warning
info
verbose
debug
trace
Number of seconds to record before a detected object.
Number of seconds to record after all events are over.
Maximum number of seconds to record.
DEPRECATED. Use the
storage component instead.
Number of days to save recordings before deletion.
A
strftime pattern for saved recordings.
Default pattern results in filenames like:
23:59:59.jpg
.
DEPRECATED. mp4
is the only supported extension.
The file extension used for recordings.
Options for the thumbnail created on start of a recording.
If
true
, the thumbnail that is created on start of recording is saved to
{camera_identifier}/latest_thumbnail.jpg
Full path depends on the
storage component tier configuration.
DEPRECATED. Thumbnails are stored with the same filename as the recording ID in the database, for example: 1.jpg, 2.jpg, 3.jpg etc.
A
strftime pattern for saved thumbnails.
Default pattern results in filenames like:
23:59:59.jpg
.
Retention rules for continuous recordings.
Minimum size of files to keep in this tier.
Min size in GB. Added together with min_mb
.
Min size in MB. Added together with min_gb
.
Maximum size of files to keep in this tier.
Max size in GB. Added together with max_mb
.
Max size in MB. Added together with max_gb
.
Maximum age of files to keep in this tier.
Minimum age of files to keep in this tier.
Retention rules for event recordings.
Minimum size of files to keep in this tier.
Min size in GB. Added together with min_mb
.
Min size in MB. Added together with min_gb
.
Maximum size of files to keep in this tier.
Max size in GB. Added together with max_mb
.
Max size in MB. Added together with max_gb
.
Maximum age of files to keep in this tier.
Minimum age of files to keep in this tier.
Concatenate fragments to an MP4 file for each event. WARNING: Will store both the fragments AND the MP4 file, using more storage space.
Enable continuous (24/7) recording. Has to be used in combination with
continuous
,
storage > tiers > continuous
or the
storage component.
FFmpeg encoder hardware acceleration arguments.
FFmpeg video encoder codec, eg h264_nvenc
.
FFmpeg audio encoder codec, eg aac
.
If your source has audio and you want to remove it, set this to null
.
A list of FFmpeg filter arguments. These filters are applied to the recorder videos.
A list of FFmpeg audio filter arguments. These filters are applied to the recorder videos.
FFmpeg encoder output arguments.
DEPRECATED. Config option 'segments_folder' is deprecated and will be removed in a future version.
What folder to store FFmpeg segments in. Segments are used to produce recordings so you should not need to change this.
Sets the FFmpeg loglevel for the recorder.
Should only be used in debugging purposes.
Valid values:
quiet
panic
fatal
error
warning
info
verbose
debug
trace
Only record the camera stream, do not process it. This is useful if you only want to record the stream and not do any processing like object detection.
Be aware that this will record the main stream, making substream redundant. Still images will not work either unless you have setup `still_image`.
Camera
A camera domain fetches frames from a camera source and distributes it to other domains in Viseron.
MJPEG Streams
Viseron will serve MJPEG streams of all cameras.
Dynamic streams
The dynamic streams are automatically created for each camera.
They utilize query parameters to control what is displayed on the stream.
Example URL: http://localhost:8888/<camera_identifier>/mjpeg-stream
Query parameters
A number of query parameters are available to instruct Viseron to resize the stream or draw different things on the image.
To utilize a parameter you append it to the URL after a ?
. To add multiple parameters you separate them with &
, like this:
http://localhost:8888/<camera name slug>/mjpeg-stream?<parameter1>=<value>&<parameter2>=<value>`
Expand to see all available query parameters
Parameter | Type | Description |
---|
width | int | frame will be resized to this width |
height | int | frame will be resized to this height |
draw_objects | any | If this query parameter is set to a truthy value (true , 1 etc), found objects will be drawn |
draw_object_mask | any | If this query parameter is set to a truthy value (true , 1 etc), configured object masks will be drawn |
draw_motion | any | If this query parameter is set to a truthy value (true , 1 etc), detected motion will be drawn |
draw_motion_mask | any | If this query parameter is set to a truthy value (true , 1 etc), configured motion masks will be drawn |
draw_zones | any | If this query parameter is set to a truthy value (true , 1 etc), configured zones will be drawn |
mirror | any | If this query parameter is set to a truthy value (true , 1 etc), mirror the image horizontally. |
rotate | any | Degrees to rotate the image. Positive/negative values rotate clockwise/counter clockwise respectively |
If you are going to have more than one consumer of the stream, it is better to configure your own static MJPEG streams.
This is because each dynamic stream will process their frames individually, duplicating the processing.
Static streams
The MJPEG streams work exactly as the dynamic streams, but instead of defining the query parameters in the URL, they are defined in the config.yaml
The benefit of using these predefined streams instead is that frame processing happens only once.
This means that you can theoretically have as many streams open as you want without increased load on your machine.
Config example
<component that provides camera domain>:
camera:
front_door:
...
mjpeg_streams:
my-big-front-door-stream:
width: 100
height: 100
draw_objects: true
my-small-front-door-stream:
width: 100
height: 100
draw_objects: true
draw_zones: true
draw_object_mask: true
The config example above would give you two streams, available at these endpoints:
http://localhost:8888/front_door/mjpeg-streams/my-big-front-door-stream
http://localhost:8888/front_door/mjpeg-streams/my-small-front-door-stream
Hardware acceleration
Viseron supports both hardware accelerated decoding and encoding.
This means your CPU will be offloaded and give you a significant performance increase.
Supported hardware:
- NVIDIA GPU
- VA-API on compatible Intel CPU's
- Raspberry Pi 3
- Raspberry Pi 4
- NVIDIA Jetson Nano
Viseron will detect what system you are running and will automagically utilize the hardware acceleration.
The Jetson Nano support is very limited in FFmpeg. If you have a Nano i suggest looking at the gstreamer
component instead.
Default FFmpeg decoder command
A default FFmpeg decoder command is generated.
To use hardware acceleration, the command varies a bit depending on the Docker container you use.
Commands
NVIDIA GPU support in the roflcoopter/amd64-cuda-viseron image:
ffmpeg -hide_banner -loglevel error -avoid_negative_ts make_zero -fflags nobuffer -flags low_delay -strict experimental -fflags +genpts -stimeout 5000000 -use_wallclock_as_timestamps 1 -vsync 0 -c:v h264_cuvid -rtsp_transport tcp -i rtsp://{username}:{password}@{host}:{port}{path} -f rawvideo -pix_fmt nv12 pipe:1
VAAPI support in the roflcoopter/viseron image:
ffmpeg -hide_banner -loglevel error -avoid_negative_ts make_zero -fflags nobuffer -flags low_delay -strict experimental -fflags +genpts -stimeout 5000000 -use_wallclock_as_timestamps 1 -vsync 0 -hwaccel vaapi -vaapi_device /dev/dri/renderD128 -rtsp_transport tcp -i rtsp://{username}:{password}@{host}:{port}{path} -f rawvideo -pix_fmt nv12 pipe:1
For RPi3 in the roflcoopter/rpi3-viseron image:
ffmpeg -hide_banner -loglevel error -avoid_negative_ts make_zero -fflags nobuffer -flags low_delay -strict experimental -fflags +genpts -stimeout 5000000 -use_wallclock_as_timestamps 1 -vsync 0 -c:v h264_mmal -rtsp_transport tcp -i rtsp://{username}:{password}@{host}:{port}{path} -f rawvideo -pix_fmt nv12 pipe:1
This means that you do not have to set hwaccel_args
unless you have a specific need to change the default command (say you need to change h264_cuvid
to hevc_cuvid
)
Custom FFmpeg decoder command
You can customize the generated command through the config.
It can be a bit hard to get this right so it is not recommended unless you know what you are doing.
The command is built up like this:
"ffmpeg" + global_args + input_args + hwaccel_args + codec + "-rtsp_transport tcp -i " + (stream url) + " -vf " + video_filters + output_args
Each entry in video_filters
are appended together, separated with a ,
.
Config example to rotate image 180 degrees
ffmpeg:
camera:
camera_1:
....
video_filters:
- transpose=2
- transpose=2
recorder:
video_filters:
- transpose=2
- transpose=2
And the resulting command looks like this:
ffmpeg -hide_banner -loglevel error -avoid_negative_ts make_zero -fflags nobuffer -flags low_delay -strict experimental -fflags +genpts -use_wallclock_as_timestamps 1 -vsync 0 -stimeout 5000000 -c:v h264_cuvid -rtsp_transport tcp -i rtsp://*****:*****@192.168.**.**:554/Streaming/Channels/101/ -vf transpose=2,transpose=2,fps=1.0 -f rawvideo -pix_fmt nv12 pipe:1
Viseron needs to know the width, height, FPS and audio/video codecs of your stream.
FFprobe is used on initialization to figure all this information out.
Some cameras dont play nice with this and fail to report some information.
To circumvent this you can manually specify the stream information.
FFprobe timeout
Sometimes FFprobe fails to connect to the stream and times out.
If this is a recurring issue you should specify all of width
, height
, fps
, codec
and audio_codec
manually.
Viseron will then not need to call FFprobe and startup will be significantly faster.
Recoverable Errors
Sometimes FFmpeg prints errors which are not fatal, such as [h264 @ 0x55b1e115d400] error while decoding MB 0 12, bytestream 114567
.
Viseron always performs a sanity check on the FFmpeg decoder command with -loglevel fatal
.
If Viseron gets stuck on an error that you believe is not fatal, you can add a subset of that error to ffmpeg_recoverable_errors
.
So to ignore the error above you would add this to your configuration:
ffmpeg_recoverable_errors:
- error while decoding MB
Recorder
FFmpeg segments are used to handle recordings.
FFmpeg will write small 5 second segments of the stream to disk.
The reason for using segments instead of just starting the recorder on an event, is to support the lookback
feature which makes it possible to record before an event actually happened.
It also makes it possible to have continuous recordings.
Store video segments in memory
To place the video segments in memory instead of writing to disk, you can mount a tmpfs disk in the container.
This will use more memory but reduce the load on your harddrives.
Example tmpfs configuration
Example Docker command
docker run --rm \
-v {segments path}:/segments \
-v {snapshots path}:/snapshots \
-v {thumbnails path}:/thumbnails \
-v {event clips path}:/event_clips \
-v {config path}:/config \
-v /etc/localtime:/etc/localtime:ro \
-p 8888:8888 \
--tmpfs /tmp \
--name viseron \
--shm-size=1024mb \
roflcoopter/viseron:latest
Example docker-compose
version: "2.4"
services:
viseron:
image: roflcoopter/viseron:latest
container_name: viseron
shm_size: "1024mb"
volumes:
- {segments path}:/segments
- {snapshots path}:/snapshots
- {thumbnails path}:/thumbnails
- {event clips path}:/event_clips
- {config path}:/config
- /etc/localtime:/etc/localtime:ro
ports:
- 8888:8888
tmpfs:
- /tmp
/config/config.yaml
storage:
recorder:
tiers:
- path: /tmp/tier1
move_on_shutdown: true
events:
max_size:
mb: 50
- path: /config/tier2
events:
max_size:
gb: 50
Substream
Using the substream is a great way to reduce the system load from FFmpeg.
When configured, two FFmpeg processes will spawn:
- One that reads the main stream and creates segments for recordings. Codec
-c:v copy
is used so practically no resources are used.
- One that reads the substream and pipes frames to Viseron for motion/object detection.
To really benefit from this you should reduce the framerate of the substream to match the lowest fps set for either motion or object detection.
It is also a good idea to change the resolution to something lower than the main stream.
Rotating video
If you rotate your camera 90 or 180 degrees, you can rotate the video in Viseron to match.
To do this you can use the video_filters
option in the config.
If you are rotating the video 90 degrees, you need to tell Viseron the width and height of the video, which should be the opposite of the cameras real resolution.
If you have a camera with 1920x1080 resolution, you need to set width: 1080
and height: 1920
in the config.
Config to rotate 90 degrees clockwise
/config/config.yaml
ffmpeg:
camera:
camera_one:
name: Camera 1
host: 192.168.XX.X
port: 554
path: /Streaming/Channels/101/
username: !secret camera_one_user
password: !secret camera_one_pass
video_filters:
- transpose=1
width: 1080
height: 1920
recorder:
idle_timeout: 5
video_filters:
- transpose=1
Adding timestamp to video
To add a timestamp to the video you can use the drawtext
filter in FFmpeg.
This filter is quite complex and you can read more about it here.
To apply the filter you need to add it to the video_filters
option in the config.
Config to add a timestamp to the video
/config/config.yaml
ffmpeg:
camera:
camera_one:
name: Camera 1
host: 192.168.XX.X
port: 554
path: /Streaming/Channels/101/
username: !secret camera_one_user
password: !secret camera_one_pass
video_filters:
- drawtext=text='%{localtime}':x=(w-tw):y=h-(2*lh):fontcolor=white:box=1:boxcolor=0x00000000@1:fontsize=20
Raw command
If you want to use a custom FFmpeg command, you can do so by specifying the raw_command
option.
Viseron needs to be able to read frames, so you must make sure to output frames to stdout.
By default this is done using the pipe:1
as the output file.
You also need to make sure that you are outputting frames in the raw format (-f rawvideo
) that Viseron expects.
The third consideration is that small segments need to be saved to disk for processing by the recorder.
This is done by using the format -f segment
.
To get the hang of it you can start by using the default command and then modify it to your liking.
Raw command with substream
If you specify substream
, Viseron will use the substream for motion/object detection, which means that the raw command for the substream has to output to pipe:1
.
The main stream raw command will be used for recordings, so it has to output segments using -f segment
.
Example using both main and substream
/config/config.yaml
ffmpeg:
camera:
camera_one:
name: Camera 1
host: 192.168.XX.X
port: 554
path: /onvif_camera/profile.0
username: !secret camera_one_user
password: !secret camera_one_pass
width: 1920
height: 1080
fps: 30
substream:
port: 554
path: /onvif_camera/profile.1
width: 1920
height: 1080
fps: 1
raw_command: |
ffmpeg -rtsp_transport tcp -i rtsp://user:pass@192.168.XX.X:554/onvif_camera/profile.1 -vf fps=1.0 -f rawvideo -pix_fmt nv12 pipe:1
raw_command: |
ffmpeg -rtsp_transport tcp -i rtsp://user:pass@192.168.XX.X:554/onvif_camera/profile.0 -f segment -segment_time 5 -reset_timestamps 1 -strftime 1 -c:v copy /segments/camera_one/%Y%m%d%H%M%S.mp4
Most of the configuration options are ignored when using raw_command
.
If you create a command that works well for your particular hardware, please share it with the community!
Troubleshooting
To enable debug logging for
ffmpeg
, add the following to your
config.yaml
/config/config.yaml
logger:
logs:
viseron.components.ffmpeg: debug