FFmpeg推流

news2024/9/21 12:33:36

目录

一. 环境准备 

二. 安装FFmpeg

三. 给docker主机安装docker服务

四. 使用 FFmpeg 进行推流测试


FFmpeg是一个非常强大的多媒体处理工具,它可以用于视频和音频的录制、转换以及流处理。在流处理方面,FFmpeg可以用来推流,即将本地媒体文件或者实时数据推送到流媒体服务器上。

一. 环境准备 

关闭防火墙和selinux,进行时间同步。

主机名IP系统软件版本配置信息
ffmpeg192.168.226.31Rocky_linux9.4

FFmpeg-n5.0.1

nasm-2.16.03

2核4G
galera2192.168.226.32Rocky_linux9.4mysql-wsrep-8.0

galera-26.4.14-1

2核4G

FFmpeg下载地址:https://github.com/FFmpeg/FFmpeg/tags

nasm下载地址nasm-2.16.03.tar.gz:Index of /pub/nasm/releasebuilds/2.16.03

 

二. 安装FFmpeg

 

下载并上传压缩包,这里我已经传好了。

[root@ffmpeg ~]# ll
total 15748
-rw-r--r--  1 root root 14428012 Aug  5 17:48 FFmpeg-n5.1.6.tar.gz
-rw-------. 1 root root      815 Jun  6 14:00 anaconda-ks.cfg
-rw-r--r--  1 root root  1688160 Aug  5 19:40 nasm-2.16.03.tar.gz

 首先安装编译 FFmpeg 所需的依赖项:

[root@ffmpeg ~]# yum install -y epel-release
[root@ffmpeg ~]# yum install -y autoconf automake bzip2 bzip2-devel cmake freetype-devel gcc gcc-c++ git libtool make mercurial pkgconfig zlib-devel

安装 NASM

NASM 是一个汇编器,FFmpeg 需要它来编译

[root@ffmpeg ~]# tar -xf nasm-2.16.03.tar.gz
[root@ffmpeg ~]# cd nasm-2.16.03
[root@ffmpeg nasm-2.16.03]# ./configure
[root@ffmpeg nasm-2.16.03]# make && make install
[root@ffmpeg nasm-2.16.03]# nasm -v
NASM version 2.16.03 compiled on Aug  5 2024

安装x264

[root@ffmpeg ~]# git clone https://code.videolan.org/videolan/x264.git
[root@ffmpeg ~]# cd x264/

#--enable-static 使得构建过程中生成静态库。
#--enable-shared 使得构建过程中生成共享库。
[root@ffmpeg x264]# ./configure --enable-static --enable-shared
[root@ffmpeg x264]# make && make install && cd ~
[root@ffmpeg ~]# export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig:$PKG_CONFIG_PATH
[root@ffmpeg ~]# pkg-config --cflags --libs x264

获取 FFmpeg 源代码

[root@ffmpeg ~]# tar -xf FFmpeg-n5.1.6.tar.gz
[root@ffmpeg ~]# cd FFmpeg-n5.1.6
[root@ffmpeg FFmpeg-n5.1.6]# ./configure --enable-shared --enable-libx264 --enable-gpl --prefix=/usr/local/ffmpeg --extra-cflags="-fPIC"
[root@ffmpeg FFmpeg-n5.1.6]# make && make install 
[root@ffmpeg FFmpeg-n5.1.6]# echo $LD_LIBRARY_PATH
[root@ffmpeg FFmpeg-n5.1.6]# ls -l /usr/local/ffmpeg/lib/libavdevice.so.59
[root@ffmpeg FFmpeg-n5.1.6]# ls -l /usr/local/ffmpeg/lib/libavdevice.so.59.7.100
[root@ffmpeg FFmpeg-n5.1.6]# export LD_LIBRARY_PATH=/usr/local/lib:$LD_LIBRARY_PATH
[root@ffmpeg ~]# export PATH=/usr/local/ffmpeg/bin:$PATH
[root@ffmpeg ~]# source ~/.bashrc


[root@ffmpeg ~]# ffmpeg -version
ffmpeg version 5.1.6 Copyright (c) 2000-2024 the FFmpeg developers
built with gcc 11 (GCC)
configuration: --enable-shared --enable-libx264 --enable-gpl --prefix=/usr/local/ffmpeg --extra-cflags=-fPIC
libavutil      57. 28.100 / 57. 28.100
libavcodec     59. 37.100 / 59. 37.100
libavformat    59. 27.100 / 59. 27.100
libavdevice    59.  7.100 / 59.  7.100
libavfilter     8. 44.100 /  8. 44.100
libswscale      6.  7.100 /  6.  7.100
libswresample   4.  7.100 /  4.  7.100
libpostproc    56.  6.100 / 56.  6.100

