Simple streaming service in Golang

Matthew 42d7596e80 Merge pull request #212 from jaesung9507/rtmps_listen 2 years ago
.github bfa299ac9f build: update github actions 3 years ago
av 74da8bec14 - 接入go mod 5 years ago
configure 47bfeeab57 Add RTMPS Listen 2 years ago
container 7010cec326 Fix Memory leak 3 years ago
parser 3032dcec1a Refactor imports and module name 4 years ago
protocol f24aaa62ee added hls via https support 2 years ago
utils 3032dcec1a Refactor imports and module name 4 years ago
.gitignore 15689e5138 Update ignore rules 3 years ago
.goreleaser.yml 74da8bec14 - 接入go mod 5 years ago
CHANGELOG.md 7d11f594a3 Changelog and Readme 4 years ago
Dockerfile 211b694429 Update Dockerfile 4 years ago
LICENSE 36aaf27ee5 补充MIT LICENSE 5 years ago
Makefile 8c2757f6a2 Default TAG value makefile 4 years ago
README.md f24aaa62ee added hls via https support 2 years ago
README_cn.md 150d08fdd6 README flags 4 years ago
go.mod bfa299ac9f build: update github actions 3 years ago
go.sum bfa299ac9f build: update github actions 3 years ago
livego.yaml 47bfeeab57 Add RTMPS Listen 2 years ago
logo.png 11c01b42bb docs: add logo 4 years ago
main.go 7942584156 remove test log 2 years ago
test.go 57a7b19671 规范性改动 4 years ago

README.md

中文

Test Release

Simple and efficient live broadcast server:

  • Very simple to install and use;
  • Pure Golang, high performance, and cross-platform;
  • Supports commonly used transmission protocols, file formats, and encoding formats;

Supported transport protocols

  • RTMP
  • AMF
  • HLS
  • HTTP-FLV

Supported container formats

  • FLV
  • TS

Supported encoding formats

  • H264
  • AAC
  • MP3

Installation

After directly downloading the compiled binary file, execute it on the command line.

Boot from Docker

Run docker run -p 1935:1935 -p 7001:7001 -p 7002:7002 -p 8090:8090 -d gwuhaolin/livego to start

Compile from source

  1. Download the source code git clone https://github.com/gwuhaolin/livego.git
  2. Go to the livego directory and execute go build or make build

Use

  1. Start the service: execute the livego binary file or make run to start the livego service;
  2. Get a channelkey(used for push the video stream) from http://localhost:8090/control/get?room=movie and copy data like your channelkey.
  3. Upstream push: Push the video stream to rtmp://localhost:1935/{appname}/{channelkey} through theRTMP protocol(default appname is live), for example, use ffmpeg -re -i demo.flv -c copy -f flv rtmp://localhost:1935/{appname}/{channelkey} push(download demo flv);
  4. Downstream playback: The following three playback protocols are supported, and the playback address is as follows:
    • RTMP:rtmp://localhost:1935/{appname}/movie
    • FLV:http://127.0.0.1:7001/{appname}/movie.flv
    • HLS:http://127.0.0.1:7002/{appname}/movie.m3u8
  5. Use hls via https: generate ssl certificate(server.key, server.crt files), place them in directory with executable file, change "use_hls_https" option in livego.yaml to true (false by default)

all options:

./livego  -h
Usage of ./livego:
      --api_addr string       HTTP manage interface server listen address (default ":8090")
      --config_file string    configure filename (default "livego.yaml")
      --flv_dir string        output flv file at flvDir/APP/KEY_TIME.flv (default "tmp")
      --gop_num int           gop num (default 1)
      --hls_addr string       HLS server listen address (default ":7002")
      --hls_keep_after_end    Maintains the HLS after the stream ends
      --httpflv_addr string   HTTP-FLV server listen address (default ":7001")
      --level string          Log level (default "info")
      --read_timeout int      read time out (default 10)
      --rtmp_addr string      RTMP server listen address

Use with flv.js

Interested in Golang? Please see Golang Chinese Learning Materials Summary