Last active
November 6, 2015 14:59
-
-
Save kitlabcode/6a3016cd93398717fe81 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| rtmp { | |
| server { | |
| listen 1935; | |
| chunk_size 4000; | |
| # TV mode: one publisher, many subscribers | |
| application tv { | |
| # 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 | |
| } | |
| # video on demand | |
| application vod { | |
| play /var/flvs; | |
| } | |
| application vod2 { | |
| play /var/mp4s; | |
| } | |
| # HLS | |
| # For HLS to work please create a directory in tmpfs (/tmp/hls here) | |
| # for the fragments. The directory contents is served via HTTP (see | |
| # http{} section in config) | |
| # | |
| # Incoming stream must be in H264/AAC. 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/hls; | |
| } | |
| # MPEG-DASH is similar to HLS | |
| application dash { | |
| live on; | |
| dash on; | |
| dash_path /tmp/dash; | |
| } | |
| } | |
| } | |
| # 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; | |
| video/mp2t ts; | |
| } | |
| root /tmp; | |
| add_header Cache-Control no-cache; | |
| } | |
| location /dash { | |
| # Serve DASH fragments | |
| root /tmp; | |
| add_header Cache-Control no-cache; | |
| } | |
| } | |
| } |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment