跳转至内容

Shairport Sync

来自 ArchWiki

Shairport Sync 是一个 AirPlay 音频播放器 — 它可以播放从 iTunes、iOS 设备以及 ForkedDaapd 等第三方 AirPlay 源流式传输的音频。由 Shairport Sync 驱动的设备所播放的音频会与源保持同步,因此也能与播放相同源的其他类似设备保持同步。这样,就能轻松实现多房间同步音频。

Shairport Sync 不支持 AirPlay 视频或照片流式传输。

Shairport Sync 是原始 Shairport 的一个分支,后者基于对 Apple 在其 AirPort Express 中使用的密钥进行逆向工程。请注意,此功能可能会被 Apple 酌情移除。

安装

安装 shairport-sync 包。

注意 Shairport Sync 要求 Avahi 守护进程正在运行。您可以使用 systemd 启动/启用 avahi-daemon.service

配置

配置文件位于 /etc/shairport-sync.conf。它包含有用的注释和配置提示。更多文档可在 README 文件中找到。

音频后端

Shairport Sync 与 PulseAudio 配合良好,虽然其计时信息的准确性不如 ALSA 或 sndio,但移除或禁用 PulseAudio 通常不切实际。在这种情况下,可以使用 pa 后端。[1]

如果您想更改后端,请检查输出设备列表,例如使用 alsa-utils 中的工具,并查看原始音频设备,例如:

$ aplay -L
...
sysdefault:CARD=PCH
    HDA Intel PCH, ALC269VC Analog
    Default Audio Device
...

然后添加设备名称

/etc/shairport-sync.conf
// These are parameters for the "alsa" audio back end.
// For this section to be operative, Shairport Sync must be built with the following configuration flag:
// --with-alsa
alsa =
{
    output_device = "sysdefault";
}

系统服务

启动

启动/启用 shairport-sync.service

守护进程设置

如果您想将 shairport-sync 作为守护进程运行,您需要在 /run 目录中创建一个文件夹,该目录在 Arch Linux 中默认是 tempfs。要使文件夹在启动时自动创建,请创建一个 tempfiles 配置文件,例如:

/usr/lib/tmpfiles.d/shairport-sync.conf
d /run/shairport-sync 0755 username group

现在您可以使用 shairport-sync -d 将 shairport-sync 作为守护进程运行,并使用 shairport-sync -k 来杀死守护进程。

用户服务

根据 作者 的说法,带有默认 PulseAudio 配置的 PulseAudio 后端只能作为 用户服务 运行。截至 2022-01-27,它似乎可以直接作为系统服务与 pulseaudio (pipewire-pulse) 一起工作而无需修改,不需要用户服务。

要将 shairport-sync 作为用户守护进程运行,您可以将其添加到桌面环境的自动启动中,或者 启用 shairport-sync.service 作为 用户单元

接下来,编辑 shairport-sync.service 并注释掉以下行:

[Unit]
...
#Requires=avahi-daemon.service
#After=avahi-daemon.service
...
[Service]
...
#User=shairport-sync
#Group=shairport-sync
...

现在,您可以 启用/启动 shairport-sync.service 作为用户

要获取日志,请使用 journal 或检查 单元状态