Bilibili Live Streaming Recorder 哔哩哔哩直播录制
Go to file
2023-10-09 16:08:20 +08:00
.github chore: update portable.yml 2023-09-28 15:56:25 +08:00
src/blrec fix: fix RuntimeError: cannot join current thread 2023-10-09 16:08:20 +08:00
webapp feat: recording fmp4 streams if no flv streams 2023-10-07 11:52:18 +08:00
.dockerignore release: 1.4.0 2022-02-12 11:29:55 +08:00
.flake8 refactor: refactor stream recording ... 2022-05-29 16:34:00 +08:00
.gitignore first commit 2021-08-10 22:03:42 +08:00
CHANGELOG.md release: 1.14.1 2023-09-28 16:29:51 +08:00
Dockerfile feat: support disable progress bar 2023-03-19 15:26:31 +08:00
Dockerfile.mirrors feat: support disable progress bar 2023-03-19 15:26:31 +08:00
FAQ.md feat: record raw data of HLS 2022-07-31 12:31:22 +08:00
LICENSE first commit 2021-08-10 22:03:42 +08:00
MANIFEST.in release: v1.0.0 2021-08-11 13:33:21 +08:00
mypy.ini release: v1.0.0 2021-08-11 13:33:21 +08:00
pyproject.toml release: 1.7.0 2022-05-06 13:44:44 +08:00
README.md feat: add prefix for env variables 2023-03-19 15:23:39 +08:00
run.bat fix: correct mistakes 2023-03-30 10:53:17 +08:00
run.ps1 fix: correct mistakes 2023-03-30 10:53:17 +08:00
setup.cfg feat: support reverse proxy with subpath 2023-03-19 15:08:43 +08:00
setup.py release: v1.0.0 2021-08-11 13:33:21 +08:00
workspace.code-workspace release: 1.7.0 2022-05-06 13:44:44 +08:00

Bilibili Live Streaming Recorder (blrec)

这是一个前后端分离的 B 站直播录制工具。前端使用了响应式设计,可适应不同的屏幕尺寸;后端是用 Python 写的,可以跨平台运行。

这个工具是自动化的,会自动完成直播的录制, 在出现未处理异常时会发送通知,空间不足能够自动回收空间,还有详细日志记录,因此可以长期无人值守运行在服务器上。

屏幕截图

webapp

terminal

