我试图通过在单独的服务器(CentOS 7.1)上运行的ffserver,从Logroidch C920网络摄像头实时播放来自Logitech C920网络摄像头的原生.H264网络摄像头,以及用户'没有重新连接.H264视频源的浏览器。
在浏览器中添加实时视频源本身就是一项挑战,所以现在我只想让Odroid上的Logitech C920网络摄像头通过ffserver将其原生的.H264实时视频源流式传输为mp4用户无需在此过程中重新编码视频。 显然,我想避免重新编码,因为这会花费太多CPU时间并且会杀死实时视频源。稍后我可能需要将容器更改为.flv或rtp,因此可以通过浏览器以实时方式播放。我使用的是Logitech C920网络摄像头,因为它可以在硬件上进行.H264编码。 (它已通过直接保存文件进行测试,除了与Linux内核错误相关的众所周知的“急躁”问题之外,它有效:http://sourceforge.net/p/linux-uvc/mailman/message/33164469/,但这是一个不同的故事)
问题是,然而我设置了ffmpeg-ffserver,只要ffserver在图片中,feed就会重新编码 - 甚至从h264(本机)到h264(libx264) - 在Odroid上占用100%的CPU设备并在视频输入中引入了巨大的延迟。
以下是我的ffmpeg和ffserver设置。
来自Odroid设备的Ffmpeg将.H264 Feed流式传输到ffserver
$ ffmpeg -s 1920x1080 -f v4l2 -vcodec h264 -i /dev/video0 -copyinkf -vcodec copy http://xxxyyyy.com:8090/feed1.ffm
ffmpeg version N-72744-g653bf3c Copyright (c) 2000-2015 the FFmpeg developers
built with gcc 4.8 (Ubuntu/Linaro 4.8.2-19ubuntu1)
configuration: --prefix=/home/odroid/ffmpeg_build --pkg-config-flags=--static --extra-cflags=-I/home/odroid/ffmpeg_build/include --extra-ldflags=-L/home/odroid/ffmpeg_build/lib --bindir=/home/odroid/bin --enable-gpl --enable-libass --enable-libfdk-aac --enable-libfreetype --enable-libmp3lame --enable-libopus --enable-libtheora --enable-libvorbis --enable-libvpx --enable-libx264 --enable-libx265 --enable-nonfree
libavutil 54. 27.100 / 54. 27.100
libavcodec 56. 41.100 / 56. 41.100
libavformat 56. 36.100 / 56. 36.100
libavdevice 56. 4.100 / 56. 4.100
libavfilter 5. 16.101 / 5. 16.101
libswscale 3. 1.101 / 3. 1.101
libswresample 1. 2.100 / 1. 2.100
libpostproc 53. 3.100 / 53. 3.100
Input #0, video4linux2,v4l2, from '/dev/video0':
Duration: N/A, start: 6581.606726, bitrate: N/A
Stream #0:0: Video: h264 (Constrained Baseline), yuvj420p(pc), 1920x1080 [SAR 1:1 DAR 16:9], -5 kb/s, 30 fps, 30 tbr, 1000k tbn, 60 tbc
[swscaler @ 0x11bf0b0] deprecated pixel format used, make sure you did set range correctly
No pixel format specified, yuvj420p for H.264 encoding chosen.
Use -pix_fmt yuv420p for compatibility with outdated media players.
[libx264 @ 0x12590e0] using SAR=64/45
[libx264 @ 0x12590e0] using cpu capabilities: ARMv6 NEON
[libx264 @ 0x12590e0] profile High, level 1b
Output #0, ffm, to 'http://robo-car.int.thomsonreuters.com:8090/feed1.ffm':
Metadata:
creation_time : now
encoder : Lavf56.36.100
Stream #0:0: Video: h264 (libx264), yuvj420p(pc), 160x128 [SAR 64:45 DAR 16:9], q=-1--1, 64 kb/s, 30 fps, 1000k tbn, 5 tbc
Metadata:
encoder : Lavc56.41.100 libx264
Stream mapping:
Stream #0:0 -> #0:0 (h264 (native) -> h264 (libx264))
Press [q] to stop, [?] for help
^Cav_interleaved_write_frame(): Immediate exit requested00 bitrate=N/A dup=0 drop=97
Last message repeated 2140 times
frame= 3723 fps=301 q=-1.0 Lsize= 396kB time=00:12:14.20 bitrate= 4.4kbits/s dup=3699 drop=103
video:321kB audio:0kB subtitle:0kB other streams:0kB global headers:0kB muxing overhead: 23.500496%
运行ffserver的服务器上的/etc/ffserver.conf:
HTTPPort 8090 # Port to bind the server to
HTTPBindAddress 0.0.0.0
MaxHTTPConnections 2000
MaxClients 1000
MaxBandwidth 10000 # Maximum bandwidth per client
# set this high enough to exceed stream bitrate
CustomLog -
<Feed feed1.ffm> # This is the input feed where FFmpeg will send
File ./feed1.ffm # video stream.
FileMaxSize 1G # Maximum file size for buffering video
</Feed>
<Stream test.mp4>
Feed feed1.ffm
Format mp4
NoAudio
</Stream>
正如您在上面的ffmpeg部分所看到的,Odroid设备上发生了重新编码,最大限度地减少了CPU:
Stream mapping:
Stream #0:0 -> #0:0 (h264 (native) -> h264 (libx264))
我已经尝试将ffserver配置中的VideoCodec值直接设置为libx264,尝试使用ffmpeg中的-re设置,尝试使用ffmpeg的不同语法等。没有任何帮助。 Reeconding始终存在,因此我无法使ffmpeg-ffserver按原样播放视频流。
ffmpeg(在Odroid和服务器上)都是昨天(2015-06-09)从源代码编译的,因此它们是最新的(和相同的)版本。
有什么想法吗?
编辑: 摘要问题是:我无法找到一种方法让ffserver广播来自Logitech C920网络摄像头的h264(本机)源,而无需重新编码。
答案 0 :(得分:4)
嗯,这不是一个真正的答案,但我设法通过切换到vlc来做到这一点。不幸的是我没有设法让ffserver接受传入的.H264流,而不重新编码它,即使我有,我仍然会遇到ffmpeg-C920-linux内核回归的问题:{{ 3}}
因此放弃ffmpeg-ffserver行并尝试vlc似乎是合理的。
如果有其他人感兴趣,有了vlc,我设法通过运行以下命令来实现C920网络摄像头原生.H264 Feed的非重新编码分发:
在Odroid设备上,这将从凸轮和
中选取.H264流streams it via http in mpeg-ts:
cvlc v4l2:///dev/video0:chroma=h264:width=1920:height=1080 --sout '#standard{access=http,mux=ts,dst=[ip of odroid]:8080,name=stream,mime=video/ts}' -vvv
在CentOS 7服务器上,下面从Odroid获取流并对其进行多播,因此消费者可以连接到它,而不是尝试连接到具有更多有限带宽(wifi)的Odroid设备:
vlc http://[ip of odroid]:8080 --sout '#standard{access=http,mux=ts,dst=[ip of centos server]:8080,name=stream,mime=video/ts}' -vvv
现在,我可以通过设备上的VLC播放器实时播放此流:
http://[ip of centos server]:8080
但是,是的,这不是原始ffmpeg-ffserver问题的真正解决方案,而是使用vlc解决方法。
答案 1 :(得分:1)
我在配置中注意到的另一件事是您在libx264 - "libx264 @ 0x12590e0] profile High, level 1b"
尝试将配置文件设置为baseline or main
,这将大大降低CPU开销。高模式用于编码蓝光光盘等内容。
答案 2 :(得分:0)
您可以删除-vcodec h264
,因为我看到您提到两个视频编解码器-vcodec h264
并再次提到-vcodec copy
。还有一件事ffserver不支持mp4
的流式传输。尝试将其转换为webm
或flv
。见Begin stream simple mp4 with ffserver