Go to file
2013-04-06 20:30:40 +04:00
doc added documentation link 2012-11-28 20:42:21 +04:00
hls fixed HLS/MPEG-TS PES header stuffing when adaptation is present 2013-04-06 17:37:36 +04:00
test fixed image url in test html 2013-04-06 20:30:40 +04:00
AUTHORS improved frame timing & added meta files 2012-03-20 03:52:39 +04:00
config removed hls module & added hls code to rtmp module 2013-03-05 10:40:40 +04:00
LICENSE improved frame timing & added meta files 2012-03-20 03:52:39 +04:00
ngx_rtmp.c removed rtmp init event queue 2013-02-05 17:52:06 +04:00
ngx_rtmp.h removed rtmp init event queue 2013-02-05 17:52:06 +04:00
ngx_rtmp_access_module.c fixed compilation 2012-10-04 14:00:18 +04:00
ngx_rtmp_amf.c Merge remote branch 'origin/safe-amf-parser' into video-on-demand 2012-07-06 12:38:24 +04:00
ngx_rtmp_amf.h Merge remote branch 'origin/safe-amf-parser' into video-on-demand 2012-07-06 12:38:24 +04:00
ngx_rtmp_auto_push_module.c implemented static pulls 2013-01-14 22:58:10 +04:00
ngx_rtmp_bandwidth.c implemented http/xml/xsl RTMP stats 2012-05-07 15:41:03 +04:00
ngx_rtmp_bandwidth.h implemented http/xml/xsl RTMP stats 2012-05-07 15:41:03 +04:00
ngx_rtmp_cmd_module.c moved initializers to postconf 2013-03-03 23:14:44 +04:00
ngx_rtmp_cmd_module.h implemented on_connect & on_disconnect 2013-01-28 22:17:19 +04:00
ngx_rtmp_codec_module.c Merge branch 'record-keyframes' 2012-12-25 19:50:11 +04:00
ngx_rtmp_codec_module.h removed codec header versions 2012-11-14 12:29:46 +04:00
ngx_rtmp_control_module.c fixed http handlers stat/control 2013-04-06 19:01:20 +04:00
ngx_rtmp_core_module.c fixed static code analysis errors; thanks to @pgbi 2013-02-15 14:23:23 +04:00
ngx_rtmp_enotify_module.c changed deleteStream to closeStream in enotify module 2012-11-15 21:20:23 +04:00
ngx_rtmp_eval.c fixed evaluation variable at the end of string 2012-09-13 15:20:14 +04:00
ngx_rtmp_eval.h added all required arguments to old-style & new-style exec 2012-09-12 19:38:41 +04:00
ngx_rtmp_exec_module.c fixed crash if missing rtmp{} block in config; thanks to @Freexer 2013-02-05 19:42:18 +04:00
ngx_rtmp_flv_module.c implemented mp4 track selector 2013-01-26 10:06:04 +04:00
ngx_rtmp_handler.c added naccepted value to stat 2013-02-02 22:18:19 +04:00
ngx_rtmp_handshake.c async client handshake switched to posted events 2012-12-27 17:19:54 +04:00
ngx_rtmp_init.c fixed static code analysis errors; thanks to @pgbi 2013-02-15 14:23:23 +04:00
ngx_rtmp_limit_module.c fixed compilation 2013-03-04 10:44:20 +04:00
ngx_rtmp_live_module.c fixed sync after channel restart 2013-02-10 19:09:24 +04:00
ngx_rtmp_live_module.h fixed some streaming bugs && implemented wait_video 2012-12-07 17:15:24 +04:00
ngx_rtmp_log_module.c disabled logging relay connections 2013-01-13 22:25:37 +04:00
ngx_rtmp_mp4_module.c fixed mp4 extended size parser 2013-02-04 18:23:45 +04:00
ngx_rtmp_netcall_module.c implemented on_connect & on_disconnect 2013-01-28 22:17:19 +04:00
ngx_rtmp_netcall_module.h new optimized notifications 2012-11-08 10:30:00 +04:00
ngx_rtmp_notify_module.c fixed loging 2013-04-02 09:55:56 +04:00
ngx_rtmp_play_module.c fixed crash when seeking incomplete remote file: introduced post seek 2013-03-20 15:20:08 +04:00
ngx_rtmp_play_module.h fixed crash when seeking incomplete remote file: introduced post seek 2013-03-20 15:20:08 +04:00
ngx_rtmp_receive.c implemented rtmp aggregate message support; fixed rtmp acks 2012-12-17 21:22:51 +04:00
ngx_rtmp_record_module.c implemented record append feature 2013-03-01 19:10:11 +04:00
ngx_rtmp_record_module.h implemented record append feature 2013-03-01 19:10:11 +04:00
ngx_rtmp_relay_module.c reverted the meaning of session_relay 2013-03-03 18:42:57 +04:00
ngx_rtmp_relay_module.h implemented static pulls 2013-01-14 22:58:10 +04:00
ngx_rtmp_send.c fixed sending status 2012-12-26 15:06:55 +04:00
ngx_rtmp_shared.c implemenmted several optimizations 2012-04-19 09:53:18 +04:00
ngx_rtmp_stat_module.c fixed http handlers stat/control 2013-04-06 19:01:20 +04:00
ngx_rtmp_streams.h removed legacy constants 2012-10-20 17:40:21 +04:00
README.md updated readme info about HLS 2013-03-22 08:51:22 +04:00
stat.xsl added naccepted value to stat 2013-02-02 22:18:19 +04:00
TODO updated TODO 2013-02-01 23:21:51 +04:00