三. 给docker主机安装docker服务

 

安装 

# step 1: 安装必要的一些系统工具
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
# Step 2: 添加软件源信息
sudo yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
# Step 3
sudo sed -i 's+download.docker.com+mirrors.aliyun.com/docker-ce+' /etc/yum.repos.d/docker-ce.repo
# Step 4: 更新并安装Docker-CE
sudo yum makecache
sudo yum -y install docker-ce
# Step 4: 开启Docker服务
sudo service docker start

配置加速器

sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "registry-mirrors": [
        "https://docker.rainbond.cc"],
  "exec-opts": ["native.cgroupdriver=systemd"],
  "log-driver": "json-file",
  "log-opts": {
    "max-size": "100m"
  },
  "storage-driver": "overlay2"
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker

拉取nginx镜像

tiangolo/nginx-rtmp 是一个 Docker 镜像,用于提供 Nginx 和 RTMP(Real-Time Messaging Protocol)服务器的功能。这个镜像由 Tiangolo 维护,主要用于视频流媒体的处理和转发。

[root@docker ~]# docker pull tiangolo/nginx-rtmp:latest

 创建nginx配置文件

[root@docker ~]# vim nginx.conf
worker_processes auto;  # 自动根据可用的 CPU 核心数量设置 worker 进程数
rtmp_auto_push on;

events {
    worker_connections 1024;  # 增加 worker 可以处理的连接数
}

http {
    sendfile on;              # 启用高效文件传输
    tcp_nopush on;            # 发送响应时优化 TCP 包
    tcp_nodelay on;           # 减少网络延迟
    keepalive_timeout 5 5;    # 长连接超时设置
    client_body_buffer_size 128k;  # 客户端请求体缓冲区大小
    client_max_body_size 10m;      # 允许客户端请求的最大单文件字节数
    client_body_timeout 10;        # 客户端请求体超时
    client_header_timeout 10;      # 客户端请求头超时
    send_timeout 10;               # 响应发送超时

    server {
        listen 8080;  # 监听 8080 端口

        # HLS 配置
        location /hls {
            types {
                application/vnd.apple.mpegurl m3u8;  # 设置 MIME 类型
            }
            root /mnt/;  # HLS 文件根目录
            add_header Cache-Control no-cache;  # 禁用缓存
            add_header Access-Control-Allow-Origin *;  # 跨域支持
        }
    }
}

rtmp {
    server {
        listen 1935;           # 监听 1935 端口,用于 RTMP 流
        listen [::]:1935 ipv6only=on;  # 同时支持 IPv6

        application live {
            live on;  # 启用直播
            record off;  # 关闭录制

            # HLS 配置
            hls on;  # 启用 HLS
            hls_path /mnt/hls/;  # HLS 文件存储路径
            hls_fragment 3s;  # HLS 片段长度
            hls_playlist_length 30s;  # HLS 播放列表长度
        }
    }
}

运行并查看端口

[root@docker ~]# docker run -d -p 1935:1935 -p 8080:8080 -v ./nginx.conf:/etc/nginx/nginx.conf --name nginx-rtmp tiangolo/nginx-rtmp



[root@docker ~]# docker ps
CONTAINER ID   IMAGE                 COMMAND                  CREATED          STATUS          PORTS                                                                                  NAMES
2c8eb664354a   tiangolo/nginx-rtmp   "nginx -g 'daemon of…"   18 seconds ago   Up 17 seconds   0.0.0.0:1935->1935/tcp, :::1935->1935/tcp, 0.0.0.0:8080->8080/tcp, :::8080->8080/tcp   nginx-rtmp


[root@docker ~]# ss -tnlp
State               Recv-Q              Send-Q                           Local Address:Port                           Peer Address:Port             Process                                              
LISTEN              0                   128                                    0.0.0.0:22                                  0.0.0.0:*                 users:(("sshd",pid=832,fd=3))                       
LISTEN              0                   4096                                   0.0.0.0:1935                                0.0.0.0:*                 users:(("docker-proxy",pid=16089,fd=4))             
LISTEN              0                   4096                                   0.0.0.0:8080                                0.0.0.0:*                 users:(("docker-proxy",pid=16104,fd=4))             
LISTEN              0                   128                                       [::]:22                                     [::]:*                 users:(("sshd",pid=832,fd=4))                       
LISTEN              0                   4096                                      [::]:1935                                   [::]:*                 users:(("docker-proxy",pid=16094,fd=4))             
LISTEN              0                   4096                                      [::]:8080                                   [::]:*                 users:(("docker-proxy",pid=16127,fd=4))  

  

