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 ,还不错。