动机

这几天为了服务器上搭建的FileBrowser播放视频浏览了一堆资料,现在基本可以做个总结了.

FileBrowser是一个开源的基于Web的文件管理器,它支持在Web浏览器中访问和管理本地和远程服务器上的文件。它提供了一个简单易用的界面来上传,下载,编辑和共享文件。

FileBrowser可以通过简单配置与FTP,SFTP和WebDAV服务器进行交互,也可以通过配置实现单点登录 (SSO) 和双重验证等安全控制。此外,该应用还提供了一些高级功能,例如文件预览、搜索和多用户管理等。

FileBrowser旨在提供一个便捷的方式来管理您的文件,无论是在个人电脑上还是在云端存储。它是一个跨平台的应用,可以在Windows,Mac和Linux操作系统下运行,并且连同所需依赖,可轻松地在本地或云中部署。

之前写了用Nginx给FileBrowser反向代理,大致方法是先设置FileBrowser的BaseUrl,这一步是必须的,然后反向代理就代理这个BaseUrl.比如使用

filebrowser config set --baseurl /files

设置filebrowser,注意这里要在你的配置文件json或者db同目录下

然后在Nginx上设置

   location  ^~  /files/
  { 
   proxy_pass   http://127.0.0.1:9201/;
    proxy_set_header Host $proxy_host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
   
  }

反向代理是一种网络服务架构,它充当服务器与客户端之间的中介。它接收来自客户端的请求,并根据某些规则将请求转发到后端服务器。并将后端服务器返回的响应返回给客户端。反向代理隐藏了后端服务器的真实地址,并可以通过负载均衡等技术来提高系统的可靠性和可伸缩性。

基本上这样就可以了,但是当我使用FileBrowser在线看视频时,出现了奇怪的问题.我在原本开放的端口上能正常看视频,虽然有点卡卡的,但也算基本正常,但是在代理的uri上却始终播不出来.

一开始我以为是FileBrowser的问题,绕来绕去搜了一些资料甚至想自己fork一份写一下,但都无果.

最后发现这个流媒体逆向代理缓存有关.在Nginx中也就是proxy_buffering这个参数

当proxy_buffering开启,A发起请求到B,B再到C,C反馈的数据先到B的buffer上,然后B会根据proxy_busy_buffer_size来决定什么时候开始把数据传输给A。

在此过程中,如果所有的buffer被写满,数据将会写入到temp_file中。

相反,如果proxy_buffering关闭,C反馈的数据实时地通过B传输给A。

之前默认proxy_buffering on;所以视频加载到满足proxy_buffers时才开始向代理服务器传输

如果数据很大的话,Nginx会接收并把他们写入到temp_file里去,大小由proxy_max_temp_file_size 控制。「当数据没有完全读完的时候」,Nginx同时向客户端传送的buffer 大小 不能超过 proxy_busy_buffers_size

所以到这里也就清楚了,另外还有一个参数proxy_cache

proxy_cache将从C上获取到的数据根据预设规则存放到B上(内存+磁盘)留着备用, A请求B时,B会把缓存的这些数据直接给A,而不需要再去向C去获取.

在Nginx服务器中,Proxy Buffer和Proxy Cache都与代理服务相关,主要用来提供客户端与被代理服务器之间的交互效率。Proxy Buffer实现了被代理服务器响应数据的异步传输,Proxy Cache则主要实现Nginx服务器对客户端数据请求的快速响应。

不过由于proxy_buffering已经关闭了,所以这个功能不会生效,但是经过测试也需要设置proxy_cache off

Nginx配置如下

   location  ^~  /files/
  {
proxy_cache off; 
proxy_buffering off;
   proxy_http_version  1.1; 
   proxy_pass   http://127.0.0.1:9201/;
   proxy_temp_file_write_size 2048k;
    proxy_set_header Host $proxy_host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
   
  }

最后

这里有mp4和mkv的视频格式,但是截至到发文位置,基本除了Chrome浏览器,其他浏览器包括Edge,对于mkv格式视频播放都没有很好的支持,Edge浏览器mkv视频只有画面没有音乐.

alt

参考资料

  1. [Nginx 反向代理 HLS 流媒体方法 – 主机指南 (hostarr.com)](https://www.hostarr.com/reverse-proxy-for-hls-stream/#:~:text=Nginx 反向代理 HLS 流媒体方法 1 1. 笔者服务器环境为 CentOS。,运行 Nginx 服务和设置开机自启动。 4 4. 编辑 Nginx 站点配置文件,加入下面这段反代规则(注意去掉注释)。)

  2. filebrowser/filebrowser: 📂 Web File Browser (github.com)

  3. 8分钟带你深入浅出搞懂Nginx - 知乎 (zhihu.com)

  4. Nginx 反向代理 FileBrowser | ConorLuo 博客 (buctllx.github.io)

  5. Installation - File Browser

  6. Stream Movies & TV Shows | Plex

  7. Nginx Proxy Buffer 和 Proxy Cache 的区别 - 简书 (jianshu.com)

本文由 mdnice 多平台发布

Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