Ubuntu上安装ffmpeg
简易安装方式
安装
sudo apt-get install ffmpeg
版本查看
ffmpeg -v
ffmpeg version 3.4.6-0ubuntu0.18.04.1 Copyright (c) 2000-2019 the FFmpeg developersbuilt with gcc 7 (Ubuntu 7.3.0-16ubuntu3)
卸载
此卸载方法只适用于刚刚那条简易安装指令,如果通过其他方法安装,该指令不适用。
sudo apt-get purge ffmpeg
以上安装方法有一个问题,就是ffmpeg版本很低(目前用该命令安装的ffmpeg为3.4.6),与官网最新稳定版差距很大(大版本已到4以上),在一些底层操作上可能会有出入,例如读取某个视频时就会出现两个版本读出来帧数不一致的问题。所以尽量还是从ffmpeg官网下载最新稳定版手动安装。
官网下载最新包安装
解压
tar -xvf ffmpeg_4.2.2.orig.tar.xz
安装yasm
sudo apt install -y yasm
设置编译项
基础选项:
./configure --enable-shared --prefix=/usr/local/ffmpeg
额外增加H264支持(可能需要额外安装,参考这里):
./configure --prefix=/usr/local/ffmpeg --enable-shared --disable-static --disable-doc --enable-gpl --enable-libx264
如果需要额外增加GPU(CUDA)加速支持,则需要在尾部增加:
--enable-cuda --enable-cuvid
同时下载并编译安装 FFmpeg NVIDIA headers (“ffnvcodec”):
git clone https://git.videolan.org/git/ffmpeg/nv-codec-headers.git
cd nv-codec-headers
(# 有多个分支,根据GPU驱动版本可能需要切换分支,如git checkout sdk/9.1)
make
sudo make install
否则编译ffmpeg时会报错“ERROR: cuvid requested, but not all dependencies are satisfied: cuda/ffnvcodec
”。
编译 安装
make
make install
建立软链接
sudo ln -s /usr/local/ffmpeg/bin/ffmpeg /usr/bin/ffmpeg
sudo ln -s /usr/local/ffmpeg/bin/ffprobe /usr/bin/ffprobe
配置ffmpeg依赖环境
sudo vi /etc/ld.so.conf
在其中添加路径:/usr/local/ffmpeg/libsudo ldconfig#更新环境变量
版本查看
ffmpeg -v
使用示例
计算视频帧数:
ffprobe -v error -count_frames -select_streams v:0 -show_entries stream=nb_read_frames -of default=nokey=1:noprint_wrappers=1 ./test.mp4
卸载
删除相应的软链接/usr/bin/ffmpeg
和/usr/bin/ffprobe
,编译目录/usr/local/ffmpeg
。清空环境变量中修改的地方并更新。
重装
当需要更新或者回退,以及需要额外增加库支持时:
①删除ffmpeg-4.2.2/ffbuild
目录下的带config
字段的文件,rm *config*
。
②删除相应的软链接/usr/bin/ffmpeg
和/usr/bin/ffprobe
,编译目录/usr/local/ffmpeg
。
③重新编译、安装并新建软链接。
④配置ffmpeg依赖环境/etc/ld.so.conf
并更新环境变量。
参考资料
[1] FFmpeg官网
[2] ffmpeg 7:4.2.2-1ubuntu1 source package in Ubuntu
[3] Linux下ffmpeg的简易安装及卸载
[4] ffmpeg安装
[5] ffmpeg: error while loading shared libraries: libavdevice.so.58: cannot open
[6] FFmpeg编译-Linux平台
[7] Ubuntu下x264库编译安装
[8] ERROR: cuvid requested, but not all dependencies are satisfied: cuda/ffnvcodec
[9] Opencv 实现GPU解码
[10] 使用GPU硬件加速FFmpeg视频转码
[11] NVIDIA VIDEO CODEC SDK - Get Started
[12] Github FFmpeg/nv-codec-headers
Ubuntu上安装ffmpeg相关推荐
- 服务器上安装ffmpeg后报错及解决方案libavdevice.so.58: cannot open shared object file: No such file or directory
服务器上安装ffmpeg后报错及解决方案 问题描述 实习的时候要求复现从视频中提取3D骨架的论文,其中一篇源码中要用到ffmpeg来对视频进行预处理.安装完ffmpeg之后导入ffmpeg的时候出错, ...
- Ubuntu上安装NVIDIA VideoProcessingFramework (VPF)
引言 安装 参考官方给的安装教程,以Linux系统为例,Windows系统请直接查看官网教程. 预先安装依赖 (1)安装Nvidia video driver和CUDA SDK ①安装与GPU匹配的C ...
- [网摘学习]在Ubuntu上安装和配置OpenStack Nova之二
再收藏一份Openstack的文章,这两天的操作与此相同.但其中出现的问题还需要查找原因.待个人继续学习研究. 原文参考:http://www.linuxde.net/2011/11/1599.htm ...
- 在 Ubuntu 上安装最新版本的 Erlang方法介绍
Erlang 是一种用于构建大规模可扩展实时系统的函数式编程语言.Erlang 最初是由 爱立信 创建的专有软件,后来被开源. Erlang 在 Ubuntu 的 Universe 仓库 中可用.启用 ...
- ubuntu18.04上安装ffmpeg
ubuntu18.04上安装ffmpeg 下载ffmpeg wget https://johnvansickle.com/ffmpeg/builds/ffmpeg-git-amd64-static.t ...
- 在Ubuntu上安装Odoo 11(企业版)
2019独角兽企业重金招聘Python工程师标准>>> 在Ubuntu上安装Odoo 11(企业版) 2017年10月8日YENTHE666 在本教程中,我将学习如何在Ubuntu ...
- 在 Ubuntu 上安装 Android Studio
在 Ubuntu 上安装 Android Studio http://www.linuxidc.com/Linux/2013-05/84812.htm 打开terminal,输入以下命令 sudo a ...
- linux卸载kodi,如何在Ubuntu上安装Kodi 18 Beta
Kodi的Beta版周期很长.很棒,因为它有助于将错误排除在生产版本之外,而且还可以保留数月的新功能.值得庆幸的是,Kodi开发人员提供了可供测试和使用的"unstable"软件包 ...
- [异常解决] ubuntu上安装虚拟机遇到的问题(vmware坑了,virtual-box简单安装,在virtual-box中安装精简版win7)
[异常解决] ubuntu上安装虚拟机遇到的问题(vmware坑了,virtual-box简单安装,在virtual-box中安装精简版win7) 参考文章: (1)[异常解决] ubuntu上安装虚 ...
最新文章
- 逻辑模型三要素-数据操作
- Leetcode 62. Unique Paths
- 【Spring注解】@Condition条件注册
- 华为云部署html网页,手把手教你如何在华为云服务器上部署一个自己的弹幕网站!...
- 电力笔记-30个行业专业词汇(Ⅰ期)
- arp 不同网段 相同vlan_同vlan不同网段能否ping通?
- 伪随机数与采样(sampling)
- 利用k-means算法实现图像自动色彩量化
- js实现相册翻页,滚动,切换,轮播功能
- 启动Eclipse 报错:java was started but returned exit
- pybind11用python调用C++代码
- 火狐firefox扩展插件开发extension代码调试方法
- Swift高仿喜马拉雅APP之一Charles抓包、图片资源获取等
- java 代码练习题_99个java练习题及答案
- html点击按钮状态改变,html点击按钮改变文字怎么实现
- Java编程练习:100以内的质数的输出
- 《禅与摩托车维修艺术》(罗伯特·M·波西格)骑行路上的哲学思考 Zen and the Art of Motorcycle Mt...
- CentOS 7安装Docker
- spark常用RDD算子 - take(),takeOrdered(),top(),first()
- SparkStreaming读取Kafka数据源并写入Mysql数据库