Created
May 9, 2017 11:03
-
-
Save alexcpn/b8867a719231be85615d024306f92e17 to your computer and use it in GitHub Desktop.
nginx configration for rtmp
This file contains 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
#user nobody; | |
worker_processes 1; | |
#error_log logs/error.log; | |
#error_log logs/error.log notice; | |
#error_log logs/error.log info; | |
#pid logs/nginx.pid; | |
events { | |
worker_connections 1024; | |
} | |
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/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 { | |
include mime.types; | |
default_type application/octet-stream; | |
#log_format main '$remote_addr - $remote_user [$time_local] "$request" ' | |
# '$status $body_bytes_sent "$http_referer" ' | |
# '"$http_user_agent" "$http_x_forwarded_for"'; | |
#access_log logs/access.log main; | |
sendfile on; | |
#tcp_nopush on; | |
#keepalive_timeout 0; | |
keepalive_timeout 65; | |
#gzip on; | |
server { | |
listen 80; | |
server_name localhost; | |
#charset koi8-r; | |
#access_log logs/host.access.log main; | |
location / { | |
root html; | |
index index.html index.htm; | |
} | |
#error_page 404 /404.html; | |
# redirect server error pages to the static page /50x.html | |
# | |
error_page 500 502 503 504 /50x.html; | |
location = /50x.html { | |
root html; | |
} | |
# 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; | |
} | |
# proxy the PHP scripts to Apache listening on 127.0.0.1:80 | |
# | |
#location ~ \.php$ { | |
# proxy_pass http://127.0.0.1; | |
#} | |
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000 | |
# | |
#location ~ \.php$ { | |
# root html; | |
# fastcgi_pass 127.0.0.1:9000; | |
# fastcgi_index index.php; | |
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; | |
# include fastcgi_params; | |
#} | |
# deny access to .htaccess files, if Apache's document root | |
# concurs with nginx's one | |
# | |
#location ~ /\.ht { | |
# deny all; | |
#} | |
} | |
# another virtual host using mix of IP-, name-, and port-based configuration | |
# | |
#server { | |
# listen 8000; | |
# listen somename:8080; | |
# server_name somename alias another.alias; | |
# location / { | |
# root html; | |
# index index.html index.htm; | |
# } | |
#} | |
# HTTPS server | |
# | |
#server { | |
# listen 443 ssl; | |
# server_name localhost; | |
# ssl_certificate cert.pem; | |
# ssl_certificate_key cert.key; | |
# ssl_session_cache shared:SSL:1m; | |
# ssl_session_timeout 5m; | |
# ssl_ciphers HIGH:!aNULL:!MD5; | |
# ssl_prefer_server_ciphers on; | |
# location / { | |
# root html; | |
# index index.html index.htm; | |
# } | |
#} | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment