首先新建一个文件夹
进入文件夹目录
下载

wget http://nginx.org/download/nginx-1.15.3.tar.gz

解压
tar xvf nginx-1.15.3.tar.gz
下载nginx rtmp模块

wget https://codeload.github.com/arut/nginx-rtmp-module/tar.gz/v1.2.1

解压tar xvf v1.2.1
进入nginx目录
cd nginx-1.15.3
执行:

#--add-module 指向rtmp模块目录
./configure --prefix=./bin --add-module=../nginx-rtmp-module-1.2.1 --with-openssl=/usr/local/openssl

在这一步会有很多报错比如缺少pcre、openssl库等
这个时候需要安装这些库
接下来开启填坑之路

#第一个错误 没有C++环境
/configure: error: C compiler cc is not found
可能是你的mac把xcode删除了
这个时候需要重新下载xcode
如果你安装了xcode还是有这个错误
需要你执行

sudo xcodebuild -license 

可以参考这篇文章https://blog.csdn.net/Jayphone17/article/details/104127109

#接下来是第二个错误
error: the HTTP rewrite module requires the PCRE library.
缺少pcre库
去这个地址
https://ftp.pcre.org/pub/pcre/
下载pcre库,注意不要下载pcre2库
比如我下载的是pcre-8.42
下载到指定的一个目录
进入目录 依次执行

./configure --prefix=/usr/local
make
sudo make install

将这个模块安装到你的电脑中

#接下来是第三个错误
./configure: error: SSL modules require the OpenSSL library.
到这个地址下载openssl
https://www.openssl.org/source/old/
比如我下载是openssl-1.1.1
解压之后进入目录
依次执行

./config --prefix=/usr/local/openssl
make
sudo make install

将openssl安装到你的电脑中

接下来回到nginx目录
执行

./configure --prefix=./bin --add-module=../nginx-rtmp-module-1.2.1 --with-openssl=/usr/local/openssl

这个时候应该就没问题了
这一步成功之后会在你的nginx-1.15.3目录下面生成一个bin文件,里面生成的文件是你上面的命令生成的,接下来启动你的nginx
还是在你的nginx目录执行

bin/sbin/nginx

开启nginx
在浏览器输入localhost:8080访问是否成功
image.png

同时我的目录情况如下
image.png

image.png

接下来配置rtmp模块
打开nginx目录下的bin/conf/nginx.conf(ps:不要找错地方了,不是和bin同目录下的conf)
在http节点后面配置

rtmp {
      server {
          listen 1935;
          application live {
              live on;
              record off;
          }
      }
}

我的整个文件是这样的

#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    #gzip  on;

    server {
        listen       80;
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;
            index  index.html index.htm;
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        #location ~ \.php$ {
        #    root           html;
        #    fastcgi_pass   127.0.0.1:9000;
        #    fastcgi_index  index.php;
        #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
        #    include        fastcgi_params;
        #}

        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }


    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #server {
    #    listen       8000;
    #    listen       somename:8080;
    #    server_name  somename  alias  another.alias;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}


    # HTTPS server
    #
    #server {
    #    listen       443 ssl;
    #    server_name  localhost;

    #    ssl_certificate      cert.pem;
    #    ssl_certificate_key  cert.key;

    #    ssl_session_cache    shared:SSL:1m;
    #    ssl_session_timeout  5m;

    #    ssl_ciphers  HIGH:!aNULL:!MD5;
    #    ssl_prefer_server_ciphers  on;

    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}

}
rtmp {
      server {
          listen 1935;
          application live {
              live on;
              record off;
          }
      }
}

配置好之后保存
在nginx目录下敲命令
reload一下你的配置文件,在停止你的nginx ,最后在启动 一共三个命令

bin/sbin/nginx -s reload
bin/sbin/nginx -s stop
bin/sbin/nginx

1,通过工具推流
接下来就可以推流了
注意推流的地址不是8080
而是你配置的1935比如你在obs中推流
地址为rtmp://localhost:1935/live/room
串流密钥你可以随便填写一个比如我填的room
这个串流密钥是你在拉流的客户端需要和地址拼接后使用的
比如你在vlc中拉流地址应该为rtmp://localhost:1935/live/room

2,通过ffmpeg推流

ffmpeg -re -i /Users/yanzhe/ffmpeg/input.mp4 -vcodec libx264 -acodec aac -f flv rtmp://localhost:1935/live/room

通过ffplay拉流

 ffplay rtmp://localhost:1935/live/room

效果图为
在这里插入图片描述

如果你需要你的手机访问你的nginx地址,只需你的电脑和你的手机在同一个网络下,就可以访问了

Logo

瓜分20万奖金 获得内推名额 丰厚实物奖励 易参与易上手

更多推荐