在 CentOS 上搭建 Mumble 服务器

2023-07-29,,

Mumble 服务器搭建

前言

Mumble 是一个开源、低延迟、高质量的语音通话平台。可以在多个平台搭建,并且有多个开源的客户端(Windows、Linux、Android、MacOS)。这是 官网 Github

比如你可以在 F-Droid 下载一个开源的客户端 Mumla ,可以使用自己搭建的服务器,也可以使用许多公共服务器。

Mumble 有以下特点:

对用户

低延迟,用于游戏交流体验超棒
保持隐私和安全
始终是加密通话
默认使用公钥、私钥配对
通过服务器辨别朋友
对于游戏玩家:
In-game Overlay 看谁在说话、FPS、时间
方位音频,听到玩家从游戏中的所处的位置说话。
有指南帮助设置,例如配置麦克风
对管理员
Libre 软件,没有授权什么的限制
开源,安全,可扩展
可扩展的用户权限系统
可通过 Ice 和 GRPC 协议扩展
对 Hosters
免费软件
可通过 Ice middleware 自动化管理
低资源占用
稳定的 server 软件
可自定义的 web-interfaces (通过 Ice)

这里是官方的服务器搭建指南: Server guide

其实像 Ubuntu 类的系统搭建是比较简单的,有官方包,安装运行就行,但是 CentOS 没有官方 yum 可安装的包,所以要手动搭建。

今天在我的阿里云 CentOS 服务器上搭建了 Mumble 服务器。

安装

Windows

下载安装包安装就行了

Linux

CentOS7

下载

(服务器端是 murmur ,不是 mumble,mumble 是客户端)

tar -jxvf murmur-static_x86-1.3.0.tar.bz2
cd cd murmur-static_x86-1.3.0
mkdir /usr/local/murmur
sudo cp -r ./murmur-static_x86-1.3.0/* /usr/local/murmur/
sudo cp ./murmur-static_x86-1.3.0/murmur.ini /etc/murmur.ini
创建 Murmur 账户、数据目录、登陆目录
sudo groupadd -r murmur
sudo useradd -r -g murmur -m -d /var/lib/murmur -s /sbin/nologin murmur
sudo mkdir /var/log/murmur
sudo chown murmur:murmur /var/log/murmur
sudo chmod 0770 /var/log/murmur
系统配置

Murmur.ini vim /etc/murmur.ini

database=/var/lib/murmur/murmur.sqlite
logfile=/var/log/murmur/murmur.log
pidfile=/var/run/murmur/murmur.pid # 对了,把服务密码设一下,不要让人随便就能加入
serverpassword=mypassword # Reminder: When changing the port that murmur will listen to you will need to also update the firewall.
# Update the firewall by editing /etc/firewalld/services/murmur.xml
# Then run "sudo firewall-cmd --reload"
port=64738 # Comment out the following setting since the service will already be executing as the correct user:
# uname=murmur # 再设下最大在线用户数。估计我的服务器承载不了很多人
users=10

允许后台运行

创建一个系统单位,让 Murmur 可以被系统管理,创建文件 vim /etc/systemd/system/murmur.service

[Unit]
Description=Mumble Server (Murmur)
Requires=network-online.target
After=network-online.target mariadb.service time-sync.target [Service]
User=murmur
Type=forking
ExecStart=/usr/local/murmur/murmur.x86 -ini /etc/murmur.ini
PIDFile=/var/run/murmur/murmur.pid
ExecReload=/bin/kill -s HUP $MAINPID [Install]
WantedBy=multi-user.target

当前的系统中,/var/run 已经不能用了,创建 vim /etc/tmpfiles.d/murmur.conf

d /var/run/murmur 775 murmur murmur
自动覆盖Log

设置 logrotate 不让 log 文件 /var/log 装满。创建 vim /etc/logrotate.d/murmur

/var/log/murmur/*log {
su murmur murmur
dateext
rotate 4
missingok
notifempty
sharedscripts
delaycompress
postrotate
/bin/systemctl reload murmur.service > /dev/null 2>/dev/null || true
endscript
}
防火墙(如果要更改默认端口的话)

/etc/firewalld/services/murmur.xml

<?xml version="1.0" encoding="utf-8"?>
<service>
<short>Murmur</short>
<description>Mumble Server (Murmur)</description>
<port protocol="tcp" port="64738" /><!-- Reminder: Update /etc/murmur.ini so that it uses the same ports -->
<port protocol="udp" port="64738" />
</service>

再添加防火墙规则到默认区域并重新载入:

sudo firewall-cmd --permanent --add-service=murmur
sudo firewall-cmd --reload
SELinux

如果有 SELinux ,临时禁用:

sudo setenforce 0

要永久禁用 SELinux :

SELINUX=disabled
最后步骤:

更新系统让它准备运行 Murmur 服务

sudo systemd-tmpfiles --create /etc/tmpfiles.d/murmur.conf
sudo systemctl daemon-reload

暂时启动:

sudo systemctl start murmur.service

设置自动启动:

sudo systemctl enable murmur.service

注意 :如果启动 Murmur 后只得到了一个僵死的进程,那么需要安装 redhat-lsb-core

系统准备

在控制台打开 64738 的 TCP 和 UDP 端口,

配置服务

ini 文件

改变 ini 文件后要重启服务才能生效。 ini 长这个样子:

welcometext=
port=
serverpassword=
上面一行留空表示是公共服务
bandwidth=
users=
registerName=根频道的名字
#这是注释

登陆

用手机端的 Mumla 测试下,延迟 64ms ,还不错。

在 CentOS 上搭建 Mumble 服务器的相关教程结束。

《在 CentOS 上搭建 Mumble 服务器.doc》

下载本文的Word格式文档,以方便收藏与打印。