在 CentOS 上搭建 Mumble 服务器

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

posted @ 2020-04-28 12:12  淳帅二代  阅读(1497)  评论(0编辑  收藏  举报