질문:/dev/shm
비디오를 디렉터리 로 스트리밍하는 FFmpeg 명령을 몇 달 동안 실행해 왔습니다 . 최근까지(예: 일주일 이내) 잘 작동했지만 지금은 권한 문제가 발생하고 있습니다.
주문하다:
ffmpeg -threads 2 -video_size 640x480 -i /dev/video2 -c:v libx264 -f dash -streaming 1 /dev/shm/manifest.mpd
이는 정확한 명령은 아니지만(간결함을 위해 짝을 이룬 경우) 결과는 동일합니다.
libGL error: No matching fbConfigs or visuals found
libGL error: failed to load driver: swrast
X Error: GLXBadContext
Request Major code 151 (GLX)
Request Minor code 6 ()
Error Serial #57
Current Serial #56
ffmpeg version n4.3.1 Copyright (c) 2000-2020 the FFmpeg developers
built with gcc 7 (Ubuntu 7.5.0-3ubuntu1~18.04)
configuration: --prefix= --prefix=/usr --disable-debug --disable-doc --disable-static --enable-cuda --enable-cuda-sdk --enable-cuvid --enable-libdrm --enable-ffplay --enable-gnutls --enable-gpl --enable-libass --enable-libfdk-aac --enable-libfontconfig --enable-libfreetype --enable-libmp3lame --enable-libnpp --enable-libopencore_amrnb --enable-libopencore_amrwb --enable-libopus --enable-libpulse --enable-sdl2 --enable-libspeex --enable-libtheora --enable-libtwolame --enable-libv4l2 --enable-libvorbis --enable-libvpx --enable-libx264 --enable-libx265 --enable-libxcb --enable-libxvid --enable-nonfree --enable-nvenc --enable-omx --enable-openal --enable-opencl --enable-runtime-cpudetect --enable-shared --enable-vaapi --enable-vdpau --enable-version3 --enable-xlib
libavutil 56. 51.100 / 56. 51.100
libavcodec 58. 91.100 / 58. 91.100
libavformat 58. 45.100 / 58. 45.100
libavdevice 58. 10.100 / 58. 10.100
libavfilter 7. 85.100 / 7. 85.100
libswscale 5. 7.100 / 5. 7.100
libswresample 3. 7.100 / 3. 7.100
libpostproc 55. 7.100 / 55. 7.100
Input #0, video4linux2,v4l2, from '/dev/video2':
Duration: N/A, start: 1900.558740, bitrate: 147456 kb/s
Stream #0:0: Video: rawvideo (YUY2 / 0x32595559), yuyv422, 640x480, 147456 kb/s, 30 fps, 30 tbr, 1000k tbn, 1000k tbc
Stream mapping:
Stream #0:0 -> #0:0 (rawvideo (native) -> h264 (libx264))
Press [q] to stop, [?] for help
[libx264 @ 0x55b15d8912c0] using cpu capabilities: MMX2 SSE2Fast SSSE3 SSE4.2 AVX FMA3 BMI2 AVX2
[libx264 @ 0x55b15d8912c0] profile High 4:2:2, level 3.0, 4:2:2 8-bit
[libx264 @ 0x55b15d8912c0] 264 - core 152 r2854 e9a5903 - H.264/MPEG-4 AVC codec - Copyleft 2003-2017 - http://www.videolan.org/x264.html - options: cabac=1 ref=3 deblock=1:0:0 analyse=0x3:0x113 me=hex subme=7 psy=1 psy_rd=1.00:0.00 mixed_ref=1 me_range=16 chroma_me=1 trellis=1 8x8dct=1 cqm=0 deadzone=21,11 fast_pskip=1 chroma_qp_offset=-2 threads=12 lookahead_threads=2 sliced_threads=0 nr=0 decimate=1 interlaced=0 bluray_compat=0 constrained_intra=0 bframes=3 b_pyramid=2 b_adapt=1 b_bias=0 direct=1 weightb=1 open_gop=0 weightp=2 keyint=250 keyint_min=25 scenecut=40 intra_refresh=0 rc_lookahead=40 rc=crf mbtree=1 crf=23.0 qcomp=0.60 qpmin=0 qpmax=69 qpstep=4 ip_ratio=1.40 aq=1:1.00
[dash @ 0x55b15d88f600] No bit rate set for stream 0
[dash @ 0x55b15d88f600] Opening '/dev/shm/init-stream0.m4s' for writing
Could not write header for output file #0 (incorrect codec parameters ?): Permission denied
Error initializing output stream 0:0 --
Conversion failed!
(장문; 박사.:출력 파일 #0에 헤더를 쓸 수 없습니다(잘못된 코덱 매개변수?): 권한이 거부되었습니다.)
대조적으로, 이 명령 버전(홈 디렉터리에 쓰는)은 잘 작동합니다( /tmp/
또한 작동합니다).
ffmpeg -threads 2 -video_size 640x480 -i /dev/video2 -c:v libx264 -f dash -streaming 1 ~/manifest.mpd
위에서 언급했듯이 이상한 점은 (의도적으로) 무엇이든 변경하거나 앱을 변경할 수 있는 권한이 없다는 것입니다. 앱이 방금 작동을 멈춘 것 같습니다(나라는 것을 배제할 수는 없지만). 마지막으로 작동했던 것으로 기억하는 것은 아마도 일주일 전(~2021년 3월 20일)이었을 것입니다.
내가 시도한 것:
sudo ffmpeg...
ffmpeg를 sudo()로 실행- 결과:
sudo: ffmpeg: command not found
. 과거에는 이 작업이 필요하지 않았으며 출력은 이전과 동일합니다.
- 결과:
sudo sysctl fs.protected_regular=0
- 결과: 변화가 없습니다.
ffmpeg ...
다음과 같이 명령을 실행하십시오 .su
- 결과: 변화 없음
- chmod +777 /dev/shm
- 결과: 변경 사항이 없습니다(
ls -tls
디렉토리가 실제로 있음을 나타냄rwxrwxrwt
).
- 결과: 변경 사항이 없습니다(
- chown root:root 및 내 사용자 이름은 /dev/shm에 있습니다.
- 결과: 변화가 없습니다.
touch /dev/shm/test.txt
그리고sudo touch /dev/shm/test.txt
- 결과: 문제 없이 파일이 성공적으로 생성되었습니다.
이 작업을 수행하기 위한 권한과 관련하여 제가 생각할 수 있는 모든 것을 다 써봤습니다.
질문FFmpeg가 /dev/shm에 파일을 쓰도록 하려면 어떻게 해야 합니까? 이상적으로는 먼저 이런 일이 발생하는 이유를 파악하십시오.
이 문제를 진단하는 데 도움이 되도록 실행해야 하는 명령에 대한 아이디어가 있는 사람이 있으면 언제든지 의견을 추가해 주세요.
시스템 메시지:
- 커널: 4.19.0-14-amd64
- 배포판: 데비안
- FFmpeg: 버전 n4.3.1(중요한 경우 Snapd를 사용하여 설치)
==해결책==
불행히도 jsbilling을 사용한 솔루션은 작동하지 않지만 링크된 포럼 스레드에는 기본적으로 집에 디렉터리를 마운트 하고 거기에 ffmpeg 출력을 작성하여 쓰기 문제를 해결하는 snap.<snapname>.*
기사가 있습니다 ./dev/shm
~/stmp
$ mkdir ~/stmp/
$ sudo mount --bind /dev/shm/streaming_front/ ~/stmp/
...
$ ffmpeg -threads 2 -video_size 640x480 -i /dev/video2 -c:v libx264 -f dash -streaming 1 ./stmp/manifest.mpd
이는 이상적인 솔루션은 아니지만 실행 가능한 솔루션입니다.
답변1
스냅을 사용한다면,이 포럼 게시물/dev/shm의 파일이 특정 모드를 사용할 수 있음을 나타냅니다.
/dev/shm/snap.<snapname>.*
다른 포럼 회원이 이 해킹을 제안했지만 이는 기본적으로 보안 우회입니다.
$ mkdir /dev/shm/shared
$ mkdir ~/shmdir
$ sudo mount --bind /dev/shm/shared ~/shmdir
$ touch ~/shmdir/foo
$ ls /dev/shm/shared/
foo