基于Vue3 + WebRTC + Node + SRS + FFmpeg搭建的直播间
2025年起,billd-live项目的所有仓库将进入dev状态,如果你需要获取线上生产环境的代码,有以下两种方式:
- 请花些时间查看之前提交的代码:https://github.com/galaxy-s10/billd-live/commits/master/。
- 订阅 billd-project,价格:https://live.hsslive.cn/price
历史原因:
- 只有作者一人开发和维护。项目初期时,希望大家能参与进来:README.md,但截止到2025年01月07日,也就是差不多两年过去了,billd-live项目(
billd-live
、billd-live-admin
、billd-live-server
、billd-live-flutter
等),还是只有作者一人开发和维护。 - billd-live项目初心只是为了记录自己的学习音视频、直播等相关内容的过程(也就是写的东西是给自己看的,不是给别人看的),README.md
项目发展至今,遇到很多形形色色的人,总结来说,95%的人都是直播方面的小白,5%的是接触过直播;这95%里面的人里面,大概有10%是小老板/外包之类的,剩下的90%就基本都是技术开发了,这90%的技术开发里,虽然bill-live项目收获到了很多star,但这其中绝大多数来自于看个乐,真正将项目clone下来运行的寥寥无几。- 很久之前写过一篇文章:前端之被包养就不要谈独立人格。有能力你可以自己写,不用别人的。别人的免费开源的东西,人家有个 readme 或者文档已经是仁尽义尽。
billd 直播间,目前实现了类似 bilibili 的 Web 在线直播功能,即你(房主)可以发布直播,别人进入你的直播间后能看到你的直播内容;而你也可以作为观众,进入别人的直播间看别人的直播内容。
名称 | 仓库 | star & fork | 线上地址 |
---|---|---|---|
直播间前台 | billd-live | https://live.hsslive.cn | |
直播间后端 | billd-live-server | https://live-api.hsslive.cn | |
直播间后台 | billd-live-admin | https://live-admin.hsslive.cn | |
直播间移动端 | billd-live-flutter | https://live.hsslive.cn/download | |
直播间移动端 | billd-live-react-native | https://live.hsslive.cn/download | |
直播间客户端 | billd-live-electron | https://live.hsslive.cn/download | |
直播间移动端 | billd-live-kotlin | https://live.hsslive.cn/download |
- 原生 webrtc 推拉流
- srs webrtc 推流,支持
http-flv
、hls
、webrtc
、rtmp
拉流 - msr 推流,ffmpeg 转码,支持
http-flv
、hls
、webrtc
、rtmp
拉流 - 一对一打 PK
- 一对多打 PK
- 多对多打 PK
- 多平台转推(b 站、虎牙直播)
- 前端混流
- 推流鉴权
- 拉流鉴权
- OBS、FFmpeg推流
- 用户模块(qq 登录)
- 支付模块(支付宝当面付)
- 订单模块
- 商品模块
- 礼物模块
- 直播后台
- 响应式页面
- 适配多语言(i18n)
- 移动端App(Flutter)
- 客户端App(Electron)
- 接入bilibili直播
- 接入腾讯云(云直播)
- 接入腾讯云(实时音视频 TRTC)
- 私有化部署
- 前端相关:Vue3 以及相关技术栈、
Typescript
、WebRTC
、WebCodecs
、Web Workder
、Web Audio
、Canvas
- 后端相关:Nodejs 以及相关技术栈、
Koa2
、Sequelize
、Mysql
、Redis
、Socket.io
- 流媒体服务器相关:SRS、 FFmpeg、Coturn
- Docker 相关:Docker
https://live.hsslive.cn/privatizationDeployment
Apifox:https://apifox.com/apidoc/shared-c7556b54-17b2-494e-a039-572d83f103ed
官网下载:https://live.hsslive.cn/download/live
- 首页
- 进入直播间
- 发起直播
- 排行榜
- 首页
- 进入直播间
- 直播间详情、分区详情
- 直播中心
b 站教程:从零搭建迷你版 b 站 web 直播间合集,看里面带
从零搭建迷你b站直播间
封面的视频。billd-live 付费课:https://www.hsslive.cn/article/151
- 安装依赖(建议使用 node 版本:v18.19.0)
pnpm i
更新 billd 相关依赖:
pnpm i billd-utils@latest billd-scss@latest billd-deploy@latest billd-html-webpack-plugin@latest
- 运行
npm run dev
- 打包
npm run build
- 安装依赖(建议使用 node 版本:v18.19.0)
pnpm i
更新 billd 相关依赖:
pnpm i billd-utils@latest billd-scss@latest billd-html-webpack-plugin@latest
本地必须要有 docker、ffmpeg 环境!
项目启动后,会在项目的 src/secret/目录下生成 secret.ts 文件,请填写里面的信息,MYSQL_CONFIG、REDIS_CONFIG、SRS_CONFIG 必填!
# 1.初始化docker容器
pnpm run docker:dev
# 2.初始化数据库(可选,只需要执行一次)
pnpm run mysql:dev
# 3.运行(4300端口)
pnpm run dev
- iphone 14
- 三星 s10
- ipad air 3
https://live.hsslive.cn/doc/faq
https://live.hsslive.cn/support
配置:MacBook Pro 2023 Apple M3 Max,14 核 CPU,36G 内存
- 操作系统:mac os 14.1
- node 版本:v18.19.0
- pnpm 版本:8.6.3
- docker 版本:24.0.5, build ced0996
- mysql 版本:基于 docker,镜像:mysql:8.0
- redis 版本:基于 docker,镜像:redis:7.0
- srs 版本:基于 docker,镜像:registry.cn-hangzhou.aliyuncs.com/ossrs/srs:5.0.170
- ffmpeg 版本:5.1.2
配置:4 核 CPU,4G 内存,8M 带宽(广州)
- 操作系统:CentOS Linux release 8.2.2004
- nginx 版本:1.22.1
- node 版本:v16.19.1
- pnpm 版本:8.6.3
- docker 版本:23.0.1, build a5ee5b1
- mysql 版本:基于 docker,镜像:mysql:8.0
- redis 版本:基于 docker,镜像:redis:7.0
配置:2 核 CPU,2G 内存,带宽 30M(香港),2G内存也能跑,但偶尔会占满内存导致服务器卡死。配置:2 核 CPU,4G 内存,带宽 30M(香港)
- 操作系统:Alibaba Cloud Linux release 3 (Soaring Falcon)
- node 版本:v16.20.0
- pnpm 版本:8.6.3
- pm2 版本:5.3.0
- docker 版本:24.0.2, build cb74dfc
- srs 版本:基于 docker,镜像:registry.cn-hangzhou.aliyuncs.com/ossrs/srs:5.0.170
- ffmpeg 版本:6.0
billd-live自2023年3月开源以来,仅有作者(也就是我)一个人维护,深知做开源的难处。
如果你做过开源项目,并且单个仓库拿到 128+star
,我个人认为这是非常不容易的,因为这代表了你的开源被很多人关注或认同,如果此时你正在了解直播相关方面的内容,我录制的 billd-live付费课 或许会对你有一定帮助,它将对你进行免费,作为我认同你在开源方面做的贡献,以及我对你力所能及的回馈,希望你能不忘初心,砥砺前行~