NGINX-based RTMP server

nginx-rtmp-module

Project blog

http://rarut.wordpress.com

Wiki manual

https://github.com/arut/nginx-rtmp-module/wiki/Directives

Google group

https://groups.google.com/group/nginx-rtmp

https://groups.google.com/group/nginx-rtmp-ru (Russian)

Project page at github

Project features, examples, donation information

http://arut.github.com/nginx-rtmp-module/

Features

  • Live streaming of video/audio

  • Video on demand FLV/MP4, playing from local filesystem or HTTP

  • Stream relay support for distributed streaming: push & pull models

  • Recording streams in multiple FLVs

  • H264/AAC support

  • Online transcoding with FFmpeg

  • HLS (HTTP Live Streaming) support

  • HTTP callbacks (publish/play/record/update etc)

  • Running external programs on certain events (exec)

  • HTTP control module for recording audio/video and dropping clients

  • Advanced buffering techniques to keep memory allocations at a minimum level for faster streaming and low memory footprint

  • Proved to work with Wirecast,FMS,Wowza, JWPlayer,FlowPlayer,StrobeMediaPlayback, ffmpeg,avconv,rtmpdump,flvstreamer and many more

  • Statistics in XML/XSL in machine- & human- readable form

  • Linux/FreeBSD/MacOS

Build

cd to NGINX source directory & run this:

./configure --add-module=<path-to-nginx-rtmp-module>
make
make install

See this article about building nginx-rtmp with HLS support: https://github.com/arut/nginx-rtmp-module/wiki/Building-nginx-rtmp-with-HLS-support

RTMP URL format

rtmp://rtmp.example.com/app[/name]

app - should match one of application {} blocks in config

name - interpreted by each application can be empty

Multi-worker live streaming

Module supports multi-worker live streaming through automatic stream pushing to nginx workers. This option is toggled with rtmp_auto_push directive.

Example nginx.conf

