Mac平台直播推流搭建

Homebrew

Homebrew ( ['hoʊmbru:] ), 简称brew,是Mac OSX上的软件包管理工具,能在Mac中方便的安装软件或者卸载软件,类似于Linux系统中的apt-get, yum. 

Homebrew官网: http://brew.sh/index_zh-cn.html

Homebrew的安装:

ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"

相关命令

命令

描述

brew search 软件名

搜索软件

brew install 软件名

安装软件

brew remove 软件名

卸载软件


Nginx

  • Nginx (发音同engine (['ɛndʒɪn]) x)是一个轻量级的网页服务器, 能反向代理HTTP, HTTPS, SMTP, POP3, IMAP的协议链接, 以及一个负载均衡器和一个HTTP缓存.
  • 反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。
  • Nginx是一款面向性能设计的HTTP服务器,相较于Apache、lighttpd具有占有内存少,稳定性高等优势。
  • Nginx官网: http://nginx.org/

Nginx的安装

// 下载brew对nginx的扩展 (brew有默认仓库, tap表示对brew进行扩展, 可理解为第三方的仓库)
brew tap homebrew/nginx 

// 安装nginx和rtmp模块
brew install nginx-full --with-rtmp-module
// 下载brew对nginx的扩展 (brew有默认仓库, tap表示对brew进行扩展, 可理解为第三方的仓库)
brew tap homebrew/nginx 

// 安装nginx和rtmp模块
brew install nginx-full --with-rtmp-module

查看Nginx的信息

// 查看nginx的信息
brew info nginx-full

部分输出信息如下:

#nginx服务器的根目录
Docroot is: /usr/local/var/www

#nginx的配置文件nginx.conf中设置了默认端口为8080, 可以不需要sudo来支持nginx
The default port has been set in /usr/local/etc/nginx/nginx.conf to 8080 so that nginx can run without sudo.

nginx will load all files in /usr/local/etc/nginx/servers/.

Nginx的启动和停止

#绑定80端口, 不需要sudo就可以启动nginx
$ sudo chown root:wheel /usr/local/Cellar/nginx-full/1.10.1/bin/nginx

$ sudo chmod u+s /usr/local/Cellar/nginx-full/1.10.1/bin/nginx

# 重新加载配置
$ nginx -s reload

# 启动nginx, 不需要后台服务, 没有绑定80则要添加sudo
$ nginx  

# 停止nginx
$ nginx -s stop

# 现在运行start homebrew/nginx/nginx-full并在登陆后重启
brew services start homebrew/nginx/nginx-full

# 停止start homebrew/nginx/nginx-full
brew services stop homebrew/nginx/nginx-full
#绑定80端口, 不需要sudo就可以启动nginx
$ sudo chown root:wheel /usr/local/Cellar/nginx-full/1.10.1/bin/nginx

$ sudo chmod u+s /usr/local/Cellar/nginx-full/1.10.1/bin/nginx

# 重新加载配置
$ nginx -s reload

# 启动nginx, 不需要后台服务, 没有绑定80则要添加sudo
$ nginx  

# 停止nginx
$ nginx -s stop

# 现在运行start homebrew/nginx/nginx-full并在登陆后重启
brew services start homebrew/nginx/nginx-full

# 停止start homebrew/nginx/nginx-full
brew services stop homebrew/nginx/nginx-full

启动后, 在浏览器进入 http://localhost:8080 , 如图示则启动成功!


配置rtmp

打开nginx的配置文件

vim /usr/local/etc/nginx/nginx.conf

在http节点的下面, 添加rtmp的配置

rtmp {  #rtmp协议
    server {    #服务器相关配置
        listen 1935;    #监听的端口号, rtmp默认1935
        application ZedLive {   # 自定义的路径名
            live on;    #开启实时
            record off;     #不记录数据
        }
    }
}
rtmp {  #rtmp协议
    server {    #服务器相关配置
        listen 1935;    #监听的端口号, rtmp默认1935
        application ZedLive {   # 自定义的路径名
            live on;    #开启实时
            record off;     #不记录数据
        }
    }
}

重新加载nginx的配置

#修改完nginx.conf文件后, 重新加载
nginx -s reload

FFmpeg

  • FFmpeg (Fast Forward MPEG), 提供了多种音视频格式的录制、转换以及流化的功能支持
  • 包含了音视频解码函数库libavcodec
  • 包含了音视频格式转换函数库libavformat

安装FFmpeg

brew install ffmpeg
brew install ffmpeg

进行推流

#使用x264视频编码, aac音频编码
#播放路径要与rtmp配置的匹配
ffmpeg -re -i 视频路径 -vcodec libx264 -acodec aac -f flv rtmp://localhost:1935/ZedLive/room
  • x264主要功能在于进行H.264/MPEG-4 AVC的视频编码, 支持硬解, 可减轻CPU负载
  • AAC (Advanced Audio Coding), 专为声音数据设计的有损压缩格式, 旨在取代MP3格式

配置HLS

打开配置文件nginx.confg

vim /usr/local/etc/nginx/nginx.conf

增加对HLS的支持

1.找到http花括号中的 server, 添加相应配置

server {
    listen       8080;
    server_name  localhost;

    location / {
        root   html;
        index  index.html index.htm;
    }
    #配置HLS, 让客户端能以http协议获取HLS的拉流
    location /hls {
        # Serve HLS fragments
        types {
            application/vnd.apple.mpegurl m3u8;
            video/mp2t ts;
        }
        root html;
        add_header Cache-Control no-cache;
    }

    //...其它的忽略...
}

2.找到rtmp花括号中的 server, 添加相应配置

rtmp {
server {
    listen 1935;
    application ZedLive {
        live on;
        record off;
    }
    #增加对HLS支持开始, 推流必须是基于H264/AAC格式
    application hls {
        live on;
        hls on;
        hls_path /usr/local/var/www/hls;
    }
}

}

重新加载nginx配置

nginx -s reload

进行推流

ffmpeg -loglevel verbose -re -i  视频路径  -vcodec libx264 -vprofile baseline -acodec libmp3lame -ar 44100 -ac 1 -f flv rtmp://localhost:1935/hls/文件名(不包含.m3u8后缀)
ffmpeg -loglevel verbose -re -i  视频路径  -vcodec libx264 -vprofile baseline -acodec libmp3lame -ar 44100 -ac 1 -f flv rtmp://localhost:1935/hls/文件名(不包含.m3u8后缀)

查看HLS直播时生成的.m3u8和.ts文件

在 /usr/local/var/www/hls 目录中
正常情况下该目录无权限访问, 可以通过terminal或Finder为自己添加相应权限

以Http协议的方式访问HLS拉流

// iOS系统的Safari浏览器原生支持HLS, 直接播放即可
 http://localhost:8080/hls/文件名称.m3u8