Skip to content

一个主播录制工具 & 自动投稿b站

License

Notifications You must be signed in to change notification settings

thsrite/StreamerHelper

 
 

Repository files navigation

StreamerHelper

StreamerHelper

🍰 Never miss your Streamer again

MIT npm version nodejs version

Introduction

StreamerHelper 部署后,会在后台批量监测各个平台主播是否在线,并实时录制直播保存为视频文件,停播后投稿到b站。

(关于版权问题,投稿的参数默认一律设置的转载,简介处默认放有直播间链接)

Installation

录播配置

cp templates/info-example.json templates/info.json

Docker 部署(推荐)

配置文件: /app/templates/info.json

视频目录: /app/download

容器的保活使用docker提供的restart参数,不再使用PM2。

DNS参数可以根据地区以及实际情况进行配置。

# 本地编译
docker build -t streamerhelper .
# /your_project_path/info.json 指你配置好的info.json文件的绝对路径,后面的同理。
docker run --name stream -itd -v /your_project_path/info.json:/app/templates/info.json -v /your_project_path/download/:/app/download --dns 114.114.114.114 --restart always streamerhelper

或者直接使用docker.io上面的镜像

docker pull itgoyo/streamerhelper

然后配置好相应的info.json内容,还有设置好文件的下载目录download即可



直接部署到本机环境上

安装 Node.js

curl -sL https://deb.nodesource.com/setup_12.x | sudo -E bash -
sudo apt-get install -y nodejs

安装 ffmpeg

# Mac
brew update
brew install ffmpeg
# Linux
sudo add-apt-repository ppa:djcj/hybrid
sudo apt-get update
sudo apt-get install ffmpeg

登录:

access_token的获取可以使用biliup-rs这个项目获取 https://github.com/ForgQi/biliup-rs

又或者从这个项目获取BiliHelper-personal

https://github.com/lkeme/BiliHelper-personal

npm i -g pm2
# 如果装不动,添加 --registry=https://registry.npm.taobao.org 参数,npm i 同理
git clone https://github.com/ZhangMingZhao1/StreamerHelper.git && cd StreamerHelper
npm i
npm run serve

Configuration

配置文件info.json可以这个网站快速生成:https://streamertool.vercel.app/

info.json中字段的含义

StreamerHelper

字段 说明 可选值 是否必填 默认值
debug debug开关,开启后会有多余的记录 true/false false
recycleCheckTime 检测本地文件上传以及删除的间隔 300(s)
roomCheckTime 检测直播间的间隔 600(s)
videoPartLimitSize 小于此大小的文件不上传 100(mb)
logLevel 此级别之上(包括)的日志将被推送,无视大小写 "TRACE"|"DEBUG"|"INFO"|"WARN"|"ERROR" "error"

push

日志推送配置,WeChat 推送使用 Server 酱

mail

字段 说明 是否必填 默认值
enable 是否开启 true
host STMP 服务主机
port STMP 服务端口 465
from STMP 服务邮箱,作为发送邮件的邮箱
pwd STMP 服务密码
to 接受邮件的邮箱
secure 是否开启安全服务 true

wechat

字段 说明 是否必填 默认值
enable 是否开启 false
sendKey Server酱sendkey

personInfo

以下各字段的值会在登录后自动填写,如果选择access_token登录,需要手动填写personInfoaccess_token的值。

字段 说明 是否必填
nickname B站昵称
access_token 用于鉴权的token凭证
refresh_token
expires_in
tokenSignDate
mid

streamerInfo

是一个数组,描述需要录制的主播信息。

字段 说明 可选值 是否必填 默认值
name 主播名
uploadLocalFile 是否投稿 true/false true
deleteLocalFile 是否删除本地视频文件 true/false true
delayTime 投稿成功后延迟删除本地文件的时间(需要deleteLocalFile为true) 2(天)
templateTile 稿件标题,支持占位符{{name}} {{time}} 直播间名称
desc 稿件描述 Powered By StreamerHelper. https://github.com/ZhangMingZhao1/StreamerHelper
source 稿件直播源(需要copyright为2) {直播间名称} 直播间 {直播间地址}
dynamic 稿件粉丝动态 {直播间名称} 直播间 {直播间地址}
copyright 稿件来源,1为自制2为转载 1/2 2
roomUrl 直播间地址
tid 稿件分区 详见tid表 为空会导致投稿失败
tags 稿件标签 至少一个,总数量不能超过12个,并且单个不能超过20个字,否则稿件投稿失败

