live video streaming server in golang
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
Matthew 16c6af5d90
Update README.md
6 months ago
.github/workflows remove fortify 6 months ago
av - 接入go mod 6 years ago
configure Add RTMPS Listen 3 years ago
container chore: fix function name in comment 1 year ago
parser Refactor imports and module name 5 years ago
protocol fix: typo 2 years ago
utils Refactor imports and module name 5 years ago
.gitignore Update ignore rules 4 years ago
.goreleaser.yml - 接入go mod 6 years ago
CHANGELOG.md Changelog and Readme 5 years ago
Dockerfile Update Dockerfile 5 years ago
LICENSE 补充MIT LICENSE 6 years ago
Makefile Default TAG value makefile 5 years ago
README.md Update README.md 6 months ago
README_cn.md README flags 5 years ago
SECURITY.md Create SECURITY.md 6 months ago
go.mod build: update github actions 4 years ago
go.sum build: update github actions 4 years ago
livego.yaml Add RTMPS Listen 3 years ago
logo.png docs: add logo 5 years ago
main.go remove test log 3 years ago
test.go 规范性改动 5 years ago

README.md

中文

Test Release CodeQL Advanced

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 the RTMP 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