sudo yum localinstall --nogpgcheck https://download1.rpmfusion.org/free/el/rpmfusion-free-release-7.noarch.rpm https://download1.rpmfusion.org/nonfree/el/rpmfusion-nonfree-release-7.noarch.rpm yum -y install ffmpeg
yum -y install gcc openssl-devel pcre-devel zlib-devel
//方式一:git命令下載 git clone https://github.com/arut/nginx-rtmp-module.git //方式二:下載nginx-rtmp-module-1.2.0.tar.gz //解壓 tar -zxvf nginx-rtmp-module-1.2.0.tar.gz //重命名 mv nginx-rtmp-module-1.2.0 nginx-rtmp-module
tar zxvf nginx-1.14.2.tar.gz cd nginx-1.14.2/
./configure --prefix=/usr/local/nginx --add-module=../nginx-rtmp-module --with-http_ssl_module make make install
mkdir -p /mnt/share/html/hls
vim /usr/local/nginx/conf/nginx.conf #文件末尾追加 rtmp { server { listen 1935; #監聽的端口 chunk_size 4000; # rtmp推流請求路徑 application hls { live on; hls on; # 本地保存hlv格式文件 hls_path /mnt/share/html/hls; hls_fragment 10s; # 轉推[騰訊雲](https://l.gushuji.site/tencent) push rtmp://106630.livepush.myqcloud.com/live/rtsptest?txSecret=b8d28c20ab68f2467727b837eefcb4a2&txTime=5F140099; } } }
/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
/usr/local/nginx/sbin/nginx
ffmpeg -rtsp_transport tcp -i "rtsp://admin:1111aaaa@172.19.20.201:554/cam/realmonitor?channel=1&subtype=0" -vcodec copy -acodec aac -ar 44100 -strict -2 -ac 1 -f flv -s 4000x3000 -q 10 -f flv "rtmp://127.0.0.1:1935/hls"
注:若不加-rtsp_transport
可能會報 Could not find codec parameters for stream 0 (Video: h264, none)
錯誤,ffmpeg默認使用udp方式傳輸,在使用:avformat\_find\_stream\_info 會出現返回 codec\_id ==AV\_CODEC\_ID\_NONE 的狀況;html
若是id = none 的狀況在 打開解碼器的時候確定會報錯,因此在 執行 avformat\_find\_stream\_info 的時候有必要判斷一下視頻信息的有效性!nginx
在 avformat\_open\_input打開流地址以前 強制ffmpeg 以tcp傳輸 ,能夠解決上面返回 none的狀況。git
[aac @ 0x12fb900] Queue input is backward in time0:01:59.57 bitrate=4261.0kbits/s speed=0.934x [flv @ 0x12e37a0] Non-monotonous DTS in output stream 0:1; previous: 119622, current: 119605; changing to 119622. This may result in incorrect timestamps in the output file. [aac @ 0x12fb900] Queue input is backward in time0:02:14.50 bitrate=4266.0kbits/s speed=0.933x [flv @ 0x12e37a0] Non-monotonous DTS in output stream 0:1; previous: 134622, current: 134605; changing to 134622. This may result in incorrect timestamps in the output file. [aac @ 0x12fb900] Queue input is backward in time0:02:29.15 bitrate=4263.7kbits/s speed=0.932x [flv @ 0x12e37a0] Non-monotonous DTS in output stream 0:1; previous: 149621, current: 149606; changing to 149621. This may result in incorrect timestamps in the output file. [aac @ 0x12fb900] Queue input is backward in time0:02:44.50 bitrate=4267.9kbits/s speed=0.931x [flv @ 0x12e37a0] Non-monotonous DTS in output stream 0:1; previous: 164621, current: 164606; changing to 164621. This may result in incorrect timestamps in the output file. [flv @ 0x12e37a0] Failed to update header with correct duration.ate=4267.0kbits/s speed=0.93x [flv @ 0x12e37a0] Failed to update header with correct filesize. frame= 4333 fps= 23 q=-1.0 Lsize= 90306kB time=00:02:53.47 bitrate=4264.6kbits/s speed=0.931x video:86498kB audio:3599kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 0.231989% [aac @ 0x12fb900] Qavg: 1180.000 Exiting normally, received signal 2. [root@localhost hls]# ll 總用量 54324 -rw-r--r--. 1 nobody nobody 5484336 7月 16 07:03 live-10.ts -rw-r--r--. 1 nobody nobody 6584324 7月 16 07:03 live-11.ts -rw-r--r--. 1 nobody nobody 5495052 7月 16 07:03 live-12.ts -rw-r--r--. 1 nobody nobody 5491292 7月 16 07:04 live-13.ts -rw-r--r--. 1 nobody nobody 5482456 7月 16 07:04 live-14.ts -rw-r--r--. 1 nobody nobody 5491104 7月 16 07:04 live-15.ts -rw-r--r--. 1 nobody nobody 4022072 7月 16 07:04 live-16.ts -rw-r--r--. 1 nobody nobody 5485652 7月 16 07:02 live-7.ts -rw-r--r--. 1 nobody nobody 5487720 7月 16 07:03 live-8.ts -rw-r--r--. 1 nobody nobody 6585452 7月 16 07:03 live-9.ts -rw-r--r--. 1 nobody nobody 155 7月 16 07:04 live.m3u8
若是推送成功則能夠在流管理界面的狀態看到直播中的字樣。github
點擊操做中的測試則能夠看到攝像頭的直播畫面以下:vim