Docker 部署 Navidrome 服务器与远程访问听歌的教程

Navidrome 是一个轻量级、功能强大的音乐流媒体服务器,可以通过 Docker 容器方便地部署。本教程涵盖从本地部署到远程访问的详细步骤。

一、环境准备

1. 安装 Docker 和 Docker Compose

在服务器(或本地机器)上安装 Docker 和 Docker Compose。

安装 Docker

Ubuntu 示例:

sudo apt update
sudo apt install -y docker.io
sudo systemctl enable --now docker

CentOS 示例:

sudo yum update
sudo yum install -y docker
sudo systemctl enable --now docker

验证 Docker 是否安装成功:

docker --version

安装 Docker Compose





sudo curl -L "https://github.com/docker/compose/releases/download/2.20.2/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose
docker-compose --version

2. 确保有音乐文件准备

将你的音乐文件整理好,可以保存在一个目录下,比如 /home/user/Music


二、本地部署 Navidrome

1. 创建 Navidrome 配置和音乐存储目录

mkdir -p ~/navidrome/config ~/navidrome/music

将你的音乐文件复制到 ~/navidrome/music 中:

cp -r /path/to/your/music/* ~/navidrome/music/

2. 创建 Docker Compose 文件

~/navidrome 目录下创建 docker-compose.yml

version: "3.8"

services:
  navidrome:
    image: deluan/navidrome:latest
    container_name: navidrome
    restart: unless-stopped
    ports:
      - "4533:4533" # Navidrome 默认端口
    volumes:
      - ./config:/data
      - ./music:/music
    environment:
      ND_LOGLEVEL: info
      ND_SCANNINGINTERVAL: "1h" # 自动扫描音乐文件的间隔
      ND_SESSIONTIMEOUT: "24h" # 登录会话超时时间

3. 启动 Navidrome

~/navidrome 目录下运行:

docker-compose up -d

验证服务是否启动:

docker ps

访问本地服务:

  • 打开浏览器并输入 http://localhost:4533(或 http://<你的IP>:4533)。
  • 初次访问会提示创建管理员账户。

三、配置远程访问

1. 开启端口转发

确保服务器或路由器上开放 4533 端口。

检查端口是否已开放:

sudo ufw allow 4533
sudo ufw reload

验证端口状态:

sudo netstat -tuln | grep 4533

2. 配置反向代理(推荐 Nginx)

反向代理可以通过域名访问 Navidrome,同时启用 HTTPS 提升安全性。

安装 Nginx

Ubuntu 示例:

sudo apt update
sudo apt install -y nginx

配置 Nginx

创建配置文件 /etc/nginx/sites-available/navidrome

nginx复制代码
server {
    listen 80;
    server_name yourdomain.com; # 替换为你的域名或 IP

    location / {
        proxy_pass http://localhost:4533;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

启用配置并重启 Nginx:

sudo ln -s /etc/nginx/sites-available/navidrome /etc/nginx/sites-enabled/
sudo nginx -t
sudo systemctl reload nginx

启用 HTTPS(Let’s Encrypt)

使用 Certbot 为域名启用 HTTPS:

sudo apt install -y certbot python3-certbot-nginx
sudo certbot --nginx -d yourdomain.com

3. 配置动态域名(如没有固定 IP)

如果你没有固定的公网 IP,可以使用动态域名服务(如 No-IP 或 Cloudflare)设置 DDNS。

四、优化与管理

1. 自动更新音乐库

Navidrome 会根据 ND_SCANNINGINTERVAL 配置自动扫描新增的音乐文件。如果需要手动触发:

docker exec -it navidrome navidrome --scan

2. 查看日志

调试或排查问题:

docker logs -f navidrome

3. 更新 Navidrome

定期更新 Docker 镜像:

docker-compose pull
docker-compose up -d

4. 管理用户

通过 Web 界面可以管理用户和播放列表。

五、远程访问听歌

  1. 通过浏览器访问 http://yourdomain.comhttps://yourdomain.com
  2. 在移动设备上安装支持 Subsonic 协议的播放器(如 DSubUltrasonic)。
    • 服务器地址:你的域名(如 https://yourdomain.com)。
    • 用户名和密码:在 Navidrome Web 界面创建的账号。

六、总结

通过 Docker 部署 Navidrome 并结合反向代理和 HTTPS 配置,可以快速搭建安全、高效的音乐流媒体服务器。关键步骤包括:

  1. 本地部署 Navidrome。
  2. 开放端口或设置反向代理实现远程访问。
  3. 启用 HTTPS 提升安全性。

如有任何问题或特殊需求,欢迎进一步咨询!

发布者:myrgd,转载请注明出处:https://www.object-c.cn/4419

Like (0)
Previous 2024年11月22日 下午5:58
Next 2024年11月22日 下午7:33

相关推荐

  • ubuntu服务器安装cuda11.0、cuDNN入门教程

    在 Ubuntu 服务器上安装 CUDA 11.0 和 cuDNN 的详细教程如下。本教程涵盖了从环境准备到安装和验证的完整流程,适用于初学者。 一、环境准备 1. 系统要求 2. 卸载旧版本(如有) 清理可能存在的旧版本 CUDA 和 NVIDIA 驱动: 二、安装 NVIDIA 驱动 1. 检查 GPU 支持情况 使用 lspci 或 nvidia-sm…

    2024年11月22日
    00
  • 在国内访问 GitHub 可能会遇到加载缓慢或无法打开的问题

    在国内访问 GitHub 可能会遇到加载缓慢或无法打开的问题,这通常与网络连接、DNS 设置或网络限制有关。以下是几种解决方法: 1. 更改 DNSDNS 配置错误可能导致 GitHub 无法正常访问。可以尝试修改 DNS 为公共 DNS 服务:推荐使用:阿里云 DNS:223.5.5.5 和 223.6.6.6Google DNS:8.8.8.8 和 8.…

    2024年11月27日
    00
  • 使用 Webpack 5 优化构建减少生成文件的体积提升前端性能

    在使用 Webpack 5 时,优化构建以减少生成文件的体积是提升前端性能的重要一步。以下是一些常见的优化方法和策略: 1. 开启生产模式 确保构建时使用生产模式,Webpack 会自动应用多种优化(如代码压缩、Tree Shaking 等): 或在配置文件中明确设置: 2. 启用 Tree Shaking Tree Shaking 是 Webpack 内置…

    2024年12月3日
    00
  • 在 Nuxt.js 应用中,webpack 的 compile 事件钩子构建过程

    在 Nuxt.js 应用中,webpack 的 compile 事件钩子通常用于在构建过程中处理或监听 Webpack 编译的状态。webpack 是 Nuxt.js 中的核心构建工具之一,而 Nuxt.js 本身是基于 Webpack 配置的,允许你通过扩展 Webpack 配置来进行自定义。要使用 webpack 的 compile 事件钩子,首先你需要…

    2024年11月29日
    00
  • 部署 Harbor 时,如果运行 install 脚本报错可能导致问题的

    在部署 Harbor 时,如果运行 install 脚本报错,可能是网络问题导致的。以下是排查网络问题的方法: 1. 检查网络连通性 测试目标网络的连通性: 检查 DNS 配置: 如果解析失败,检查 /etc/resolv.conf 中的 DNS 配置,或者尝试手动指定公共 DNS,如 Google 的 8.8.8.8 或阿里云的 223.5.5.5。 2.…

    2024年12月9日
    00
  • 修复 Elementor 网站上出现的 HTTPS 400 错误请求(服务器错误)

    在修复 Elementor 网站上出现的 HTTPS 400 错误请求(服务器错误)时,您需要采取以下步骤来排查和解决问题。这类错误通常与服务器配置、插件冲突或 HTTPS 配置相关。 1. 检查 HTTPS 配置 2. 排查插件冲突 3. 检查主题兼容性 4. 调整服务器配置 URL 重写规则: 5. 清理缓存 6. 检查网络请求 7. 联系主机服务商 如…

    2024年12月9日
    00
  • 在安装Docker时,执行yum install -y yum-utils 报错的解决方法

    在安装 Docker 时,如果执行 yum install -y yum-utils 报错,可能是由于以下原因之一: 解决方法1. 检查 Yum 源配置确保您的系统配置了可用的 Yum 源。使用以下命令检查: 如果列表为空或不可用,重新配置一个有效的源(例如阿里云、腾讯云)。 替换为阿里云源(以 CentOS 7 为例): 2. 安装 EPEL 仓库yum-…

    2024年11月27日
    00
  • 高性能 TongRDS 是一种分布式内存数据缓存中间件

    TongRDS 是一种分布式内存数据缓存中间件,旨在为高性能、高并发的应用场景提供快速的数据访问解决方案。类似于 Redis 或 Memcached,TongRDS 的核心功能围绕内存数据存储和分布式特性展开,同时可能具备特定的优化或扩展能力。 以下是 TongRDS 的可能特性和应用场景总结: 1. 核心特性 分布式缓存架构 高性能存储 灵活的数据模型 扩…

    2024年12月3日
    00
  • 云服务器的 宝塔面板 中配置 PHP 支持 WebP 格式的图片

    在云服务器的 宝塔面板 中配置 PHP 支持 WebP 格式的图片,主要是通过安装或启用 GD 库或者 ImageMagick 来实现 WebP 图片的处理支持。下面是一步步的操作方法:1. 确保服务器已经安装 WebP 扩展WebP 格式的支持需要 PHP 依赖于 GD 库或 ImageMagick 库。如果你使用的是 PHP 7.0 及以上版本,通常 G…

    2024年11月29日
    00
  • 在 Debian 8 上设置 Apache 虚拟主机步骤操作

    在 Debian 8 上设置 Apache 虚拟主机需要按照以下步骤操作。这可以让您为不同的域名或子域名配置独立的网站目录和设置。 步骤 1:安装 Apache确保 Apache 已安装。如果没有安装,可以运行以下命令: 步骤 2:创建虚拟主机的目录结构为每个虚拟主机创建单独的目录,例如: 为测试,在每个目录下创建一个 index.html 文件: 设置目录…

    2024年12月2日
    00
  • STM32 的串口(RS485)数据收发通信模式

    STM32 的串口(RS485)数据收发需要使用 RS485 协议,这是一种常用于工业设备和长距离通信的串行通讯标准。RS485 支持半双工通信,即数据可以在同一线路上进行收发。STM32 支持通过 UART 串口来配置 RS485 模式,利用硬件流控制进行数据收发。以下是实现 STM32 与 RS485 数据收发的基本步骤。 1. 硬件连接 RS485 与…

    2024年11月25日
    00
  • 安装 Laravel 11 + Filament 详细教程

    安装Laravel 11之前选确保安装了Composer 管理器,接下来的步骤是通过Composer 包管理器安装完成的。 一、前提条件 二、使用 Composer 创建新的 Laravel 11 项目 三、在现有项目中添加 Laravel 11(如果是集成到现有项目) 请注意,在实际安装过程中,可能会遇到各种问题,如权限问题(在 Linux 下,如果没有足…

    2025年1月18日
    00
  • 在 MySQL 中 utf8mb4 和 utf8mb3 两种 UTF-8 编码的字符集主要区别

    在 MySQL 中,utf8mb4 和 utf8mb3 是两种 UTF-8 编码的字符集,它们的主要区别如下:1. 支持的字符范围不同utf8mb3:原来的 UTF-8 编码实现,支持最多 3 个字节的字符。无法存储超出基本多语言平面 (BMP) 的 Unicode 字符(U+10000 至 U+10FFFF),例如某些表情符号和特殊的语言字符。主要用于存储…

    2024年12月3日
    00
  • 在进行 Java 单元测试时,遇到找不到类名的错误

    在进行 Java 单元测试时,遇到找不到类名的错误,通常是由于以下几个原因引起的。下面是一些常见问题及其解决方法:1. 类路径(Classpath)问题最常见的原因是编译后的类文件没有正确地包含在类路径中,或者类文件没有被正确加载到测试框架中。要解决这个问题,确保以下几点:解决方法:确认类是否存在:首先确保测试类和目标类都已经编译,并且在正确的目录中。检查 …

    2024年11月28日
    00
  • 在 Apache Spark 中,任务的切分(Task Division)机制

    在 Apache Spark 中,任务的切分(Task Division)是 Spark 将应用程序逻辑划分为多个并行任务的核心机制。任务切分的主要原则是基于数据分区和操作算子。以下是任务切分的核心原则和关键影响因素: 1. Spark 任务切分的基本概念 2. 任务切分的原则 2.1 基于分区(Partition)的切分 2.2 基于依赖关系(Depend…

    2024年11月25日
    00

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

在线咨询: QQ交谈

邮件:723923060@qq.com

关注微信