四. 使用 FFmpeg 进行推流测试

准备一个视频文件、摄像头输入或其他任何 FFmpeg 支持的媒体源。

例如我在这个网站下载一个MP4的格式视频,大约五分钟的大小。

哔哩哔哩 (゜-゜)つロ 干杯~-bilibili

https://www.kedou.life/

 上传到ffmpeg主机,视频名为shipin.mp4

[root@ffmpeg ~]# ll
total 76580
drwxrwxr-x  17 root root     4096 Aug  5 20:43 FFmpeg-n5.1.6
-rw-r--r--   1 root root 14428012 Aug  5 17:48 FFmpeg-n5.1.6.tar.gz
-rw-------.  1 root root      815 Jun  6 14:00 anaconda-ks.cfg
drwxrwsr-x  24  802  900     4096 Aug  5 19:43 nasm-2.16.03
-rw-r--r--   1 root root  1688160 Aug  5 19:40 nasm-2.16.03.tar.gz
-rw-r--r--   1 root root 62278099 Aug  5 21:00 shipin.mp4
drwxr-xr-x  11 root root     4096 Aug  5 20:31 x264

 推流测试

[root@ffmpeg ~]# ffmpeg -re -i shipin.mp4 -c:v libx264 -preset ultrafast -maxrate 1500k -bufsize 3000k -pix_fmt yuv420p -g 50 -s 1280x720 -c:a aac -b:a 128k -ar 44100 -f flv rtmp://192.168.226.32:1935/live/stream

这个时候,切换到docker容器里查看

[root@docker ~]# docker ps
CONTAINER ID   IMAGE                 COMMAND                  CREATED          STATUS          PORTS                                                                                  NAMES
2c8eb664354a   tiangolo/nginx-rtmp   "nginx -g 'daemon of…"   12 minutes ago   Up 12 minutes   0.0.0.0:1935->1935/tcp, :::1935->1935/tcp, 0.0.0.0:8080->8080/tcp, :::8080->8080/tcp   nginx-rtmp

[root@docker ~]# docker exec -it nginx-rtmp /bin/bash
root@2c8eb664354a:/# cd /mnt/hls/  

root@2c8eb664354a:/mnt/hls# ls
stream-0.ts  stream-1.ts  stream-2.ts  stream-26.ts  stream-27.ts  stream-28.ts  stream-29.ts  stream.m3u8

然后桌面新建一个.html结尾的文件,注意代码里你需要修改的是对应的IP地址

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>HLS Stream with Video.js</title>
    <link href="https://vjs.zencdn.net/7.14.3/video-js.css" rel="stylesheet" />
    <style>
        /* 自定义 Video.js 播放器样式 */
        .vjs-default-skin {
            font-family: "Arial", sans-serif;
            font-size: 16px;
            color: #FFF;
            background-color: #333;
            border: 2px solid #555;
            border-radius: 10px;
            overflow: hidden;
        }

        .vjs-control-bar {
            background: rgba(0, 0, 0, 0.7);
        }

        .vjs-big-play-button {
            background: rgba(255, 255, 255, 0.3);
            border: none;
            border-radius: 50%;
        }

        .vjs-progress-holder {
            background: rgba(255, 255, 255, 0.2);
        }

        .vjs-play-progress {
            background: #FFCC00; /* 进度条前景色 */
        }

        .vjs-load-progress {
            background: #666; /* 加载进度条色 */
        }

        .vjs-seek-to-live-control {
            display: none;
        }

        .video-js {
            width: 720px;  /* 固定宽度 */
            height: 405px; /* 固定高度,宽高比为16:9 */
            margin: 0 auto;  /* 水平居中 */
            box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.5);
            display: block;  /* 确保播放器为块级元素 */
        }

        body {
            background-color: #333;
            margin: 0;
            padding: 0;
            display: flex;
            justify-content: center;
            align-items: center;
            height: 100vh;
        }
    </style>
