Last active
December 7, 2023 21:50
-
-
Save MasterAler/48e283e8f01d068c3c072179a8fdee09 to your computer and use it in GitHub Desktop.
Minimal recipe for rtsp-simple-server
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
############################################### | |
# General parameters | |
# Sets the verbosity of the program; available values are "error", "warn", "info", "debug". | |
logLevel: debug | |
# Destinations of log messages; available values are "stdout", "file" and "syslog". | |
logDestinations: [stdout] | |
# If "file" is in logDestinations, this is the file which will receive the logs. | |
logFile: rtsp-simple-server.log | |
# Timeout of read operations. | |
readTimeout: 10s | |
# Timeout of write operations. | |
writeTimeout: 10s | |
# Number of read buffers. | |
# A higher number allows a wider throughput, a lower number allows to save RAM. | |
readBufferCount: 512 | |
# HTTP URL to perform external authentication. | |
# Every time a user wants to authenticate, the server calls this URL | |
# with the POST method and a body containing: | |
# { | |
# "ip": "ip", | |
# "user": "user", | |
# "password": "password", | |
# "path": "path", | |
# "action": "read|publish" | |
# "query": "url's raw query" | |
# } | |
# If the response code is 20x, authentication is accepted, otherwise | |
# it is discarded. | |
externalAuthenticationURL: | |
# Enable the HTTP API. | |
api: no | |
# Address of the API listener. | |
apiAddress: 127.0.0.1:9997 | |
# Enable Prometheus-compatible metrics. | |
metrics: no | |
# Address of the metrics listener. | |
metricsAddress: 127.0.0.1:9998 | |
# Enable pprof-compatible endpoint to monitor performances. | |
pprof: no | |
# Address of the pprof listener. | |
pprofAddress: 127.0.0.1:9999 | |
# Command to run when a client connects to the server. | |
# This is terminated with SIGINT when a client disconnects from the server. | |
# The following environment variables are available: | |
# * RTSP_PORT: server port | |
runOnConnect: | |
# Restart the command if it exits suddenly. | |
runOnConnectRestart: no | |
############################################### | |
# RTSP parameters | |
# Disable support for the RTSP protocol. | |
rtspDisable: no | |
# List of enabled RTSP transport protocols. | |
# UDP is the most performant, but doesn't work when there's a NAT/firewall between | |
# server and clients, and doesn't support encryption. | |
# UDP-multicast allows to save bandwidth when clients are all in the same LAN. | |
# TCP is the most versatile, and does support encryption. | |
# The handshake is always performed with TCP. | |
protocols: [udp, multicast, tcp] | |
# Encrypt handshakes and TCP streams with TLS (RTSPS). | |
# Available values are "no", "strict", "optional". | |
encryption: "no" | |
# Address of the TCP/RTSP listener. This is needed only when encryption is "no" or "optional". | |
rtspAddress: 172.11.22.44:8554 | |
# Address of the TCP/TLS/RTSPS listener. This is needed only when encryption is "strict" or "optional". | |
rtspsAddress: :8322 | |
# Address of the UDP/RTP listener. This is needed only when "udp" is in protocols. | |
rtpAddress: :8000 | |
# Address of the UDP/RTCP listener. This is needed only when "udp" is in protocols. | |
rtcpAddress: :8001 | |
# IP range of all UDP-multicast listeners. This is needed only when "multicast" is in protocols. | |
multicastIPRange: 224.1.0.0/16 | |
# Port of all UDP-multicast/RTP listeners. This is needed only when "multicast" is in protocols. | |
multicastRTPPort: 8002 | |
# Port of all UDP-multicast/RTCP listeners. This is needed only when "multicast" is in protocols. | |
multicastRTCPPort: 8003 | |
# Path to the server key. This is needed only when encryption is "strict" or "optional". | |
# This can be generated with: | |
# openssl genrsa -out server.key 2048 | |
# openssl req -new -x509 -sha256 -key server.key -out server.crt -days 3650 | |
serverKey: server.key | |
# Path to the server certificate. This is needed only when encryption is "strict" or "optional". | |
serverCert: server.crt | |
# Authentication methods. | |
authMethods: [basic, digest] | |
############################################### | |
# RTMP parameters | |
# Disable support for the RTMP protocol. | |
rtmpDisable: no | |
# Address of the RTMP listener. This is needed only when encryption is "no" or "optional". | |
rtmpAddress: :1950 | |
# Encrypt connections with TLS (RTMPS). | |
# Available values are "no", "strict", "optional". | |
rtmpEncryption: "no" | |
# Address of the RTMPS listener. This is needed only when encryption is "strict" or "optional". | |
rtmpsAddress: :1951 | |
# Path to the server key. This is needed only when encryption is "strict" or "optional". | |
# This can be generated with: | |
# openssl genrsa -out server.key 2048 | |
# openssl req -new -x509 -sha256 -key server.key -out server.crt -days 3650 | |
rtmpServerKey: server.key | |
# Path to the server certificate. This is needed only when encryption is "strict" or "optional". | |
rtmpServerCert: server.crt | |
############################################### | |
# HLS parameters | |
# Disable support for the HLS protocol. | |
hlsDisable: no | |
# Address of the HLS listener. | |
hlsAddress: :8888 | |
# By default, HLS is generated only when requested by a user. | |
# This option allows to generate it always, avoiding the delay between request and generation. | |
hlsAlwaysRemux: no | |
# Variant of the HLS protocol to use. Available options are: | |
# * mpegts - uses MPEG-TS segments, for maximum compatibility. | |
# * fmp4 - uses fragmented MP4 segments, more efficient. | |
# * lowLatency - uses Low-Latency HLS. | |
hlsVariant: mpegts | |
# Number of HLS segments to keep on the server. | |
# Segments allow to seek through the stream. | |
# Their number doesn't influence latency. | |
hlsSegmentCount: 7 | |
# Minimum duration of each segment. | |
# A player usually puts 3 segments in a buffer before reproducing the stream. | |
# The final segment duration is also influenced by the interval between IDR frames, | |
# since the server changes the duration in order to include at least one IDR frame | |
# in each segment. | |
hlsSegmentDuration: 1s | |
# Minimum duration of each part. | |
# A player usually puts 3 parts in a buffer before reproducing the stream. | |
# Parts are used in Low-Latency HLS in place of segments. | |
# Part duration is influenced by the distance between video/audio samples | |
# and is adjusted in order to produce segments with a similar duration. | |
hlsPartDuration: 200ms | |
# Maximum size of each segment. | |
# This prevents RAM exhaustion. | |
hlsSegmentMaxSize: 50M | |
# Value of the Access-Control-Allow-Origin header provided in every HTTP response. | |
# This allows to play the HLS stream from an external website. | |
hlsAllowOrigin: '*' | |
# Enable TLS/HTTPS on the HLS server. | |
# This is required for Low-Latency HLS. | |
hlsEncryption: no | |
# Path to the server key. This is needed only when encryption is yes. | |
# This can be generated with: | |
# openssl genrsa -out server.key 2048 | |
# openssl req -new -x509 -sha256 -key server.key -out server.crt -days 3650 | |
hlsServerKey: server.key | |
# Path to the server certificate. | |
hlsServerCert: server.crt | |
# List of IPs or CIDRs of proxies behind the HLS server. | |
# If the server receives a request from one of these entries, IP in logs | |
# will be taken from the X-Forwarded-For header. | |
hlsTrustedProxies: [] | |
############################################### | |
# Path parameters | |
# These settings are path-dependent, and the map key is the name of the path. | |
# It's possible to use regular expressions by using a tilde as prefix. | |
# For example, "~^(test1|test2)$" will match both "test1" and "test2". | |
# For example, "~^prefix" will match all paths that start with "prefix". | |
# The settings under the path "all" are applied to all paths that do not match | |
# another entry. | |
paths: | |
lol: | |
ondemand: | |
runOnDemand: ffmpeg -re -stream_loop -1 -i /mnt/2tb/school.flv -c copy -f rtsp -rtsp_transport tcp rtsp://localhost:$RTSP_PORT/$RTSP_PATH | |
runOnDemandRestart: yes | |
ondemand2: | |
runOnDemand: ffmpeg -re -i /mnt/2tb/cctv2_36_sec.mp4 -c copy -f rtsp -rtsp_transport tcp rtsp://localhost:$RTSP_PORT/$RTSP_PATH | |
runOnDemandRestart: no |
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
#!/bin/bash | |
ffmpeg -re -stream_loop -1 -i sample.flv -f rtsp -rtsp_transport tcp rtsp://172.11.22.44:8554/lol |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment