2023-05-23 20:58:54 +08:00
2022-02-06 08:50:41 +08:00
dev
2023-01-29 15:05:36 +08:00
2023-03-03 22:05:08 +08:00
2022-03-16 00:07:42 +08:00
2023-03-28 19:48:18 +08:00
2023-03-28 19:48:18 +08:00
2023-02-18 23:10:41 +08:00
2020-03-22 20:45:03 +08:00
2023-05-23 20:58:54 +08:00
2023-05-11 21:19:17 +08:00
dev
2023-01-29 15:05:36 +08:00
2023-03-03 22:05:08 +08:00
2023-03-03 22:05:08 +08:00

RTMP插件

rtmp插件提供rtmp协议的推拉流能力以及向远程服务器推拉rtmp协议的能力。

仓库地址

https://github.com/Monibuca/plugin-rtmp

引入

import _ "m7s.live/plugin/rtmp/v4"

推拉地址形式

rtmp://localhost/live/test
  • localhost是m7s的服务器域名或者IP地址默认端口1935可以不写,否则需要写
  • live代表appName
  • test代表streamName
  • m7s中live/test将作为streamPath为流的唯一标识

例如通过ffmpeg向m7s进行推流

ffmpeg -i [视频源] -c:v h264 -c:a aac -f flv rtmp://localhost/live/test

会在m7s内部形成一个名为live/test的流

如果m7s中已经存在live/test流的话就可以用rtmp协议进行播放

ffplay -i rtmp://localhost/live/test

配置

rtmp:
    publish:
        pubaudio: true # 是否发布音频流
        pubvideo: true # 是否发布视频流
        kickexist: false # 剔出已经存在的发布者,用于顶替原有发布者
        publishtimeout: 10s # 发布流默认过期时间,超过该时间发布者没有恢复流将被删除
        delayclosetimeout: 0 # 自动关闭触发后延迟的时间(期间内如果有新的订阅则取消触发关闭)0为关闭该功能保持连接。
        waitclosetimeout: 0 # 发布者断开后等待时间超过该时间发布者没有恢复流将被删除0为关闭该功能由订阅者决定是否删除
        buffertime: 0 # 缓存时间用于时光回溯0为关闭缓存
    subscribe:
        subaudio: true # 是否订阅音频流
        subvideo: true # 是否订阅视频流
        subaudioargname: ats # 订阅音频轨道参数名
        subvideoargname: vts # 订阅视频轨道参数名
        subdataargname: dts # 订阅数据轨道参数名
        subaudiotracks: [] # 订阅音频轨道名称列表
        subvideotracks: [] # 订阅视频轨道名称列表
        submode: 0 # 订阅模式0为跳帧追赶模式1为不追赶多用于录制2为时光回溯模式
        iframeonly: false # 只订阅关键帧
        waittimeout: 10s # 等待发布者的超时时间,用于订阅尚未发布的流
    tcp:
        listenaddr: :1935
        listennum: 0
    pull:
        repull: 0 # 当断开后是否自动重新拉流0代表不进行重新拉流-1代表无限次重新拉流
        pullonstart: {} # 是否在m7s启动的时候自动拉流
        pullonsub: {}  # 是否在有人订阅的时候自动拉流(按需拉流)
    push:
        repush: 0 # 当断开后是否自动重新推流0代表不进行重新推流-1代表无限次重新推流
        pushlist: {} # 推流列表,以 streamPath为key远程地址为value
    chunksize: 65536 # rtmp chunk size
    keepalive: false #保持rtmp连接默认随着stream的close而主动断开

:::tip 配置覆盖 publish subscribe 两项中未配置部分将使用全局配置 :::

API

rtmp/api/list

获取所有rtmp流

rtmp/api/pull?target=[RTMP地址]&streamPath=[流标识]

从远程拉取rtmp到m7s中

rtmp/api/push?target=[RTMP地址]&streamPath=[流标识]

将本地的流推送到远端

Description
RTMP协议插件,提供RTMP协议的server功能:接收rtmp推流和rtmp的播放功能
Readme MIT 324 KiB
Languages
Go 100%