</head>
<body>
    <video id="my-video" class="video-js vjs-default-skin" controls preload="auto"
           data-setup='{"fluid": false}'>
                     // 修改此处的IP为你的IP即可
        <source src="http://192.168.226.32:8080/hls/stream.m3u8" type="application/x-mpegURL">
    </video>

    <script src="https://vjs.zencdn.net/7.14.3/video.min.js"></script>
    <script>
        var player = videojs('my-video', {
            controls: true,
            autoplay: false,
            preload: 'auto'
        });

        // 示例: 监听播放进度事件
        player.on('timeupdate', function() {
            var currentTime = player.currentTime();
            var duration = player.duration();
            console.log('当前播放时间:', currentTime, '总时长:', duration);
        });
    </script>
</body>
</html>

在推流的同时,打开网页播放即可

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1983436.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring快速学习

目录 IOC控制反转 引言 IOC案例 Bean的作用范围 Bean的实例化 bean生命周期 DI 依赖注入 setter注入 构造器注入 自动装配 自动装配的方式 注意事项; 集合注入 核心容器 容器的创建方式 Bean的三种获取方式 Bean和依赖注入相关总结 IOC/DI注解开发 注解开发…

探索四川财谷通抖音小店:安全与信赖的购物新体验

在数字经济蓬勃发展的今天&#xff0c;抖音平台凭借其庞大的用户基础和强大的内容生态&#xff0c;逐渐成为了电商领域的一股不可忽视的力量。其中&#xff0c;四川财谷通抖音小店作为这一浪潮中的佼佼者&#xff0c;不仅以其丰富的商品种类和独特的品牌魅力吸引了众多消费者的…

【数据结构】排序 —— 快速排序(quickSort)

Hi~&#xff01;这里是奋斗的明志&#xff0c;很荣幸您能阅读我的文章&#xff0c;诚请评论指点&#xff0c;欢迎欢迎 ~~ &#x1f331;&#x1f331;个人主页&#xff1a;奋斗的明志 &#x1f331;&#x1f331;所属专栏&#xff1a;数据结构、LeetCode专栏 &#x1f4da;本系…

Python酷库之旅-第三方库Pandas(067)

目录 一、用法精讲 266、pandas.Series.dt.second属性 266-1、语法 266-2、参数 266-3、功能 266-4、返回值 266-5、说明 266-6、用法 266-6-1、数据准备 266-6-2、代码示例 266-6-3、结果输出 267、pandas.Series.dt.microsecond属性 267-1、语法 267-2、参数 …

集合基础知识及练习