功能

  • 自动完成直播录制
  • 同步保存弹幕
  • 自动修复时间戳问题:跳变、反跳等。
  • 直播流参数改变自动分割文件,避免出现花屏等问题。
  • 流中断自动拼接且支持 无缝 拼接,不会因网络中断而使录播文件片段化。
  • flv 文件添加关键帧等元数据,使定位播放和拖进度条不会卡顿。
  • 可选录制的画质
  • 可自定义文件保存路径和文件名
  • 支持按文件大小或时长分割文件
  • 支持转换 flvmp4 格式(需要安装 ffmpeg
  • 硬盘空间检测并支持空间不足自动删除旧录播文件。
  • 事件通知(支持邮箱、ServerChanPushDeerpushplusTelegramBark
  • Webhook(可配合 REST API 实现录制控制,录制完成后压制、上传等自定义需求)

前提条件

Python 3.8+
ffmpeg、 ffprobe

安装

更新

  • 通过 pip 或者 pipx 安装的用以下方式更新

    pip install blrec --upgrade 或者 pipx upgrade blrec

  • 免安装绿色版

    • 下载并解压新版本
    • 确保旧版本已经关闭退出以避免之后出现端口冲突
    • 把旧版本的设置文件 settings.toml 复制并覆盖新版本的设置文件
    • 运行新版本的 run.bat

卸载

  • 通过 pip 或者 pipx 安装的用以下方式卸载

    pip uninstall blrec 或者 pipx uninstall blrec

  • 免安装绿色版

    删除解压后的文件夹

Docker

环境变量

  • 默认设置文件位置: ENV BLREC_DEFAULT_SETTINGS_FILE=/cfg/settings.toml
  • 默认日志存放目录: ENV BLREC_DEFAULT_LOG_DIR=/log
  • 默认录播存放目录: ENV BLREC_DEFAULT_OUT_DIR=/rec
  • 默认时区: ENV TZ="Asia/Shanghai"

默认参数运行

sudo docker run -v /etc/blrec:/cfg -v /var/log/blrec:/log -v ~/blrec:/rec -dp 2233:2233 acgnhiki/blrec

命令行参数用法

sudo docker run \
    -v /etc/blrec:/cfg -v /var/log/blrec:/log -v ~/blrec:/rec \
    -dp 2233:2233 acgnhiki/blrec \
    -c /cfg/another_settings.toml \
    --key-file path/to/key-file \
    --cert-file path/to/cert-file \
    --api-key bili2233

使用方法

命令行参数用法

blrec --help

默认参数运行

在命令行终端里执行 blrec ,然后浏览器访问 http://localhost:2233

默认设置文件位置:~/.blrec/settings.toml

默认日志文件目录: ~/.blrec/logs

默认录播文件目录: .

指定设置文件和录播与日志保存位置

blrec -c path/to/settings.toml -o path/to/records --log-dir path/to/logs

如果指定的设置文件不存在会自动创建

命令行参数会覆盖掉设置文件的对应的设置

绑定主机和端口

默认为本地运行,主机和端口绑定为: localhost:2233

需要外网访问,把主机绑定到 0.0.0.0,端口绑定则按照自己的情况修改。

例如:blrec --host 0.0.0.0 --port 8000

网络安全

指定 SSL 证书使用 https 协议并指定 api key 可防止被恶意访问和泄漏设置里的敏感信息

例如:blrec --key-file path/to/key-file --cert-file path/to/cert-file --api-key bili2233

如果指定了 api key浏览器第一次访问会弹对话框要求输入 api key。

输入的 api key 会被保存在浏览器的 local storage 以避免每次都得输入

如果在不信任的环境下,请使用浏览器的隐式模式访问。

关于 api-key

api key 可以使用数字和字母,长度限制为最短 8 最长 80。

3 次尝试内 api key 正确客户端 ip 会自动加入白名单3 次错误后则 ip 会被加入黑名单,黑名单后请求会被拒绝 (403)。

黑名单和白名单数以及同时尝试连接的 ip 数量限制各为 100黑名单或白名单到达限制后不再接受除了白名单内的其它 ip 。

只有重启才会清空黑名单和白名单。

作为 ASGI 应用运行

uvicorn blrec.web:app

或者

hypercorn blrec.web:app

作为 ASGI 应用运行,参数通过环境变量指定。

  • BLREC_CONFIG 指定设置文件
  • BLREC_OUT_DIR 指定录播存放位置
  • BLREC_LOG_DIR 指定日志存放位置
  • BLREC_API_KEY 指定 api key

bash

BLREC_CONFIG=path/to/settings.toml BLREC_OUT_DIR=path/to/dir BLREC_API_KEY=******** uvicorn blrec.web:app --host 0.0.0.0 --port 8000

cmd

set BLREC_CONFIG=D:\\path\\to\\config.toml & set BLREC_OUT_DIR=D:\\path\\to\\dir & set BLREC_API_KEY=******** uvicorn blrec.web:app --host 0.0.0.0 --port 8000

Webhook

程序在运行过程中会触发一些事件,如果是支持 webhook 的事件,就会给所设置的 webhook 网络地址发送 POST 请求。

关于支持的事件和 POST 请求所发送的数据,详见 wiki。

REST API

后端 web 框架用的是 FastApi , 要查看自动生成的交互式 API 文档,访问 http://localhost:2233/docs (默认主机和端口绑定)。

Progressive Web AppPWA

前端其实是一个渐进式网络应用,可以通过地址栏右侧的图标安装,然后像原生应用一样从桌面启动运行。

注意PWA 要在本地访问或者在 https 下才支持。


开发

  1. 克隆代码

    git clone https://github.com/acgnhiki/blrec.git

  2. 进入项目目录

    cd blrec

  3. 创建虚拟环境

    python3 -m venv .venv

  4. 激活虚拟环境

    source .venv/bin/activate

  5. 以可编辑方式安装

    pip install -e .[dev]

  6. 修改代码

    ……

  7. 运行 blrec

    blrec

  8. 退出虚拟环境

    deactivate


常见问题

FAQ

更新日志

CHANGELOG


其它相关工具或项目

名称 链接 简介
录播姬 官网 简单易用成熟稳定的 B 站直播录制工具
rclone 官网 可以挂载网盘用于存放录播文件
alist 官网 网盘文件浏览、播放
filebrowser 官网 服务器文件管理