rtmp {

    server {

        listen 1935;

        chunk_size 4000;

        # TV mode: one publisher, many subscribers
        application mytv {

            # enable live streaming
            live on;

            # record first 1K of stream
            record all;
            record_path /tmp/av;
            record_max_size 1K;

            # append current timestamp to each flv
            record_unique on;

            # publish only from localhost
            allow publish 127.0.0.1;
            deny publish all;

            #allow play all;
        }

        # Transcoding (ffmpeg needed)
        application big {
            live on;

            # On every pusblished stream run this command (ffmpeg)
            # with substitutions: $app/${app}, $name/${name} for application & stream name.
            #
            # This ffmpeg call receives stream from this application &
            # reduces the resolution down to 32x32. The stream is the published to
            # 'small' application (see below) under the same name.
            #
            # ffmpeg can do anything with the stream like video/audio
            # transcoding, resizing, altering container/codec params etc
            #
            # Multiple exec lines can be specified.

            exec ffmpeg -re -i rtmp://localhost:1935/$app/$name -vcodec flv -acodec copy -s 32x32 -f flv rtmp://localhost:1935/small/${name};
        }

        application small {
            live on;
            # Video with reduced resolution comes here from ffmpeg
        }

        application webcam {
            live on;

            # Stream from local webcam
            exec_static ffmpeg -f video4linux2 -i /dev/video0 -c:v libx264 -an -f flv rtmp://localhost:1935/webcam/mystream;
        }

        application mypush {
            live on;

            # Every stream published here
            # is automatically pushed to 
            # these two machines
            push rtmp1.example.com;
            push rtmp2.example.com:1934;
        }

        application mypull {
            live on;

            # Pull all streams from remote machine
            # and play locally
            pull rtmp://rtmp3.example.com pageUrl=www.example.com/index.html;
        }
        
        application mystaticpull {
            live on;

            # Static pull is started at nginx start
            pull rtmp://rtmp4.example.com pageUrl=www.example.com/index.html name=mystream static;
        }

        # video on demand
        application vod {
            play /var/flvs;
        }

        application vod2 {
            play /var/mp4s;
        }

        # Many publishers, many subscribers
        # no checks, no recording
        application videochat {

            live on;

            # The following notifications receive all 
            # the session variables as well as 
            # particular call arguments in HTTP POST
            # request

            # Make HTTP request & use HTTP retcode
            # to decide whether to allow publishing
            # from this connection or not
            on_publish http://localhost:8080/publish;

            # Same with playing
            on_play http://localhost:8080/play;

            # Publish/play end (repeats on disconnect)
            on_done http://localhost:8080/done;

            # All above mentioned notifications receive
            # standard connect() arguments as well as 
            # play/publish ones. If any arguments are sent
            # with GET-style syntax to play & publish
            # these are also included.
            # Example URL:
            #   rtmp://localhost/myapp/mystream?a=b&c=d

            # record 10 video keyframes (no audio) every 2 minutes
            record keyframes;
            record_path /tmp/vc;
            record_max_frames 10;
            record_interval 2m;

            # Async notify about an flv recorded
            on_record_done http://localhost:8080/record_done;

        }


        # HLS

        # For HLS to work please create a directory in tmpfs (/tmp/app here)
        # for the fragments. The directory contents is served via HTTP (see
        # http{} section in config)
        #
        # Incoming stream must be in H264/AAC/MP3. For iPhones use baseline H264
        # profile (see ffmpeg example).
        # This example creates RTMP stream from movie ready for HLS:
        #
        # ffmpeg -loglevel verbose -re -i movie.avi  -vcodec libx264 
        #    -vprofile baseline -acodec libmp3lame -ar 44100 -ac 1 
        #    -f flv rtmp://localhost:1935/hls/movie
        #
        # If you need to transcode live stream use 'exec' feature.
        #
        application hls {
            live on;
            hls on;
            hls_path /tmp/app;
            hls_fragment 5s;
        }

    }
}

# HTTP can be used for accessing RTMP stats
http {

    server {

        listen      8080;

        # This URL provides RTMP statistics in XML
        location /stat {
            rtmp_stat all;

            # Use this stylesheet to view XML as web page
            # in browser
            rtmp_stat_stylesheet stat.xsl;
        }

        location /stat.xsl {
            # XML stylesheet to view RTMP stats.
            # Copy stat.xsl wherever you want
            # and put the full directory path here
            root /path/to/stat.xsl/;
        }

        location /hls {
            # Serve HLS fragments
            types {
                application/vnd.apple.mpegurl m3u8;
            }
            alias /tmp/app;
            expires -1;
        }

    }
}

Multi-worker streaming example

rtmp_auto_push on;

rtmp {

    server {

        listen 1935;

        chunk_size 4000;

        # TV mode: one publisher, many subscribers
        application mytv {
            live on;
        }
    }
}