hls-server-ef

1.2.3 • Public • Published

hls-server-encodingfixed

Standard - JavaScript Style Guide

Simple HTTP middleware for serving HTTP Live Streaming (HLS) compatible media streams.

Disclaimer

The only difference from hls-server: a single undefined check has been added to prevent a crash.

Usage

First you need a compatible media stream (see Producing Streams)

Fast way:

require('hls-server-ef')(8000)

Detailed way:

var HLSServer = require('hls-server-ef')
var http = require('http')
 
var server = http.createServer()
var hls = new HLSServer(server, {
  path: '/streams',     // Base URI to output HLS streams
  dir: 'public/videos'  // Directory that input files are stored
})
server.listen(8000)

Producing Streams

HLS can only stream files that have been properly encoded and segmented. FFMPEG is great for this.
Here is how to do it with node-fluent-ffmpeg.

var ffmpeg = require('fluent-ffmpeg')
 
function callback() { // do something when encoding is done }
 
fmpeg('input.mp4', { timeout: 432000 }).addOptions([
    '-profile:v baseline',
    '-level 3.0',
    '-s 640x360',
    '-start_number 0',
    '-hls_time 10',
    '-hls_list_size 0',
    '-f hls'
  ]).output('public/videos/output.m3u8').on('end', callback).run()

To create segments from an existing RTMP stream, use the following node-fluent-ffmpeg command. You can expect 20-50 seconds of latency, depending on hardware.

var ffmpeg = require('fluent-ffmpeg')
 
// host, port and path to the RTMP stream
var host = 'localhost'
var port = '1935'
var path = '/live/test'
 
function callback() { // do something when stream ends and encoding finshes }
 
fmpeg('rtmp://'+host+':'+port+path, { timeout: 432000 }).addOptions([
    '-c:v libx264',
    '-c:a aac',
    '-ac 1',
    '-strict -2',
    '-crf 18',
    '-profile:v baseline',
    '-maxrate 400k',
    '-bufsize 1835k',
    '-pix_fmt yuv420p',
    '-hls_time 10',
    '-hls_list_size 6',
    '-hls_wrap 10',
    '-start_number 1'
  ]).output('public/videos/output.m3u8').on('end', callback).run()

To publish from an RTMP client like OBS, use a RTMP server like rtmp-server-nodejs to echo the stream.

NOTE: Transcoding live streams is very CPU-intensive. Most consumer hardware won't be able to handle transcoding more than a few streams.

CLI Tool

This package includes a CLI tool that can be installed globally with npm install -g hls-server.

To use, navigate to the directory where your .ts files are stored and run hlsserver in a command prompt. This will start a server on port 8000. (Use hlsserver --help to see additional options.)

Readme

Keywords

none

Package Sidebar

Install

npm i hls-server-ef

Weekly Downloads

1

Version

1.2.3

License

MIT

Last publish

Collaborators

  • zsmb