debian 12 + kde 使用 pipewire 替代 PulseAudio

Libitum發表於2024-07-29

背景

這篇部落格中提到,我透過安裝安裝 pipewire 的方式,解決了 debian 12 + kde + wayland 下飛書的螢幕共享問題。

在此之後,透過飛書開會倒是一切正常。只不過在會議時,當螢幕共享的時候對方偶爾能聽到自己的迴音,如果我自己 mute 則正常。神奇的是,我用耳機的時候也會這樣,此時聲音不太可能進入到麥克風中。

之前一直懷疑是裝置的設定問題或者飛書的相容性問題。直到前兩天突然在想,有沒有可能和 pipewire 相關?

什麼是 Pipewire?

從官網資訊看,Pipewire 的目標是改善 Linux 下的音影片處理,提供了一個低延時的、基於圖的音影片處理引擎,可用以替代 PulseAudio 和 JACK。

PipeWire is a project that aims to greatly improve handling of audio and video under Linux. It provides a low-latency, graph-based processing engine on top of audio and video devices that can be used to support the use cases currently handled by both PulseAudio and JACK. PipeWire was designed with a powerful security model that makes interacting with audio and video devices from containerized applications easy, with support for Flatpak applications being the primary goal. Alongside Wayland and Flatpak, we expect PipeWire to provide a core building block for the future of Linux application development.

從這裡可以看到,PipeWire 和 PulseAudio 是替代關係。
那有沒有可能,因為 PipeWire 和 PulseAudio 都在工作或者衝突,導致了一些奇怪的問題?

Debian 上的 Pipewire

我查了下電腦上,果然安裝了 PulseAudio:

dpkg -l | grep pulseaudio

於是簡單查了一下,在 debian 的官方 wiki 上,可以看到 Gnome 環境下預設切換到了 Pipewire,而其他桌面環境還不是:

In Debian 12, PipeWire 0.3.65 is available, and is considerably more reliable, and is a comfortable drop-in replacement for many use-cases. PipeWire is the default sound server with GNOME Desktop.

這也是為什麼,之前為了解決螢幕共享的問題,我需要手動安裝 pipewire。
只不過目前看起來確實替換地不完整,需要重新搞一下。

使用 PipeWire 替換 PulseAudio

  1. Step1: 安裝 Pipeline 相關的包
sudo apt install pipewire-audio
# This metapackage depends on a recommended set of pipewire packages for a standard audio desktop use.
# 所以桌面環境安裝這個就夠了。建議只安裝這個 meta package,儘量減少未來升級系統時衝突的機率。
# 這個 meta package 也會自動刪除 pulseaudio 和 pulseaudio-module-bluetooth 相關的包,避免衝突。

然後重啟電腦。

  1. 開啟相關服務
systemctl --user --now enable wireplumber.service   # 注意不是 root,不需要 sudo
  1. 檢查是否生效
> pactl info | grep '^Server Name'
Server Name: PulseAudio (on PipeWire 0.3.65)

可以看到,已經在使用 PipeWire 了。

P.S. 如果沒有 pactl 命令,可以安裝一下:

sudo apt install pulseaudio-utils   # 這個包只是 check 用的一些工具,不影響正常的功能,也可以不裝。

也可以再檢查下 ALSA 是否已經開始使用 PipeWire:

> aplay -L | grep -A 1 default
default
    Default ALSA Output (currently PipeWire Media Server)

可以看到,ALSA 也正常使用 PipeWire 服務。

其他

Debian 官方 wiki 中還提到了 JACK 的配置,還挺麻煩的。我看了下我的電腦上本來也沒有 JACK 相關的包,因此就沒有安裝和配置了。

結尾

在我把 PulseAudio 替換成 PipeWire 之後,確實沒在出現開會的時候迴音的問題了,說明這個方法確實有效。至於為什麼會有迴音,恕我才疏學淺,暫未可知 😃

Linux 環境裡,經常出現一些相互可替代的方案,wayland 和 x11 也是類似的關係。揉在一起就容易出現各種奇葩的問題。目前也只能寄希望於相關生態儘快完成遷移,減少歷史包袱吧...

相關文章