前言
前面的文章利用javacv实现了rtmp转封装,上述文章中需要的nginx-rtmp-module搭建本文做个简单的安装描述;另外这里的Linux的版本是Centos7。
安装各种编译环境
1 gcc 安装
安装 nginx 需要先将官网下载的源码进行编译,编译依赖 gcc 环境,如果没有 gcc 环境,则需要安装:
yum -y install gcc gcc-c++
2 PCRE pcre-devel 安装
PCRE(Perl Compatible Regular Expressions) 是一个Perl库,包括 perl 兼容的正则表达式库。nginx 的 http 模块使用 pcre 来解析正则表达式,所以需要在 linux 上安装 pcre 库,nginx也需要此库。
yum install -y pcre pcre-devel
3 zlib unzip 安装
unzip zlib 库提供了很多种压缩和解压缩的方式, nginx 使用 zlib 对 http 包的内容进行 gzip ,所以需要在 Centos 上安装 zlib 库。
yum install -y zlib zlib-devel
yum install -y unzip
4 OpenSSL 安装
OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及 SSL 协议,并提供丰富的应用程序供测试或其它目的使用。nginx 不仅支持 http 协议,还支持 https(即在ssl协议上传输http),所以需要在 Centos 安装 OpenSSL 库。
yum install -y openssl openssl-devel
安装nginx 跟rtmp模块
1 创建源码目录 先回到根目录下
mkdir /nginxrtmp/ide
cd /nginxrtmp/ide
git clone https://github.com/arut/nginx-rtmp-module.git # 下载很慢去git地址下载nginx-rtmp-module-master.zip包 确认里面有代码就ok
unzip nginx-rtmp-module-master.zip
2 创建nginx目录
mkdir /nginxrtmp/nginx
cd /nginxrtmp/nginx
#创建一个同名用户来运行nginx
groupadd nginx
useradd -g nginx nginx -s /sbin/nologin
3 下载获取
wget https://nginx.org/download/nginx-1.15.8.tar.gz
tar -zxvf nginx-1.15.8.tar.gz
4 编译安装nginx
cd nginx-1.15.8
./configure --prefix=/nginxrtmp/nginx \--user=nginx \
--group=nginx \
--with-http_ssl_module \
--add-module=/nginxrtmp/ide/nginx-rtmp-module-master
#安装
make & make install
设置开机自启
请注意nginx的安装目录,如果跟我的不一样,文件内容的路径也要对应调整。
cd /lib/systemd/system
vi nginx.service
[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
ExecStart=/nginxrtmp/nginx/sbin/nginx
ExecReload=/nginxrtmp/nginx/sbin/nginx reload
ExecStop=/nginxrtmp/nginx/sbin/nginx quit
PrivateTmp=true
[Install]
WantedBy=multi-user.target
# 设置开机启动
systemctl enable nginx.service
# 启动nginx命令
systemctl start nginx.service
# 结束nginx命令
systemctl stop nginx.service
# 重启nginx命令
systemctl restart nginx.service
设置防火墙
安装成功后,设置防火墙与开启端口
yum -y install iptables-services
vi /etc/sysconfig/iptables
-A INPUT -p tcp -m state --state NEW -m tcp --dport 22 -j ACCEPT
-A INPUT -p tcp -m state --state NEW -m tcp --dport 80 -j ACCEPT
# 关闭firewall防火墙
systemctl disable firewalld.service
# 设置开机启动:
systemctl enable iptables.service
测试验证
访问页面验证是否安装成功
配置
修改配置文件,开启直播功能,增添rtmp部分
vi /nginxrtmp/nginx/conf/nginx.conf
rtmp {
server {
listen 1935;
application live {
live on;
}
}
}
#重启Nginx
systemctl restart nginx.service
开启rtmp端口
rtmp默认端口是1935
# 添加端口
vi /etc/sysconfig/iptables
-A INPUT -p tcp --dport 1935 -j ACCEPT
# 重启防火墙
systemctl restart iptables
说明
到此安装nginx-rtmp-module已经完成了,如果需要验证可以直接在安装ffmpeg 即可验证是否安装正确(后续根据情况而定看是否需要写一篇文章,毕竟百度上比较多也相对而言比较简单),因为本文主要是为了验证上一篇文章的代码可以不用安装ffmpeg。
- 值得一提的就是文章中rtmp的应用名称要与代码中的一直,不然转码不会成功哦!
验证代码与安装结果
验证一片文章中的Javacv转封装结果及本次安装结果