Example:

{
  "StreamerHelper": {
    "debug": false,
    "roomCheckTime": 600,
    "recycleCheckTime": 1800,
    "videoPartLimitSize": 100
    "logLevel": "error",
    "push": {
      "mail": {
        "enable": true,
        "host": "smtp.qq.com",
        "port": 465,
        "from": "***@qq.com",
        "pwd": ""***",
        "to": ""***@gmail.com",
        "secure": true
      },
      "wechat": {
        "enable": true,
        "sendKey": ""***"
      }
    }
  },
  "personInfo": {
    "nickname": "",
    "access_token": "",
    "refresh_token": "",
    "expires_in": 0,
    "tokenSignDate": 0,
    "mid": 0
  },
  "streamerInfo": [
    {
      "name": "主播1",
      "uploadLocalFile": true,
      "deleteLocalFile": true,
      "templateTitle": "{{name}}{{time}} 直播",
      "delayTime": 0,
      "desc": "",
      "source": "",
      "dynamic": "",
      "copyright": 2,
      "roomUrl": "https://live.xxx.com/111",
      "tid": 121,
      "tags": [
        "tag1",
        "tag2",
        "tag3"
      ]
    },
    {
      "name": "主播2",
      "uploadLocalFile": true,
      "deleteLocalFile": false,
      "templateTitle": "{{name}}{{time}} 直播",
      "delayTime": 1,
      "desc": "",
      "source": "",
      "dynamic": "",
      "copyright": 2,
      "roomUrl": "https://live.xxx.com/222",
      "tid": 171,
      "tags": [
        "tag1",
        "tag2",
        "tag3"
      ]
    }
  ]
}

Environment

我们的测试机器配置以及环境如下:

cpu mem bps OS Node.js
Intel i5-4590 @ 3.30GHz 2GB 100m Ubuntu 18.04 12.18.3

可以同时下载4个主播,不会产生卡顿。

Contributor

@ZhangMingZhao1 @umuoy1 @ni00 @daofeng2015 @FortuneDayssss @bulai0408 @zsnmwy

Thanks:

TodoList

  • 支持斗鱼,虎牙,b站直播,afreeca,抖音直播,快手直播,西瓜直播,花椒直播,YY 直播,战旗直播,酷狗繁星,NOW 直播,CC 直播,企鹅电竞直播
  • 自动监测主播在线
  • 自动上传b站
  • 多p下载多p上传
  • 支持多个主播
  • tag可配置,对应在info.json的每个主播
  • 支持access_token验证,防验证码
  • 重启后同时检测本地是否有上传失败的视频文件,并上传。
  • 爬虫定时区间,节省服务器流量,现支持配置房间检测间隔
  • 支持docker部署
  • 上传文件大小监测,解决主播断流问题出现很多小切片导致上传审核失败
  • 增加一个独立脚本遍历download文件夹下的视频文件重新上传(重启上传的折中解决办法,还有解决第一次账号密码配置错误失败上传的问题)
  • 支持twitch
  • 规范化log,完善debug log

Example

例子

见:https://space.bilibili.com/526120032

Tips

建议使用管口大的vps,否则上传下载速度可能会受影响。更新后请及时拉取像或git pull重新pm2 stop && npm run serve。vps比较低配的话配置的主播数量不要太多,也要注意vps的磁盘大小。日志文件会自动创建,在./logs/下。

代录服务

没有服务器的可以又想录制的可以找我代录制,5B币(大会员用户系统每个月都会送5B币)或者5RMB代录某主播一个月+v:itgoyo 记得备注(代录)

需要远程搭建帮助的付费[不贵]可以+v:itgoyo 记得备注(代录搭建)

有能力或者有时间的可以自行查资料自己动手做,我个人也比较推荐因为并不复杂,至于为什么收费,因为我没有这么多时间帮助小白弄这个东西,一天过来几个让我搭建环境的,我自己还有本职工作,也没这么多时间折腾这东西,所以先查资料或者看别人的视频,最后还是不会或者真的非常需要再来找我。


About

一个主播录制工具 & 自动投稿b站

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 99.4%
  • Dockerfile 0.6%