การทำงานกับสื่อมักต้องมีการเปลี่ยนแปลงลักษณะของไฟล์สื่อ เช่น อัตราบิตหรือความละเอียด การค้นหาวิธีเริ่มต้นใช้งานที่ตรงไปตรงมาอาจเป็นเรื่องที่น่ากลัว ในหน้านี้ คุณจะได้ดูข้อมูลเกี่ยวกับเครื่องมือที่ใช้และวิธีติดตั้งเครื่องมืออย่างรวดเร็ว
ก่อนอื่น เราจะอธิบายการใช้งานพื้นฐานของยูทิลิตีสื่อบรรทัดคำสั่ง 2 รายการที่พบได้ทั่วไป ได้แก่ Shaka Packager และ FFmpeg จากนั้นเราจะช่วยให้คุณติดตั้งเครื่องมือได้อย่างรวดเร็ว เหตุผลที่ควรครอบคลุม 2 แอปพลิเคชัน แม้ว่าทั้ง 2 โปรแกรมจะมีประสิทธิภาพและมีประโยชน์ในตัวของมันเอง แต่ก็ไม่ได้มีทุกอย่างที่จำเป็นในการเตรียมสื่อสำหรับเว็บ นอกจากนี้ เรายังได้สร้างหน้าการเปลี่ยนรูปแบบสื่อและการเข้ารหัสสื่อ ซึ่งแสดงการดำเนินการทั่วไปอีกมากมายกับแอปพลิเคชัน 2 รายการนี้
แอปพลิเคชันเหล่านี้ไม่ใช่ตัวเลือกเดียวที่ใช้สำหรับงานการจัดการไฟล์ แต่เป็นแอปพลิเคชันที่พบบ่อยและมีประสิทธิภาพมากที่สุด 2 รายการ ตัวเลือกอื่นๆ ได้แก่ แอปพลิเคชัน GUI Miro, HandBrake และ VLC นอกจากนี้ ยังมีบริการเข้ารหัส/แปลงรหัส เช่น Zencoder, Amazon Elastic Encoder และ Google Transcoder API
ชาคา Packager
Shaka Packager เป็น SDK การจัดแพ็กเกจสื่อแบบไม่มีค่าใช้จ่าย หากใช้โปรแกรมเล่นสื่อในเว็บไซต์ คุณจะใช้ Shaka Packager เพื่อเตรียมไฟล์ โดยรองรับการแปลงสำหรับโปรโตคอลสตรีมมิงวิดีโอ 2 รายการที่ใช้กันมากที่สุด ได้แก่ การสตรีมที่ปรับเปลี่ยนได้แบบไดนามิกผ่าน HTTP (DASH) หรือ HTTP Live Streaming (HLS) Shaka Packager รองรับฟีเจอร์ความปลอดภัยที่สำคัญ ได้แก่ การเข้ารหัสทั่วไปและการจัดการสิทธิ์ดิจิทัล (DRM) ของ Widevine รวมถึงจัดการสตรีมมิงแบบสดและวิดีโอออนดีมานด์ได้ด้วย
ยูทิลิตีนี้ไม่ได้มีไว้สำหรับนักพัฒนาซอฟต์แวร์ C++ เท่านั้น คุณสามารถใช้ทั้งเป็นไลบรารีสำหรับสร้างซอฟต์แวร์สื่อและยูทิลิตีบรรทัดคำสั่งสำหรับเตรียมไฟล์สื่อสำหรับการเล่นบนเว็บ แต่คือความสามารถอย่างหลัง ที่มีประโยชน์สำหรับเราที่นี่ แท้จริงแล้ว Shaka Packager เป็นวิธีเดียวที่นักสร้างสื่อบนเว็บจะทำบางงานได้โดยไม่ต้องเสียเงินไปกับแอปพลิเคชันเชิงพาณิชย์ราคาแพง
รูปแบบพื้นฐานของคำสั่ง Shaka Packager มีดังนี้
packager stream_descriptor [stream_descriptor-2 [stream_descriptor-n]] [flags]
คุณจะไม่ได้แสดงสิ่งนี้หากพิมพ์ packager -help
ตัวอย่างนี้อธิบายเหตุผลได้ง่ายกว่า และก็แสดงให้เห็นถึงตัวอย่างในเอกสารประกอบของ Shaka Packager โปรดทราบว่ามีstream_descriptor
รายการหลายรายการในลวดลาย แม้ว่าเราจะไม่ได้แสดง แต่คุณสามารถจัดการสตรีมวิดีโอและสตรีมเสียงของไฟล์แยกกันในคำสั่งเดียว
เปรียบเทียบรูปแบบพื้นฐานนี้กับการใช้งานแบบง่ายที่แสดงลักษณะของไฟล์ ในตัวอย่างนี้ เราได้จัดเรียงส่วนที่เทียบเท่าไว้ด้วยกัน
packager stream_descriptor [stream_descriptor-n] [flags]
packager input=glocken.mp4 --dump_stream_info
คำสั่งจะแสดงผลลัพธ์ดังนี้
File "glocken.mp4":
Found 2 stream(s).
Stream [0] type: Video
codec_string: avc1.640028
time_scale: 30000
duration: 300300 (10.0 seconds)
is_encrypted: false
codec: H264
width: 1920
height: 1080
pixel_aspect_ratio: 1:1
trick_play_factor: 0
nalu_length_size: 4
Stream [1] type: Audio
codec_string: mp4a.40.2
time_scale: 48000
duration: 481280 (10.0 seconds)
is_encrypted: false
codec: AAC
sample_bits: 16
num_channels: 2
sampling_frequency: 48000
language: eng
seek_preroll_ns: 20833
มองหาลักษณะที่กล่าวถึงในข้อมูลเบื้องต้นเกี่ยวกับไฟล์สื่อ และสังเกตสิ่งต่อไปนี้ ความสูงและความกว้างเป็นความละเอียดที่ถูกต้องสำหรับ Full HD และตัวแปลงรหัสเสียงและวิดีโอก็เป็นหนึ่งในตัวแปลงรหัสที่ควรใช้สำหรับประเภทคอนเทนเนอร์ ได้แก่ AAC สำหรับเสียง และ H264 สำหรับวิดีโอ และโปรดทราบว่าระบบจะระบุสตรีมด้วยตัวเลข ซึ่งมีประโยชน์สำหรับการดำเนินการที่จัดการเสียงและวิดีโอแยกกัน
โปรดทราบว่าเอาต์พุตด้านบนไม่ได้แสดงอัตราบิต แม้ว่าจะไม่มีข้อมูลบางอย่าง แต่เอาต์พุตนี้อ่านง่ายกว่า เราจึงใช้เมื่อใดก็ตามที่ทำได้ เมื่อต้องการข้อมูลที่ซ่าคาแพ็กเกอร์ไม่สามารถรับได้ เช่น อัตราบิต เราจะใช้ FFmpeg
FFmpeg
นอกจากนี้ FFmpeg ยังเป็นแอปพลิเคชันฟรีสำหรับการบันทึก แปลง และสตรีมไฟล์สื่อ ความสามารถของเครื่องมือนี้ไม่ได้ดีกว่าหรือแย่กว่าของ Shaka Packager เพียงแค่แตกต่างกัน
รูปแบบพื้นฐานของคำสั่ง FFmpeg จะมีลักษณะดังนี้
ffmpeg [GeneralOptions] [InputFileOptions] -i input [OutputFileOptions] output
แอปพลิเคชันนี้จัดการสตรีมได้หลายรายการเช่นเดียวกับ Shaka Packager ตัวเลือกบางรายการมีการใช้งานในตำแหน่งต่างๆ ที่หลากหลาย และจัดการเอาต์พุตของไฟล์ให้แตกต่างกันโดยขึ้นอยู่กับว่าอยู่ตรงไหนในคำสั่ง โปรดระมัดระวังเรื่องนี้ขณะที่คุณดูคำถาม FFmpeg ใน Stack Overflow และเว็บไซต์ที่คล้ายกัน
เราจะเปรียบเทียบรูปแบบพื้นฐานกับตัวอย่างอีกครั้งเพื่อแสดงลักษณะของไฟล์
ffmpeg [GeneralOptions] [InputFileOptions] -i input [OutputFileOptions] output
ffmpeg -i glocken.mp4
นอกจากข้อมูลที่เราร้องขอแล้ว ยังพิมพ์ข้อความแสดงข้อผิดพลาดดังที่แสดงในตัวอย่างด้านล่างด้วย เพราะในทางเทคนิคแล้ว นี่เป็นการใช้งาน FFmpeg ที่ไม่ถูกต้อง เราใช้แอปนี้เนื่องจากแสดงข้อมูลที่สนใจ
Input #0, mov,mp4,m4a,3gp,3g2,mj2, from 'glocken.mp4':
Metadata:
major_brand : isom
minor_version : 512
compatible_brands: isomiso2avc1mp41
encoder : Lavf58.17.100
Duration: 00:01:47.53, start: 0.000000, bitrate: 10715 kb/s
Stream #0:0(eng): Video: h264 (High) (avc1 / 0x31637661), yuvj420p(pc), 1920x1080, 10579 kb/s, 29.97 fps, 29.97 tbr, 30k tbn, 59.94 tbc (default)
Metadata:
handler_name : VideoHandler
Stream #0:1(eng): Audio: aac (LC) (mp4a / 0x6134706D), 48000 Hz, stereo, fltp, 128 kb/s (default)
Metadata:
handler_name : SoundHandler
At least one output file must be specified
การติดตั้งแอปพลิเคชันด้วย Docker
หากต้องการทําตามและลองใช้คําสั่งของเรา คุณสามารถติดตั้งเครื่องมือที่จําเป็นด้วยตนเอง หรือใช้เส้นทางที่ง่ายขึ้นด้วย Docker เราขอแนะนําให้ใช้ Docker เนื่องจากจะช่วยประหยัดเวลาได้มาก นอกเหนือจากนั้น เรายังได้มอบ คำแนะนำเพื่อให้คุณตั้งค่าได้อย่างรวดเร็ว
เริ่มด้วยการสร้างไดเรกทอรีใหม่ไว้ที่อื่นในคอมพิวเตอร์ของคุณที่ชื่อว่า
media-tools
คุณสามารถใช้ชื่อใดก็ได้ตามต้องการ แต่โปรดทราบว่าวิธีการต่อไปนี้สมมติว่าคุณใช้media-tools
เป็นชื่อไดเรกทอรีสร้างไดเรกทอรี
docker
และmedia
ภายในmedia-tools
ซึ่งจะทำให้ไดเรกทอรีmedia
ของคุณไม่อยู่ในบริบทการสร้าง การดำเนินการนี้สำคัญเนื่องจากmedia
คือที่เก็บไฟล์ที่เราวางแผนจะดำเนินการ และไฟล์บางไฟล์อาจมีขนาดใหญ่ การวางDockerfile
ในmedia-tools
โดยตรงจะทำให้การสร้างอิมเมจช้าลงหากคุณสร้างอิมเมจอีกครั้งในอนาคต เช่น เพื่อเปลี่ยนเวอร์ชันที่ติดตั้งสร้าง
/media-tools/docker/Dockerfile
และเพิ่มวิธีการสร้างต่อไปนี้FROM google/shaka-packager:release-v2.4.3 as packager FROM jrottenberg/ffmpeg:4.3.2-alpine38 COPY --from=packager /usr/bin /usr/bin ENTRYPOINT ["sh"]
สร้างอิมเมจโดยใช้คำสั่งต่อไปนี้
docker build -t media-tools ./docker
เรียกใช้อิมเมจเป็นเชลล์แบบอินเทอร์แอกทีฟ บน Linux:
docker run -w /media -v ${PWD}/media:/media -it --rm media-tools /media #
บน Windows:
docker run -w /media -v %cd%/media:/media -it --rm media-tools /media #
ขณะที่เรียกใช้อิมเมจ คุณสามารถตรวจสอบเวอร์ชันของทั้ง FFmpeg และ Shaka Packager เพื่อตรวจสอบว่าทุกอย่างสำเร็จด้วยการเรียกใช้ ffmpeg -version
และ packager --version
เอาต์พุตควรมีลักษณะดังนี้
/media # ffmpeg -version
ffmpeg version 4.3.2 Copyright (c) 2000-2021 the FFmpeg developers
built with gcc 6.4.0 (Alpine 6.4.0)
configuration: --disable-debug --disable-doc --disable-ffplay --enable-shared --enable-avresample --enable-libopencore-amrnb --enable-libopencore-amrwb --enable-gpl --enable-libass --enable-fontconfig --enable-libfreetype --enable-libvidstab --enable-libmp3lame --enable-libopus --enable-libtheora --enable-libvorbis --enable-libvpx --enable-libwebp --enable-libxcb --enable-libx265 --enable-libxvid --enable-libx264 --enable-nonfree --enable-openssl --enable-libfdk_aac --enable-postproc --enable-small --enable-version3 --enable-libbluray --enable-libzmq --extra-libs=-ldl --prefix=/opt/ffmpeg --enable-libopenjpeg --enable-libkvazaar --enable-libaom --extra-libs=-lpthread --enable-libsrt --enable-libaribb24 --extra-cflags=-I/opt/ffmpeg/include --extra-ldflags=-L/opt/ffmpeg/lib
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
libavresample 4. 0. 0 / 4. 0. 0
libswscale 5. 7.100 / 5. 7.100
libswresample 3. 7.100 / 3. 7.100
libpostproc 55. 7.100 / 55. 7.100
/media # packager --version
packager version v2.4.3-dd9870075f-release
เมื่อลองใช้ Shaka Packager และ FFmpeg แล้ว คุณสามารถศึกษาแนวคิดพื้นฐานต่อได้ โดยหัวข้อถัดไปคือพื้นฐานสตรีมมิงสื่อ