import java.util.ArrayList;public class Solution {//将字符串转化为整数public static void main(String[] args) {ArrayList<String> listnew ArrayList();list.add("aaa");list.add("aaa");list.add("bbb");list.add("ccc"…

【Python】Django Web 框架

一、常用的Web开发框架 1.Django Django是一个由Python写成的开放源代码的Web应用框架。这套框架的主要目标是使开发复杂、数据库驱动的网站变得简单。Django注重组件的重用性和“可拔插性”、敏捷开发和DRY(Dont Repeat Yourself)法则 2.Flask Flask是一个微型的Python开发…

音视频开发 sdl库

介绍 SDL (Simple DirectMedia Layer) 是一个跨平台的开源多媒体库,它提供了底层访问多种硬件的接口,如音频、视频、输入设备等。它主要用于游戏开发,但也可用于其他类型的多媒体应用程序。下面是 SDL 的一些主要特点: 跨平台性: SDL 支持多种操作系统,包括 Windows、macOS、L…

如何在linux系统上安装tomcat应用程序?

1&#xff09;首先查看安装包信息 yum info tomcat yum info tomcat 2&#xff09;安装 yum -y install tomcat yum -y install tomcat 3&#xff09;查看安装是否成功 rpm -q tomcat rpm -q tomcat 4&#xff09;如果输出一下内容则代表安装成功 tomcat-7.0.76-16.el7_9.n…

新手教学系列——Redis 实现分布式锁:让系统更高效的两种策略

在分布式系统中,分布式锁是一种常见的解决方案,用于确保同一资源不会被多个节点同时访问。Redis 作为一种高性能的内存数据库,提供了方便快捷的分布式锁实现方式。今天,我们将深入探讨如何使用 Redis 实现分布式锁,并且介绍两种常见的策略:占位锁和等待锁。 一、什么是分…

Linux源码阅读笔记13-进程通信组件中

架构图 代码分析 loff_t lnchannel_llseek(struct file *filp, loff_t offset, int whence) {loff_t newpos;switch(whence) {case 0:newpos offset;break;case 1:newpos filp->f_pos offset;break;case 2:return -EINVAL;}if (newpos < 0 || newpos > LNCHANNEL_…

剪映国际版(CapCut) 2024 下载 安装 汉化

将 剪映国际版&#xff08;CapCut&#xff09; 2024 压缩包解压到本地&#xff1a; 点击蓝色字体下载压缩包 提取码 jwsg 鼠标右键 点击 CapCut 3.0.0.exe 选择 以管理员身份运行&#xff1a; 勾选 Agree with CapCut Users License Agreement & Pricacy Policy 点击 Mor…

基于SSM的哈米音乐实战项目,Java课程设计作业,Java毕业设计项目,找工作前的实战项目,附部分源码以及数据库

1、项目所需技术 java基础&#xff0c;java反射&#xff0c;泛型html&#xff0c;css&#xff0c;JavaScript&#xff0c;jquery&#xff0c;bootstrap&#xff0c;layuijstl&#xff0c;el表达式&#xff0c;jsp&#xff0c;mysql&#xff0c;jdbc&#xff0c;xml&#xff0c…

HashMap及其相关知识点

一、HashMap插入与删除 通过将key转换为hashCode&#xff08;int&#xff09;&#xff0c;通过hashCode计算下标&#xff0c;int index hashCode & (length - 1)&#xff0c;从而实现插入与删除。 二、Hash冲突 Java8之前&#xff1a;通过数组链表的数据结构解决hash冲…

【Java数据结构】Map和Set超详细两万字讲解(内含搜索树+哈希表)

&#x1f512;文章目录&#xff1a; 1.❤️❤️前言~&#x1f973;&#x1f389;&#x1f389;&#x1f389; 2. Map和Set的基础概念 3.Map的基础使用 4.Set的基础使用 5. TreeMap的本质——红黑树 5.1二叉搜索树的概念 5.2二叉搜索树的模拟实现 二叉搜索树——查找 二…

东莞网页设计结构图

东莞网页设计结构图是一个网页设计师在设计网站时使用的工具&#xff0c;用来展示网页的布局、内容结构和功能模块等信息。在设计一个网页时&#xff0c;网页设计师通常会首先制作一个网页设计结构图&#xff0c;以便更好地组织和规划网站的内容和功能。东莞网页设计结构图可以…

PFA的特点及焊接方法和应用领域

一、PFA特点&#xff1a; 1、外观半透明&#xff0c;易观察试剂情况&#xff1b; 2、耐高低温&#xff1a;-200&#xff5e;260℃&#xff1b; 3、耐腐蚀&#xff1a;耐强酸、强碱、王水、HF和各种有机溶剂&#xff1b; 4、防污染&#xff1a;本底值低&#xff0c;金属元素…

SpringBoot 整合 Spring Security 、JWT 实现认证、权限控制

​ 博客主页: 南来_北往 系列专栏&#xff1a;Spring Boot实战 前言 Spring Security 和 JWT 实现认证、权限控制是一种在Web应用中保障安全的重要手段。 Spring Security是一个功能强大的身份验证和访问控制框架&#xff0c;它提供了完善的认证机制和方法级的授权功能。…

手机维修--学习笔记(一)

最近觉得手机主板维修比较有意思&#xff0c;观看许多师傅的维修视频&#xff0c;并做笔记如下&#xff1a; 手机主板维修&#xff1a; 【手机电路板怎么修&#xff0c;师傅对着电路图一步一步讲解&#xff0c;看完受益匪浅】https://www.bilibili.com/video/BV13A411v7wL?v…

梯度和反向传播

一.梯度 在机器学习的时候都了解过了&#xff0c;梯度是一个向量&#xff0c;导数变化最快的方向 损失函数&#xff1a; 通过梯度使损失降到最 用ywxb举例也就是使用梯度来更新w的值&#xff0c;ww-学习率*梯度。大于零就减小&#xff0c;反之增大 二.反向传播 就比如搭积木…

【源码+文档+调试讲解】古风生活体验交流网站

摘 要 二十一世纪我们的社会进入了信息时代&#xff0c;信息管理系统的建立&#xff0c;大大提高了人们信息化水平。传统的管理方式对时间、地点的限制太多&#xff0c;而在线管理系统刚好能满足这些需求&#xff0c;在线管理系统突破了传统管理方式的局限性。于是本文针对这一…