As stated on the RAAR Import Recordings section, RAAR
is not responsible for the actual recording of the audio files. It simply
assumes that recordings are placed within directories defined by
IMPORT_DIRECTORIES
waiting for the RAAR Importer to pick them
up.
But don't panic :-) we've got you covered in case you don't have your own recording solution already in place.
The following sections describes a recording solution based on JACK, Rotter and some systemd service units, which plays nicely together with RAAR.
Rotter is a Recording of Transmission /
Audio Logger for JACK. It captures audio from
jackd
, encodes it in a specified format and creates a new recording file
every hour by default. This makes it ideal for using it together with RAAR.
In the following deployment walk-through rotter
will be configured to capture
the audio from the first two JACK input ports found, while storing the
recordings into the /var/lib/rotter/raar
directory in the lossless
FLAC format.
A separate recording-handler will move the finished recordings from the
/var/lib/rotter/raar
directory to a final RAAR import directory. It also
determines the recording duration with the help of
ffprobe
and adds it to the recording
file name in the ISO 8601 duration
format in seconds.
A final recording file will be named according to YYYY-MM-DDThhmmss±hhmm_PTsS.flac
(such as 2019-11-30T170000+0100_PT3600S.flac
).
Of course, the JACK configuration, audio codec and directory locations can be customized to meet the requirements of your environment.
Also note, that the deployment was tested on CentOS 7, but should work on other distributions as well (with some minor modifications).
There are pre-built binary packages for CentOS 7 available from Fedora EPEL (jack) and RaBe APEL (rotter) and Nux Dextop (ffprobe from ffmpeg), which can be installed as follows:
# Add Fedora EPEL repository
yum install epel-release
# Add RaBe APEL repository
curl -o /etc/yum.repos.d/home:radiorabe:audio.repo \
http://download.opensuse.org/repositories/home:/radiorabe:/audio/CentOS_7/home:radiorabe:audio.repo
# Add Nux Dextop repository
rpm -Uvh http://li.nux.ro/download/nux/dextop/el7/x86_64/nux-dextop-release-0-5.el7.nux.noarch.rpm
# Install rotter (which will also install "jack-audio-connection-kit" and
# "jack-audio-connection-kit-example-clients") as well as the ffprobe command
# from the ffmpeg package.
yum install rotter ffmpeg
Install the raar jackd systemd service instance override:
# Install the jackd@raar service instance unit override
mkdir "/etc/systemd/system/jackd@raar.service.d"
wget -O "/etc/systemd/system/jackd@raar.service.d/override.conf" \
https://raw.githubusercontent.com/radiorabe/raar/master/config/systemd/jackd%40raar.service.d/override.conf
# You might need to adapt the jackd service instance unit override to suite
# your environment
vi /etc/systemd/system/jackd@raar.service.d/override.conf
# Reload systemd manager configuration
systemctl daemon-reload
Install the raar rotter systemd service instance override:
# Install the rotter@raar service instance unit override
mkdir "/etc/systemd/system/rotter@raar.service.d"
wget -O "/etc/systemd/system/rotter@raar.service.d/override.conf" \
https://raw.githubusercontent.com/radiorabe/raar/master/config/systemd/rotter%40raar.service.d/override.conf
# You might need to adapt the rotter service instance unit override to suite
# your environment
vi /etc/systemd/system/rotter@raar.service.d/override.conf
# Reload systemd manager configuration
systemctl daemon-reload
You can now enable and start the raar@rotter.service
instance, which will
also trigger the start of the raar@jackd.service
instance.
# Enable and start the service unit instance
systemctl enable raar@rotter.service
systemctl start raar@rotter.service
# Check the status
systemctl status raar@rotter.service
systemctl status raar@jackd.service
# In case of problems, inspect the systemd journal
journalctl -u raar@rotter.service
journalctl -u raar@jackd.service
The recordings should appear in the /var/lib/rotter/raar
directory.
As a final step, install the RAAR Record Handler.
First, a dedicated system user and group will be created under which all
involved processes will run. The user and group is named rotter
(you might
need to adapt the supplementary groups, audio
and jackuser
, to match with
your distribution).
# Create a dedicated audio recording user which belongs to the audio and
# jackuser groups. The later is required in order to gain real-time priority
# see also /etc/security/limits.d/95-jack.conf
useradd --comment "rotter system user" \
--home-dir "/var/lib/rotter" \
--create-home \
--groups audio,jackuser \
--password '*' \
--system \
--shell /sbin/nologin \
--user-group \
rotter
In case you want to use an ALSA device (such as
an USB or PCI audio interface, or a virtual AoIP device) as your jackd
backend, you have to configure it beforehand. Afterwards test that you're able
to record from its capture device, with the help of arecord
:
# Capture 10 seconds via arecord directly from the first ALSA device as the
# rotter user
su -l -s /bin/bash \
-c 'arecord -D hw:0 -c 2 -d 10 -r 48000 -f S32_LE -v /tmp/test-arecord.wav' \
rotter
Keep in mind, that you will have to change the jack configuration later on, if
your device isn't available as hw:0
(refer to arecord -L
). Also note, that
you might have to adapt the sample format -f ...
option according to your
device's capabilities (refer to arecord -D hw:0 --dump-hw-params
).
If the recorded test file can be played as expected, continue with the next section.
Install jackd
(jack2) and the helper
tools
(example-clients)
from the packages provided by your distribution or compile it from source
(jack2 releases).
Allow headless operation of jackd
by allowing users of the rotter
group to
own the first audio device service (you might have to adapt
org.freedesktop.ReserveDevice1.Audio0
according to your device):
wget -O /etc/dbus-1/system.d/rotter.conf \
https://raw.githubusercontent.com/radiorabe/centos-rpm-rotter/master/dbus-rotter.conf
# Reload the D-Bus configuration
systemctl reload dbus
Install the jackd systemd service unit template and raar jackd systemd service instance override:
# Install the jackd system service unit template
wget -O "/etc/systemd/system/jackd@.service" \
https://raw.githubusercontent.com/radiorabe/centos-rpm-rotter/master/jackd%40.service
# Install the jackd@raar service instance unit override
mkdir "/etc/systemd/system/jackd@raar.service.d"
wget -O "/etc/systemd/system/jackd@raar.service.d/override.conf" \
https://raw.githubusercontent.com/radiorabe/raar/master/config/systemd/jackd%40raar.service.d/override.conf
# You might need to adapt the jackd service instance unit override to suite
# your environment
vi /etc/systemd/system/jackd@raar.service.d/override.conf
# Reload systemd manager configuration
systemctl daemon-reload
Install rotter
from the packages provided by your distribution or compile it
from source.
Install the rotter systemd service unit template and raar rotter systemd service instance override:
# Install the rotter system service unit template
wget -O "/etc/systemd/system/rotter@.service" \
https://raw.githubusercontent.com/radiorabe/centos-rpm-rotter/master/rotter%40.service
# Install the rotter@raar service instance unit override
mkdir "/etc/systemd/system/rotter@raar.service.d"
wget -O "/etc/systemd/system/rotter@raar.service.d/override.conf" \
https://raw.githubusercontent.com/radiorabe/raar/master/config/systemd/rotter%40raar.service.d/override.conf
# You might need to adapt the rotter service instance unit override to suite
# your environment
vi /etc/systemd/system/rotter@raar.service.d/override.conf
# Reload systemd manager configuration
systemctl daemon-reload
You can now enable and start the raar@rotter.service
instance, which will
also trigger the start of the raar@jackd.service
instance.
# Enable and start the service unit instance
systemctl enable raar@rotter.service
systemctl start raar@rotter.service
# Check the status
systemctl status raar@rotter.service
systemctl status raar@jackd.service
# In case of problems, inspect the systemd journal
journalctl -u raar@rotter.service
journalctl -u raar@jackd.service
The recordings should appear in the /var/lib/rotter/raar
directory:
ls -la /var/lib/rotter/raar
total 717844
drwxr-xr-x. 2 rotter rotter 4096 Feb 6 16:59 .
drwxr-xr-x. 3 rotter rotter 17 Feb 6 15:45 ..
-rw-r--r--. 1 rotter rotter 120309610 Feb 6 16:00 2018-02-06T154512+0100.flac
-rw-r--r--. 1 rotter rotter 230000737 Feb 6 16:28 2018-02-06T160000+0100.flac
-rw-r--r--. 1 rotter rotter 250600686 Feb 6 16:59 2018-02-06T162851+0100.flac
-rw-r--r--. 1 rotter rotter 127717296 Feb 6 17:16 2018-02-06T170000+0100.flac
The RAAR Record Handler will upload the finished
recordings from the /var/lib/rotter/raar
directory to an SFTP server, which
serves the RAAR import directory (IMPORT_DIRECTORIES
). The RAAR
Importer will pick up the final recordings from the SFTP upload
(import) directory.
The record handler also determines the recording duration with the help of
ffprobe
and adds it to the recording
file name in the ISO 8601 duration
format in seconds.
For example, a one hour (3600 seconds) rotter recording file
/var/lib/rotter/raar/2019-11-30T170000+0100.flac
will be renamed and upload to
sftp://user-01@archive.example.com/upload/2019-11-30T170000+0100_PT3600S.flac
Install ffmpeg
(required for
ffprobe
) from the packages provided by
your distribution or compile it from
source.
Create an SSH public/private key pair and ensure the the corresponding user is able to login via SFTP to the SFTP server:
su -l -s /bin/bash rotter
mkdir --mode=700 ~/.ssh
# Create the key pair with no passphrase
ssh-keygen -C "RAAR record handler key for ${USER}@$(hostname --fqdn)" \
-t ed25519 \
-N '' \
-f ~/.ssh/raar-record-handler.id_ed25519
# Exit the temporary rotter login shell
exit
# Display the public key
cat "/var/lib/rotter/.ssh/raar-record-handler.id_ed25519.pub"
Add the previously generated public key to the user's ~/.ssh/authorized_keys
file on the remote SFTP server.
Test the SFTP login (you have to adapt user-01@archive.example.com
):
su -c '/usr/bin/sftp -i /var/lib/rotter/.ssh/raar-record-handler.id_ed25519 user-01@archive.example.com' \
-s /bin/bash \
rotter
Install the RAAR Record Handler and its corresponding systemd service unit (raar-record-handler.service):
wget -O /usr/local/bin/raar-record-handler.sh \
https://raw.githubusercontent.com/radiorabe/raar/master/bin/raar-record-handler.sh
chmod 755 /usr/local/bin/raar-record-handler.sh
wget -O /etc/systemd/system/raar-record-handler.service \
https://raw.githubusercontent.com/radiorabe/raar/master/config/systemd/raar-record-handler.service
wget -O /etc/tmpfiles.d/rotter-raar.conf \
https://raw.githubusercontent.com/radiorabe/raar/master/config/systemd/tmpfiles.d/rotter-raar.conf
You have to adapt the SFTP destination, which defaults to
sftp://user-01@archive.example.com/upload
(the path must match with a
directory from IMPORT_DIRECTORIES
of the RAAR importer, in case the importer
runs on the same host):
systemctl edit raar-record-handler.service
[Service]
# SFTP upload destination
Environment="RAAR_RECORD_HANDLER_SFTP_DEST="sftp://user-01@archive.example.com/upload"
The path to the SSH key can also be overridden in case you have chosen a
different one (RAAR_RECORD_HANDLER_SSH_PRIVAT_KEY
).
Enable and start the raar-record-handler.service
:
# Enable and start the service unit
systemctl enable raar-record-handler.service
systemctl start raar-record-handler.service
# Check the status and logs
systemctl status raar-record-handler.service
journalctl -u raar-record-handler.service
At every hour, the service should upload the finished recordings to the SFTP destination.
The following commands and logs might be helpful for troubleshooting.
ALSA:
-
List all audio devices
arecord -l
-
List all PCMs
arecord -L
-
Dump the capabilities of a device
arecord -D <device> --dump-hw-params
-
List hardware parameters of an active capture device
cat /proc/asound/card0/pcm0c/sub0/hw_params
Jackd:
-
List Jack ports
su -l -s /bin/bash -c "jack_lsp -s raar -c -p" rotter
-
Status of the
jackd@raar.service
systemd service instance unitsystemctl status jackd@raar.service
-
Systemd journal of
jackd@raar.service
journalctl -u jackd@raar.service journalctl -u jackd@raar.service -f
Rotter:
-
Status of the
rotter@raar.service
systemd service instance unitsystemctl status rotter@raar.service
-
Systemd journal of
rotter@raar.service
journalctl -u rotter@raar.service journalctl -u rotter@raar.service -f
RAAR Record Handler:
-
Status of the
raar-record-handler.service
systemd service unitsystemctl status raar-record-handler.service
-
Systemd journal of
raar-record-handler.service
journalctl -u raar-record-handler.service journalctl -u raar-record-handler.service -f
-
Duration of recording file in seconds
ffprobe -i RECORDING-FILENAME \ -show_entries format="duration" \ -print_format csv="print_section=0" \ -v quiet