Rat's

云转码express-ffmpeg+CMS一体化系统安装教程
项目介绍该云转码不再是简单的云转码系统,而是CMS系统+云转码系统一体化,自带整个完备的并且对移动端友好的,而且非...
扫描右侧二维码阅读全文
12
2018/09

云转码express-ffmpeg+CMS一体化系统安装教程

项目介绍

该云转码不再是简单的云转码系统,而是CMS系统+云转码系统一体化,自带整个完备的并且对移动端友好的,而且非常利于SEO优化的自适应CMS系统,根据后台的分类系统和门户CMS管理系统,直接在首页达成完备的在线视频播放系统,适用于在线教育、企业内部培训视频、在线视频自媒体门户等多种运用方向。

如果你不想使用CMS,也可以单独当它是一个可以在线视频转码的工具,对视频进行在线格式转换,很适合用来做一个视频转码的网站。

提示:本文主要介绍的是开源免费版的功能及其源码的安装方法,仅供学习交流使用。且不能用于非法用途,否则后果自负!
  • 实现大文件分块上传,批量上传。
  • 实现服务器端自动动态码率转码并且切片,完成后会自动删除原视频文件。
  • 实现批量添加水印和字幕,和同时处理。
  • 实现截图,默认自动生成四张截图。
  • 一键获取分享链接,设置防盗链,token防盗链或者仅允许指定域名iframe调用。
  • ts切片文件域名分发,负载均衡,支持无限多服务器同步分发。

官方网站:http://ffmpeg.moejj.com/
开源版演示:https://www.moejj.com
高级版演示:https://www.leimulamu.com,具体介绍看文章最后面。

截图

请输入图片描述
请输入图片描述
请输入图片描述

更新

【2019.1.17】
更新部分安装步骤,使出错率更小。

为什么要使用云转码

传统视频如果没有正确的压缩,一般来说尺寸非常大,动则3Gb4Gb的大小,再者因为视频需要在网站中进行播放,传统中如果放置常规的flv或者mp4格式,那么浏览器会一直进行缓存,并且在缓存在一定播放长度之后才会进行播放,这样会消耗更多的带宽和让用户等待更长的时间,所以转码之后再进行切片是非常必须的,一来无损的压缩视频文件使其占用磁盘尺寸更小,并且基于hls格式,也是M3u8格式中储存了所有ts切片列表,这种模式加载,只需要加载第一个ts切片视频就可以开始播放,这样就使用户等待的时间更少,减少服务器带宽使用,并且画质的损失很小。这也就是为什么现在大部分视频网站都是使用hls格式来播放的。

具体功能

  • 后台云转码加切片,运用最精简的代码,做成最快的转码+切片功能。
  • 秒切功能,切片速度领先所有市面收费云转码系统。
  • 视频分类、视频筛选、视频搜索,后台一应俱全。
  • 防盗链、token防盗链,多重防盗链,避免流量损失,可以设置指定域名只能iframe调用。
  • 字幕烧录,水印烧录,超级简单的操作,即可将字幕烧录进视频或者添加水印到视频中。
  • 支持vtt字幕,后台可以根据不同的视频上传不同的vtt字幕,前台播放自动加载字幕。
  • 视频截图,后台配置截图数,云转码切片的时候自动截图。
  • ts分发,多服务器同步内容,ts文件自动循环加域名前缀,负载均衡。
  • cms系统配置,站点名称设置、seo标题设置、seokeywords设置,seodescription设置,前台显示截图设置,前台自动生成cms系统,自适应布局,针对移动端优化,seo效果极佳。

新增功能

#增加会员系统
增加会员系统,可以不开启CMS,独立开启会员系统,双向验证,安全可靠,后台可以配合卡劵生成,前台用户使用卡劵进行升级。

#真正意义上的权限系统
路由层面的权限系统,非网上的播放器假权限,根据权限不同,相同的M3U8播放文件返回不同的内容,比如普通会员只能播放3分钟,就只会返回3分钟的切片内容,升级之后才会返回完整的切片内容。

#卡劵系统
后台设定卡劵生成,可以设置开通会员时间,用户前台使用即可升级到对应的会员,到期之后权限失效,需要重新开通,如果连续使用则是累加会员时间。

安装

如果你觉得安装很困难,想很快安装好,可以使用博主写的Linux一键脚本,脚本地址:点击访问

安装教程官网其实有,不过仅有Ubuntu的手动教程,其它系统都没有,博主发现该程序所需的大部分环境宝塔面板均可以直接安装,鉴于为小白着想,这里就用宝塔面板安装该程序,支持的系统也多。

所需环境:nodejsexpressjsmongoDbffmpegRedis

1、安装宝塔

#Centos系统
yum install -y wget && wget -O install.sh http://download.bt.cn/install/install.sh && sh install.sh
#Ubuntu系统
wget -O install.sh http://download.bt.cn/install/install-ubuntu.sh && sudo bash install.sh
#Debian系统
wget -O install.sh http://download.bt.cn/install/install-ubuntu.sh && bash install.sh

安装完成后,进入面板,点击左侧软件管理,然后安装MongoDbRedisNginx(使用域名访问才需要安装,反之不用)。注意Debian安装MongoDb之前还需要使用命令apt install sudo,不然可能存在MongoDb启动不了的情况。

2、安装ffmpeg
安装方法参考:使用静态ffmpeg二进制文件秒安装ffmpeg

3、安装其它依赖
安装Nodejs

#Debian/Ubuntu系统
curl -sL https://deb.nodesource.com/setup_8.x | bash -
apt-get install -y nodejs git screen

#Centos系统
curl -sL https://rpm.nodesource.com/setup_8.x | bash -
yum install nodejs git screen -y

安装PM2express

npm install -g pm2 express

4、创建数据库
创建之前建议去面板软件管理那里找到MongoDb数据库重启一下。

#这里数据库名,用户和密码都是ffmpeg
mongo
use ffmpeg
db.createUser({user:"ffmpeg",pwd:"ffmpeg",roles:[{role:"readWrite",db:"ffmpeg"}]})
db.auth("ffmpeg","ffmpeg")

如果显示1则增加用户正确,再使用Ctrl+D退出。这里如果有No such file or directory报错,请检查下数据库运行状态。

5、配置云转码

git clone https://gitee.com/quazero/express-ffmpeg.git
cd express-ffmpeg
#创建config文件夹
mkdir config
cd config

创建并编辑auth.js配置文件:

nano auth.js

将以下代码复制进去:

#该配置比很早的版本多了三个设置项,很多人出错就在这里,secret是session需要的秘钥,login是后台登陆地址,loginmsg 是后台未登录显示的内容,默认是404。
module.exports = {
    user: "admin",
    password: "admin",
    db: "ffmpeg",
    dbuser: "ffmpeg",
    dbpassword: "ffmpeg",
    secret: "yoursecret",
    login: "/adminlogin",
    loginmsg: "404 Not Found"
};

再使用Ctrl+XY确认退出编辑模式,参数从上往下依次是登陆云转码平台的账号,密码,数据库,数据库用户名,数据库密码。本教程安装的mongodb数据库为ffmpeg,用户名和密码都是ffmpeg,可以自行进行修改。

6、安装并运行云转码

cd /root/express-ffmpeg
npm install
#如果服务器重启,则必须在express-ffmpeg源码文件里重新运行命令启动
pm2 start bin/www -i 0

7、反向代理
点击左侧网站,添加站点,然后再点击添加好了的域名名称,这时候就进入了站点配置,点击反向代理,目标URL填入http://127.0.0.1:3000,再启用反向代理即可。

8、站点配置
最后打开xx.com/adminlogin,输入设定的账号密码,本教程设置的是adminadmin,进入之后点击设置,在其中绑定域名,设置tokenkey,上传水印图片(推荐120*35),然后域名分发、CMS设置等功能都需要提交下,不然进入首页会出现502错误,而且视频也会播放不了。

最后就可以直接分享视频,也可以在别的网站贴视频什么的。

云转码高级版

演示站:https://www.leimulamu.com/
更新日志:https://www.iqi360.com/topic/5c53f9e8ac599a7c35b49d7c

作者最近出了个云转码付费高级版,功能在上面提的基本功能前提下,新增如下:

  • 拥有全新的主题,样式更好看了。
  • 新增加多码率版本,可以同时转码240P360P480P720P1080P,后台可以自行配置。
  • 新增跑马灯广告,后台直接设置广告文字,速度,多长时间出现一次,无需任何复杂的配置。
  • 新增用户组权限,根据后台配置,可以自行设置用户组可观看分辨率。
  • 新增超级截图功能,比原来截图速度快100倍,并无夸张,只需要1秒钟即可截图设定数量的图片。
  • 新增推广功能,用户个人中心获取推广链接,根据IP访问增加积分,积分累计升级用户组,解锁更高分辨率。
  • 新增标签化和截取视频片段生成gif动态图
  • 新增一键获取视频所有分辨率m3u8m3u8地址全部随机目录。
  • 电视剧和电影分开,可以自行配置电视剧,豆瓣链接一键获取所需数据。
  • 前台增加电视剧板块,电视剧自带多码率切换,可根据用户组来播放对应分辨率视频。
  • 更新文章列表和文章的模板,后台cms文章发布功能集成到高级版中。
  • 更新vip付费用户组的创建,跟普通用户组分开,使用积分购买vip用户组。
  • 更新卡卷对接高级版CMS,可以生成充值积分卡卷,充值的积分可以用以购买VIP用户组。
  • vip付费功能,设置开通天数,开通对应vip用户组和所需积分,前台用户自行使用积分开通VIP用户组。
  • 增加了多码率烧录srt字幕的功能,ftp上传视频和相同文件名的srt文件到movies文件夹,入库之后点击转码会自动将srt字幕烧录进视频,并且多码率全有效。
  • 增加高级版的图集功能,图集效果适合做漫画等功能。
  • 新增用户上传功能,用户上传积分奖励,用户可以看见自己上传的视频。上传三层安全过滤,后台增加了审核按钮。
  • 用户上传MD5检验,如果存在视频则提示已经有用户上传(避免重复上传)。

更新日志:

【2019年3月3日】
新增了多服务器多域名分发配置。
新增了大量对接网盘系统的API配置。
根据所填写分发配置,m3u8中的ts会随机的添加分发域名。
通过多服务器同步切片或者直接反代,就可以实现多服务器负载均衡的效果。或者直接分发CDN域名,也可以解决带宽和负载问题。

【2019年3月12日】
增加一个新的分辨率640P的选项。
增加保留mp4的新选项640P。
修复一些BUG,比如点击推荐然后删除出错的问题。
增加自定义每个分辨率的码率功能,可以设置自己需要的码率。

【2019年3月20日】
增加单独图片水印单独位置的水印烧录功能,这个算是一个比较大的重构功能。
删除原有的配置中的水印配置,并且重新了设计了水印功能,可以设置每一个位置设置不同的图片水印。
很智能的自动匹配视频的大小,也就是所有视频转码之后,图片水印的大小都是自适应的,都是一样的大小。
后台水印管理中,可以添加四个位置四个图片水印,可以完全不同,也可以相同,不添加则不会添加图片水印。
后台预留了文字水印的位置,估计以后会再加上文字水印功能。

高级版作者会长期更新,功能会越来越多,很适合做视频网站,有需求的可以联系博主,目前22002年更新,不限制使用台数,微信rats54,博主会提供高级版的一键安装脚本,且程序经过作者正版授权,包售后,由作者提供更新和技术支持。

云转码纯净版

更新日志:https://www.iqi360.com/topic/5c81375cac599a7c35b49e03

作者最近出了个云转码纯净版,利用阿里巴巴开源的最强大的nodejs框架egg.js将整个转码切片系统抽离出来,最后制作完成了这款最好用、也最容易上手、安装也最简单的视频转码系统,称之为theone ffmpeg转码切片系统,也是用企业级标准制作的一款高性能极致视频转码切片系统。

定位:极致的方便,极致的使用体验,极致的用户自定义,极致的转码切片效率,为极致转码切片而生,企业级设计和编码。

主要功能:

1、所有码率自定义。
2、5个分辨率可选择。
3、选择是否切片,选择是否保留mp4文件,选择是否秒切。
4、选择是否截图GIF动态图,宽度,截取时长,系统会智能截取视频中间最精彩位置进行截取。
5、水印图片自适应,根据生成视频分辨率自适应图片宽高,所有分辨率转码出来图片水印都一样大小。
6、多地方水印烧录,可以同时将水印添加到视频的四个地方。
7、切片时长自己设定。
8、超级截图,生成10个截图只需要1秒钟。
9、全方位优化代码,设置简单,功能超级强大。
10、安装极简,带宽允许情况下2分钟即可安装完成,安装完成直接使用无需配置。
11、一键批量获取m3u8,一键获取视频所有截图,mp4和m3u8等全部信息,一键自动复制。
12、跨域放行防护配置项,如果开启则域名调用会有跨域判断,如果不开启,则可以将m3u8给所有网站调用。

更多功能还在完善中,目前定价666元,包更新一年,需要加微信rats54

Vultr注册就送$50,可开日本/新加坡等机房,【点击注册】。
最后修改:2019 年 03 月 20 日 09 : 41 PM

发表评论

240 条评论

  1. ki

    ../src/Image.h:19:21: 致命错误:gif_lib.h:没有那个文件或目录
    #include <gif_lib.h>

    ^

    编译中断。
    make: * [Release/obj.target/canvas/src/CanvasPattern.o] 错误 1
    make: 离开目录“/root/express-ffmpeg/node_modules/canvas/build”
    gyp ERR! build error
    gyp ERR! stack Error: make failed with exit code: 2
    gyp ERR! stack at ChildProcess.onExit (/usr/lib/node_modules/npm/node_modules/node-gyp/lib/build.js:262:23)
    gyp ERR! stack at emitTwo (events.js:126:13)
    gyp ERR! stack at ChildProcess.emit (events.js:214:7)
    gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:198:12)
    gyp ERR! System Linux 3.10.0-957.el7.x86_64
    gyp ERR! command "/usr/bin/node" "/usr/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"
    gyp ERR! cwd /root/express-ffmpeg/node_modules/canvas
    gyp ERR! node -v v8.15.1
    gyp ERR! node-gyp -v v3.8.0
    gyp ERR! not ok
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: canvas@1.3.12 (node_modules/canvas):
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: canvas@1.3.12 install: node-gyp rebuild
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: Exit status 1

    up to date in 3.329s
    fixed 0 of 5 vulnerabilities in 831 scanned packages
    5 vulnerabilities required manual review and could not be updated
    [root@localhost express-ffmpeg]# npm audit fix

    canvas@1.3.12 install /root/express-ffmpeg/node_modules/canvas
    node-gyp rebuild

    make: 进入目录“/root/express-ffmpeg/node_modules/canvas/build”
    SOLINK_MODULE(target) Release/obj.target/canvas-postbuild.node
    COPY Release/canvas-postbuild.node
    CXX(target) Release/obj.target/canvas/src/Canvas.o
    In file included from ../src/Canvas.cc:20:0:
    ../src/JPEGStream.h: 在函数‘boolean empty_closure_output_buffer(j_compress_ptr)’中:
    ../src/JPEGStream.h:42:108: 警告:不建议使用‘v8::Local<v8::Value> Nan::MakeCallback(v8::Local<v8::Object>, v8::Local<v8::Function>, int, v8::Local<v8::Value>*)’(声明于 ../../nan/nan.h:959) [-Wdeprecated-declarations]
    Nan::MakeCallback(Nan::GetCurrentContext()->Global(), (v8::Local<v8::Function>)dest->closure->fn, 2, argv);

    ^

    ../src/JPEGStream.h: 在函数‘void term_closure_destination(j_compress_ptr)’中:
    ../src/JPEGStream.h:63:113: 警告:不建议使用‘v8::Local<v8::Value> Nan::MakeCallback(v8::Local<v8::Object>, v8::Local<v8::Function>, int, v8::Local<v8::Value>*)’(声明于 ../../nan/nan.h:959) [-Wdeprecated-declarations]
    Nan::MakeCallback(Nan::GetCurrentContext()->Global(), (v8::Local<v8::Function>)dest->closure->fn, 2, data_argv);

    ^

    ../src/JPEGStream.h:71:112: 警告:不建议使用‘v8::Local<v8::Value> Nan::MakeCallback(v8::Local<v8::Object>, v8::Local<v8::Function>, int, v8::Local<v8::Value>*)’(声明于 ../../nan/nan.h:959) [-Wdeprecated-declarations]
    Nan::MakeCallback(Nan::GetCurrentContext()->Global(), (v8::Local<v8::Function>)dest->closure->fn, 2, end_argv);

    ^

    ../src/Canvas.cc: 在静态成员函数‘static void Canvas::ToBufferAsyncAfter(uv_work_t*)’中:
    ../src/Canvas.cc:211:31: 警告:不建议使用‘v8::Local<v8::Value> Nan::Callback::Call(int, v8::Local<v8::Value>*) const’(声明于 ../../nan/nan.h:1674) [-Wdeprecated-declarations]

    closure->pfn->Call(1, argv); ^

    ../src/Canvas.cc:216:31: 警告:不建议使用‘v8::Local<v8::Value> Nan::Callback::Call(int, v8::Local<v8::Value>*) const’(声明于 ../../nan/nan.h:1674) [-Wdeprecated-declarations]

    closure->pfn->Call(2, argv); ^

    ../src/Canvas.cc: 在静态成员函数‘static Nan::NAN_METHOD_RETURN_TYPE Canvas::ToBuffer(Nan::NAN_METHOD_ARGS_TYPE)’中:
    ../src/Canvas.cc:325:14: 警告:不建议使用‘v8::TryCatch::TryCatch()’(声明于 /root/.node-gyp/8.15.1/include/node/v8.h:8371):Use isolate version [-Wdeprecated-declarations]

    TryCatch try_catch; ^

    ../src/Canvas.cc: 在函数‘cairo_status_t streamPNG(void, const uint8_t, unsigned int)’中:
    ../src/Canvas.cc:357:102: 警告:不建议使用‘v8::Local<v8::Value> Nan::MakeCallback(v8::Local<v8::Object>, v8::Local<v8::Function>, int, v8::Local<v8::Value>*)’(声明于 ../../nan/nan.h:959) [-Wdeprecated-declarations]
    Nan::MakeCallback(Nan::GetCurrentContext()->Global(), (v8::Local<v8::Function>)closure->fn, 3, argv);

    ^

    ../src/Canvas.cc: 在静态成员函数‘static Nan::NAN_METHOD_RETURN_TYPE Canvas::StreamPNGSync(Nan::NAN_METHOD_ARGS_TYPE)’中:
    ../src/Canvas.cc:417:12: 警告:不建议使用‘v8::TryCatch::TryCatch()’(声明于 /root/.node-gyp/8.15.1/include/node/v8.h:8371):Use isolate version [-Wdeprecated-declarations]
    TryCatch try_catch;

    ^

    ../src/Canvas.cc:426:103: 警告:不建议使用‘v8::Local<v8::Value> Nan::MakeCallback(v8::Local<v8::Object>, v8::Local<v8::Function>, int, v8::Local<v8::Value>*)’(声明于 ../../nan/nan.h:959) [-Wdeprecated-declarations]

    Nan::MakeCallback(Nan::GetCurrentContext()->Global(), (v8::Local<v8::Function>)closure.fn, 1, argv); ^

    ../src/Canvas.cc:432:103: 警告:不建议使用‘v8::Local<v8::Value> Nan::MakeCallback(v8::Local<v8::Object>, v8::Local<v8::Function>, int, v8::Local<v8::Value>*)’(声明于 ../../nan/nan.h:959) [-Wdeprecated-declarations]

    Nan::MakeCallback(Nan::GetCurrentContext()->Global(), (v8::Local<v8::Function>)closure.fn, 1, argv); ^

    ../src/Canvas.cc: 在静态成员函数‘static Nan::NAN_METHOD_RETURN_TYPE Canvas::StreamJPEGSync(Nan::NAN_METHOD_ARGS_TYPE)’中:
    ../src/Canvas.cc:458:12: 警告:不建议使用‘v8::TryCatch::TryCatch()’(声明于 /root/.node-gyp/8.15.1/include/node/v8.h:8371):Use isolate version [-Wdeprecated-declarations]
    TryCatch try_catch;

    ^

    CXX(target) Release/obj.target/canvas/src/CanvasGradient.o
    CXX(target) Release/obj.target/canvas/src/CanvasPattern.o
    In file included from ../src/CanvasPattern.cc:9:0:
    ../src/Image.h:19:21: 致命错误:gif_lib.h:没有那个文件或目录
    #include <gif_lib.h>

    ^

    编译中断。
    make: * [Release/obj.target/canvas/src/CanvasPattern.o] 错误 1
    make: 离开目录“/root/express-ffmpeg/node_modules/canvas/build”
    gyp ERR! build error
    gyp ERR! stack Error: make failed with exit code: 2
    gyp ERR! stack at ChildProcess.onExit (/usr/lib/node_modules/npm/node_modules/node-gyp/lib/build.js:262:23)
    gyp ERR! stack at emitTwo (events.js:126:13)
    gyp ERR! stack at ChildProcess.emit (events.js:214:7)
    gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:198:12)
    gyp ERR! System Linux 3.10.0-957.el7.x86_64
    gyp ERR! command "/usr/bin/node" "/usr/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"
    gyp ERR! cwd /root/express-ffmpeg/node_modules/canvas
    gyp ERR! node -v v8.15.1
    gyp ERR! node-gyp -v v3.8.0
    gyp ERR! not ok
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: canvas@1.3.12 (node_modules/canvas):
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: canvas@1.3.12 install: node-gyp rebuild
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: Exit status 1

    up to date in 3.332s
    fixed 0 of 5 vulnerabilities in 831 scanned packages
    5 vulnerabilities required manual review and could not be updated
    [root@localhost express-ffmpeg]#

    1. Rat's
      @ki

      谷歌下错误

  2. adb

    这个只可以上传视频吗? 可以切指定文件夹的东西吗
    理想状态是切vps挂载的云盘
    或者大盘鸡已经下好的视频 貌似没这功能吧

    1. Rat's
      @adb

      可以将下载好的视频移到云转码目录的movies文件夹,然后在视频库点击导入,可以直接转码切片

      1. adb
        @Rat's

        32g内存 8HCPU 切一下午了 不是在waiting就是在trans&chunk
        是切得文件太大了? 4-6G单视频 mkv格式的
        博主可以看下我的站点 e.xiaohao.us

        1. Rat's
          @adb

          你这是VPS的配置吧,用独立服务器转码,而且快慢由cpu和分辨率大小决定,cpu性能越强越快,分辨率越小越快,而且要是单核cpu性能

          1. adb
            @Rat's

            今天换成了vultr Bare Metal
            Cpu E3-1270v6 8CPU 3.8GHZ 也是一样

            1. Rat's
              @adb

              建议你多了解下ffmpeg。

  3. qazwse11
    该评论仅登录用户及评论双方可见
    1. Rat's
      @qazwse11

      这个源码有点老,有空我看看,你看还能不能找点比较新的

      1. qazwse11
        @Rat's

        请问站长有没有速度好一点的动漫视频资源站。【现在网上的资源采集站太慢】

  4. 时间的历史

    不会安装的,可以看看我这个补充的教程,对常见问题的一个解决办法:http://www.feiji.work/?id=3

    1. Rat's
      @时间的历史

      其实更多的需要npm install这步如何能完美的安装成功,CPU 100%多半是npm install这步有问题,或者运行目录不对。

  5. kimi11

    在首页显示这个怎么回事?
    /root/express-ffmpeg/views/default/index.jade:18 16| .push-box 17| .push-img > 18| a(href="/movie/#{pushmovie.movieid._id}") 19| if pushmovie.movieid.poster 20| img(src="#{pushmovie.movieid.poster}") 21| else Cannot read property '_id' of null
    TypeError: /root/express-ffmpeg/views/default/index.jade:18

    16| .push-box 17| .push-img

    18| a(href="/movie/#{pushmovie.movieid._id}")

    19| if pushmovie.movieid.poster 20| img(src="#{pushmovie.movieid.poster}") 21| else

    Cannot read property '_id' of null

    at eval (eval at exports.compile (/root/express-ffmpeg/node_modules/jade/lib/index.js:218:8), <anonymous>:271:67) at eval (eval at exports.compile (/root/express-ffmpeg/node_modules/jade/lib/index.js:218:8), <anonymous>:388:4) at eval (eval at exports.compile (/root/express-ffmpeg/node_modules/jade/lib/index.js:218:8), <anonymous>:1033:22) at res (/root/express-ffmpeg/node_modules/jade/lib/index.js:219:38) at Object.exports.renderFile (/root/express-ffmpeg/node_modules/jade/lib/index.js:380:38) at Object.exports.renderFile (/root/express-ffmpeg/node_modules/jade/lib/index.js:370:21) at View.exports.__express [as engine] (/root/express-ffmpeg/node_modules/jade/lib/index.js:417:11) at View.render (/root/express-ffmpeg/node_modules/express/lib/view.js:135:8) at tryRender (/root/express-ffmpeg/node_modules/express/lib/application.js:640:10) at Function.render (/root/express-ffmpeg/node_modules/express/lib/application.js:592:3) at ServerResponse.render (/root/express-ffmpeg/node_modules/express/lib/response.js:1008:7) at /root/express-ffmpeg/controller/cms.js:71:11 at /root/express-ffmpeg/node_modules/async/dist/async.js:3888:9 at /root/express-ffmpeg/node_modules/async/dist/async.js:473:16 at iterateeCallback (/root/express-ffmpeg/node_modules/async/dist/async.js:992:24) at /root/express-ffmpeg/node_modules/async/dist/async.js:969:16 at /root/express-ffmpeg/node_modules/async/dist/async.js:3885:13 at /root/express-ffmpeg/controller/cms.js:38:13 at /root/express-ffmpeg/node_modules/mongoose/lib/model.js:4698:16 at /root/express-ffmpeg/node_modules/mongoose/lib/utils.js:263:16 at _hooks.execPost (/root/express-ffmpeg/node_modules/mongoose/lib/query.js:4074:11) at /root/express-ffmpeg/node_modules/kareem/index.js:135:16
    1. Rat's
      @kimi11

      这个看起来好像是你之前推荐过视频,然后删除造成的?是的话就再推荐几个,把删掉的补起来就好了

    2. kimi11
      @kimi11

      ssh报这个
      [root@vultr ~]# pm2 log
      [TAILING] Tailing last 15 lines for [all] processes (change the value with --lines option)
      /root/.pm2/pm2.log last 15 lines:
      PM2 | 2019-03-02T08:27:32: PM2 log: PM2 home : /root/.pm2
      PM2 | 2019-03-02T08:27:32: PM2 log: PM2 PID file : /root/.pm2/pm2.pid
      PM2 | 2019-03-02T08:27:32: PM2 log: RPC socket file : /root/.pm2/rpc.sock
      PM2 | 2019-03-02T08:27:32: PM2 log: BUS socket file : /root/.pm2/pub.sock
      PM2 | 2019-03-02T08:27:32: PM2 log: Application log path : /root/.pm2/logs
      PM2 | 2019-03-02T08:27:32: PM2 log: Process dump file : /root/.pm2/dump.pm2
      PM2 | 2019-03-02T08:27:32: PM2 log: Concurrent actions : 2
      PM2 | 2019-03-02T08:27:32: PM2 log: SIGTERM timeout : 1600
      PM2 | 2019-03-02T08:27:32: PM2 log: ===============================================================================
      PM2 | 2019-03-02T08:27:32: PM2 log: App [www:0] starting in -cluster mode-
      PM2 | 2019-03-02T08:27:32: PM2 log: App [www:0] online
      PM2 | 2019-03-02T08:58:51: PM2 log: App name:www id:0 disconnected
      PM2 | 2019-03-02T08:58:51: PM2 log: App [www:0] exited with code [0] via signal [SIGINT]
      PM2 | 2019-03-02T08:58:51: PM2 log: App [www:0] starting in -cluster mode-
      PM2 | 2019-03-02T08:58:51: PM2 log: App [www:0] online

      /root/.pm2/logs/www-error.log last 15 lines:
      0|www | (node:12123) DeprecationWarning: current URL string parser is deprecated, and will be removed in a future version. To use the new parser, pass option { useNewUrlParser: true } to MongoClient.connect.
      0|www | (node:12123) DeprecationWarning: collection.count is deprecated, and will be removed in a future version. Use collection.countDocuments or collection.estimatedDocumentCount instead
      0|www | (node:12123) DeprecationWarning: collection.findAndModify is deprecated. Use findOneAndUpdate, findOneAndReplace or findOneAndDelete instead.
      0|www | Error: Cannot take screenshots: neither a count nor a timemark list are specified
      0|www | at FfmpegCommand.proto.takeScreenshots.proto.thumbnail.proto.thumbnails.proto.screenshot.proto.screenshots (/root/express-ffmpeg/node_modules/fluent-ffmpeg/lib/recipes.js:132:15)
      0|www | at /root/express-ffmpeg/helper/newffmpeg.js:177:18
      0|www | at /root/express-ffmpeg/node_modules/mongoose/lib/model.js:4698:16
      0|www | at /root/express-ffmpeg/node_modules/mongoose/lib/utils.js:263:16
      0|www | at _hooks.execPost (/root/express-ffmpeg/node_modules/mongoose/lib/query.js:4074:11)
      0|www | at /root/express-ffmpeg/node_modules/kareem/index.js:135:16
      0|www | at process._tickCallback (internal/process/next_tick.js:61:11)
      0|www | (node:13126) DeprecationWarning: current URL string parser is deprecated, and will be removed in a future version. To use the new parser, pass option { useNewUrlParser: true } to MongoClient.connect.
      0|www | (node:13126) DeprecationWarning: collection.findAndModify is deprecated. Use findOneAndUpdate, findOneAndReplace or findOneAndDelete instead.
      0|www | (node:13126) DeprecationWarning: collection.count is deprecated, and will be removed in a future version. Use collection.countDocuments or collection.estimatedDocumentCount instead

      1. Rat's
        @kimi11

        这个看起来没啥问题。

  6. jiany

    [root@dcyksb express-ffmpeg]# npm install

    ^

    make: * [Release/obj.target/canvas/src/Canvas.o] 错误 1
    make: 离开目录“/www/wwwroot/bbs.dcyksb.com/express-ffmpeg/node_modules/canvas/build”
    gyp ERR! build error
    gyp ERR! stack Error: make failed with exit code: 2
    gyp ERR! stack at ChildProcess.onExit (/root/git/nvm/versions/node/v10.15.1/lib/node_modules/npm/node_modules/node-gyp/lib/build.js:262:23)
    gyp ERR! stack at ChildProcess.emit (events.js:189:13)
    gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:248:12)
    gyp ERR! System Linux 2.6.32-042stab134.3
    gyp ERR! command "/root/git/nvm/versions/node/v10.15.1/bin/node" "/root/git/nvm/versions/node/v10.15.1/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"
    gyp ERR! cwd /www/wwwroot/bbs.dcyksb.com/express-ffmpeg/node_modules/canvas
    gyp ERR! node -v v10.15.1
    gyp ERR! node-gyp -v v3.8.0
    gyp ERR! not ok
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: canvas@1.3.12 (node_modules/canvas):
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: canvas@1.3.12 install: node-gyp rebuild
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: Exit status 1

    audited 831 packages in 6.893s
    found 5 vulnerabilities (4 low, 1 high)
    run npm audit fix to fix them, or npm audit for details

    大佬这个是什么错误啊

    1. Rat's
      @jiany

      缺少依赖,不过运行完了就行,你先运行下程序,再使用pm2 log看下日志,然后再根据报错解决

  7. chanhey

    查看pm2日志显示

    Cannot process video: movies/舞蹈02《Sugar Free(无糖)》T-ara.movffmpeg exited with code 1: Conversion failed!
    0|www | (node:72581) DeprecationWarning: collection.count is deprecated, and will be removed in a future version. Use collection.countDocuments or collection.estimatedDocumentCount instead

    1. Rat's
      @chanhey

      这个不是问题,正常的报错。

  8. chanhey

    经常老是上传后点转码切片,服务器不执行ffmpeg转码,后台电影库里一直停留在trans&chunk,也不提示有什么错误...

    1. Rat's
      @chanhey

      设置问题,看下截图数那里,不能为0.

  9. 是我家宁子呀

    <html>
    <head><title>413 Request Entity Too Large</title></head>
    <body bgcolor="white">
    <center><h1>413 Request Entity Too Large</h1></center>
    <center>nginx/1.14.1</center>
    </body>
    </html>
    <!-- a padding to disable MSIE and Chrome friendly error page -->
    <!-- a padding to disable MSIE and Chrome friendly error page -->
    <!-- a padding to disable MSIE and Chrome friendly error page -->
    <!-- a padding to disable MSIE and Chrome friendly error page -->
    <!-- a padding to disable MSIE and Chrome friendly error page -->
    <!-- a padding to disable MSIE and Chrome friendly error page -->
    这个是什么错误啊

    1. Rat's
      @是我家宁子呀

      这个是nginx设置的body上传限制大小,要设置成大于4m

  10. 是我家宁子呀

    麻烦看一下这个是什么错误。PM2 错误日志显示的
    TypeError: Cannot read property 'usersystem' of undefined

    1. Rat's
      @是我家宁子呀

      这个是cms管理那里用户系统配置没保存

  11. A

    安装完毕,一切正常,然后登录后台,呵呵~502错误,看了博主的评论这是大部分人碰到的问题,却没有得到有效的解决

    1. Rat's
      @A

      502就是没安装成功,用下pm2 log看日志就知道了。

  12. 维他柠檬茶

    为什么创建并编辑 auth.js那里老是要报错啊

    1. Rat's
      @维他柠檬茶

      创建那里报错什么?

      1. 维他柠檬茶
        @Rat's

        commond not found

        1. Rat's
          @维他柠檬茶

          如果是centos系统的话,yum install nano -y就可以了

  13. 小迷糊

    高级版的安装脚本要付费吗

    1. Rat's
      @小迷糊

      这个其实是购买作者的高级版时赠送的脚本。

      1. 小迷糊
        @Rat's

        从你这儿买高级版多少钱啊

        1. Rat's
          @小迷糊

          我只是帮作者卖,便宜不了多少,有意的话可以加我留的微信。

  14. chanhey

    上传的影片一直waiting状态,不能转码,ffmpeg也有正确安装过了~

    1. Rat's
      @chanhey

      看下转码设置那里,截图数数量,一般最少为1,不然转码会有问题

  15. express-ffmpeg

    https://www.iqi360.com/category/5c386b74467870259b23b2e4

    express-ffmpeg官方技术支持

    Windows安装包已经开发结束

    1. Rat's
      @express-ffmpeg

      看来是时候公布我私藏很久的Linux一键脚本了。地址:https://www.iqi360.com/topic/5c431edf46eeb073833e356c

  16. MGe

    请问M3U8地址502是什么问题呢?

    1. Rat's
      @MGe

      直接访问的?看是不是防盗链的问题,只能播放器访问啥的,具体不是很清楚。

  17. 三番四复所发生

    虚拟机可以安装这个吗?

    1. Rat's
      @三番四复所发生

      应该不行。

  18. gscsds

    npm install
    提示这个怎么解决?
    found 4 vulnerabilities (3 low, 1 high)
    run npm audit fix to fix them, or npm audit for details

    1. Rat's
      @gscsds

      说npm有漏洞,要你修复,修复的命令已经给你了,npm audit fix。

      1. gscsds
        @Rat's

        弄好了,我用的是虚拟机,需要在虚拟机启动而不能再SSH那启动,搞不懂

        1. Rat's
          @gscsds

          直接用VPS服务器吧。

          1. gscsds
            @Rat's

            双十一双十二剁手到我已经把毒服取消了

            1. Rat's
              @gscsds

              没事,买买买!

  19. 行道

    站点配置之后,转码的状态是trans&chunk,分享的链接是404,请问是什么问题:
    Not Found
    404
    NotFoundError: Not Found

    1. 行道
      @行道 at /root/express-ffmpeg/app.js:265:8 at Layer.handle [as handle_request] (/root/express-ffmpeg/node_modules/express/lib/router/layer.js:95:5) at trim_prefix (/root/express-ffmpeg/node_modules/express/lib/router/index.js:317:13) at /root/express-ffmpeg/node_modules/express/lib/router/index.js:284:7 at Function.process_params (/root/express-ffmpeg/node_modules/express/lib/router/index.js:335:12) at next (/root/express-ffmpeg/node_modules/express/lib/router/index.js:275:10) at /root/express-ffmpeg/node_modules/connect-flash/lib/flash.js:21:5 at Layer.handle [as handle_request] (/root/express-ffmpeg/node_modules/express/lib/router/layer.js:95:5) at trim_prefix (/root/express-ffmpeg/node_modules/express/lib/router/index.js:317:13) at /root/express-ffmpeg/node_modules/express/lib/router/index.js:284:7 at Function.process_params (/root/express-ffmpeg/node_modules/express/lib/router/index.js:335:12) at next (/root/express-ffmpeg/node_modules/express/lib/router/index.js:275:10) at /root/express-ffmpeg/app.js:250:3 at Layer.handle [as handle_request] (/root/express-ffmpeg/node_modules/express/lib/router/layer.js:95:5) at trim_prefix (/root/express-ffmpeg/node_modules/express/lib/router/index.js:317:13) at /root/express-ffmpeg/node_modules/express/lib/router/index.js:284:7 at Function.process_params (/root/express-ffmpeg/node_modules/express/lib/router/index.js:335:12) at next (/root/express-ffmpeg/node_modules/express/lib/router/index.js:275:10) at SendStream.error (/root/express-ffmpeg/node_modules/serve-static/index.js:121:7) at emitOne (events.js:116:13) at SendStream.emit (events.js:211:7) at SendStream.error (/root/express-ffmpeg/node_modules/send/index.js:270:17)
      1. Rat's
        @行道

        这种错误貌似是没装好。

  20. 行道

    安装教程做了一遍,站点配置完了之后,打开域名是502,不懂问题出在哪里。

    1. 行道
      @行道

      问题找到了,缺少安装 redis,教程好像缺少这步骤,我是在宝塔安装 redis,就可以登陆系统了。

      1. Rat's
        @行道

        眼睛看哪了,安装宝塔那步就写了。

        1. 行道
          @Rat's

          不好意思,看走眼了。

  21. wowowowo

    secret是session需要的秘钥,这句怎么理解?secret: "yoursecret",这个里面填什么呢

    1. Rat's
      @wowowowo

      这个参数其实我也不大懂,不用管就行了。

  22. 123

    有没有什么办法让视频从头一直缓冲到尾 而不是每次只缓冲一点点 播放长视频老是会卡住

    1. 爱看动漫的小梁
      @123

      http直链调用也可以,这个不需要你搭建什么东西,你只需要ftp服务器环境即可

    2. 爱看动漫的小梁
      @123

      那你就这样,把视频上传到服务器,采用ftp方式调用

    3. Rat's
      @123

      卡说明本地到服务器网络不是很好。解决方法换个网络好点的服务器,或者装个锐速或BBR。

      1. 123
        @Rat's

        这个我知道但是并不容易解决 服务器和网络 这个涉及到高成本了 我记得以前就可以直接缓冲完整个视频 后来改成每次一点了 改代码可比加钱容易多了/滑稽 就是不知道要改哪里

        1. Rat's
          @123

          这个我不是很清楚,只知道加钱可及!

  23. 爱看动漫的小梁

    对了,微信可否一加?

  24. 爱看动漫的小梁

    奇怪?腾讯云
    版本号:CentOS Linux 7.2.1511 (Core)
    远程ssh会显示:root@VM_8_20_centos ~
    耗时:38分钟完成云转码的全部安装,环境全部由宝塔完成安装。
    我靠!看来宝塔对腾讯云的主机兼容性真心好,云转码启动完全无任何问题!

  25. 爱看动漫的小梁

    如果npm命令到一半卡住不动怎么解决

    1. Rat's
      @爱看动漫的小梁

      断开重新运行,或者等。

      1. 爱看动漫的小梁
        @Rat's

        那个,腾讯云只需要38分钟就完全安装并运行

      2. 爱看动漫的小梁
        @Rat's

        duan kai重新运行是什么意思

      3. 爱看动漫的小梁
        @Rat's

        我等了几个小时

  26. 爱看动漫的小梁

    妈耶,不用宝塔安装PM2了,上次利用腾讯云实验室也就是体验1小时机器,都可以在一小时内完成安装环境与云转码,但我等了3小时还是卡在NOW Using node v10.14.1(npm v6.4.1)这就不动了,MongoDB我觉得勉强可以继续宝塔,但PM2老是卡住,已经耗了2天了

    1. Rat's
      @爱看动漫的小梁

      Mongodb用宝塔问题不大,Nodejs手动安装可以解决很多问题。

  27. 爱看动漫的小梁

    要想成功安装云转码,并且运行不占100%
    01.多尝试安装宝塔与环境,直到云转码启动正常不占用100%(CPU)。
    02.手动安装环境为最佳!

    友情说明:我那次上传了48个视频,完美运行(已重装宝塔与环境还有云转码n次)

    1. 落伍者
      @爱看动漫的小梁

      各种失败,docker成功。一直想手动弄环境,可是一直没成功

      1. 爱看动漫的小梁
        @落伍者

        相信我,手动比容器模式好多,但前提是,你经得起折磨,经不起就勉为其难的容器模式吧!

      2. Rat's
        @落伍者

        这个要是不容易出错的话,我也不会专门花时间做Docker镜像。

    2. Rat's
      @爱看动漫的小梁

      辛苦了,这个提示等后面的人看到吧。

  28. 爱看动漫的小梁

    前天由于存储硬盘分区扩容失败后,已经对虚拟机进行了重新安装云转码,结果,启动100%CPU,要么就是安装命令一直卡在一个地方,要么宝塔MongoDB数据库建立成功却不显示已创建的数据库要么PM2异常安装,看来是宝塔各种问题导致就算安装成功,启动云转码也是100%CPU!

    1. Rat's
      @爱看动漫的小梁

      是的,有时候宝塔对这些是有些问题,但对于会玩的来说,不算啥问题,手动方法我已经写在文章最后面了,你可以看下。

      1. 爱看动漫的小梁
        @Rat's

        会玩的,压根没问题,对于我们这些不熟悉的人来说,不太好搞!

        1. Rat's
          @爱看动漫的小梁

          所以我额外在下面补了部分手动教程,基本上坑都在那里。

  29. 阿远

    我的N遍错误。

    1. Rat's
      @阿远

      看来宝塔不是很适合装Nodejs和Mongodb,我加点手动教程吧。

      1. 小飞飞飞飞飞
        @Rat's

        是不是不需要用宝塔安装PM2管理器了呀
        secret: "yoursecret", 这个要替换吗。。。
        求指点 。。。。。。。。

        1. Rat's
          @小飞飞飞飞飞

          是的,不需要安装pm2了。

          1. 小飞飞飞飞飞
            @Rat's

            自动截图正常。。。视频也显示了 就是不能播放视频。点击播放没啥反应,,。。
            大佬这是那的姿势不对呀

            1. Rat's
              @小飞飞飞飞飞

              设置那里要设置下播放器。

  30. shaoye

    终于搭建成功了 但是404页面 又爆出at /root/express-ffmpeg/app.js:265:8

    at Layer.handle [as handle_request] (/root/express-ffmpeg/node_modules/express/lib/router/layer.js:95:5) at trim_prefix (/root/express-ffmpeg/node_modules/express/lib/router/index.js:317:13) at /root/express-ffmpeg/node_modules/express/lib/router/index.js:284:7 at Function.process_params (/root/express-ffmpeg/node_modules/express/lib/router/index.js:335:12) at next (/root/express-ffmpeg/node_modules/express/lib/router/index.js:275:10) at /root/express-ffmpeg/node_modules/connect-flash/lib/flash.js:21:5 at Layer.handle [as handle_request] (/root/express-ffmpeg/node_modules/express/lib/router/layer.js:95:5) at trim_prefix (/root/express-ffmpeg/node_modules/express/lib/router/index.js:317:13) at /root/express-ffmpeg/node_modules/express/lib/router/index.js:284:7 at Function.process_params (/root/express-ffmpeg/node_modules/express/lib/router/index.js:335:12) at next (/root/express-ffmpeg/node_modules/express/lib/router/index.js:275:10) at /root/express-ffmpeg/app.js:250:3 at Layer.handle [as handle_request] (/root/express-ffmpeg/node_modules/express/lib/router/layer.js:95:5) at trim_prefix (/root/express-ffmpeg/node_modules/express/lib/router/index.js:317:13) at /root/express-ffmpeg/node_modules/express/lib/router/index.js:284:7 at Function.process_params (/root/express-ffmpeg/node_modules/express/lib/router/index.js:335:12) at next (/root/express-ffmpeg/node_modules/express/lib/router/index.js:275:10) at SendStream.error (/root/express-ffmpeg/node_modules/serve-static/index.js:121:7) at emitOne (events.js:115:13) at SendStream.emit (events.js:210:7) at SendStream.error (/root/express-ffmpeg/node_modules/send/index.js:270:17
    1. Rat's
      @shaoye

      这个问题不是很清楚,多半还是安装有点小瑕疵。

  31. shaoye

    装了几遍全程无报错,依旧502 官方活了NG反代会报502 执行一段 代码 就可以 但是依旧包错502 ,泪奔啊

    1. Rat's
      @shaoye

      那就是姿势有点小问题了,我都一次成功。

  32. soradaisuki

    点击转码就报错
    at ChildProcess.<anonymous> (/root/express-ffmpeg/node_modules/fluent-ffmpeg/lib/ffprobe.js:233:22)

    at emitTwo (events.js:125:13) at ChildProcess.emit (events.js:213:7) at Process.ChildProcess._handle.onexit (internal/child_process.js:197:12)
    events.js:182

    throw er; // Unhandled 'error' event ^
    TypeError: Cannot read property 'format' of undefined

    at /root/express-ffmpeg/helper/listsffmpeg.js:48:35 at /root/express-ffmpeg/node_modules/mongoose/lib/model.js:4518:16 at (anonymous function).call (/root/express-ffmpeg/node_modules/mongoose/lib/query.js:3800:7) at process.nextTick (/root/express-ffmpeg/node_modules/mongoose/lib/helpers/query/completeMany.js:35:39) at _combinedTickCallback (internal/process/next_tick.js:95:7) at process._tickCallback (internal/process/next_tick.js:161:9)

    1. soradaisuki
      @soradaisuki

      懂了 原来是没有找到文件,应该是上传的时候出了问题吧

      1. soradaisuki
        @soradaisuki

        宝塔的pm2有点问题...

        1. Rat's
          @soradaisuki

          感觉pm2和mongodb都有点问题

      2. Rat's
        @soradaisuki

        你可以看下movie文件夹有不有上传的视频,然后检查下有不有可读权限。

        1. soradaisuki
          @Rat's

          之前问题是解决了,但是视频播放只有封面23333,声音倒是有的

          1. Rat's
            @soradaisuki

            这个倒不是很清楚,使用方面没深入研究。

        2. 爱看动漫的小梁
          @Rat's

          不正常,因为我都注意数据变化,转码时CPU多少,不转码时是多少

  33. 爱看动漫的小梁

    安装成功,已上传4个视频,但vm状态下,需要快照来维持状态,要不然可能出现CPU100%

    1. Rat's
      @爱看动漫的小梁

      恭喜,这是折腾个把月了吧,貌似cpu100%很正常

  34. 爱看动漫的小梁

    为什么CentOS 7 64 还是报错这个?
    gyp ERR! build error
    gyp ERR! stack Error: make failed with exit code: 2
    gyp ERR! stack at ChildProcess.onExit (/www/server/nvm/versions/node/v10.13.0/lib/node_modules/npm/node_modules/node-gyp/lib/build.js:262:23)
    gyp ERR! stack at ChildProcess.emit (events.js:182:13)
    gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:240:12)
    gyp ERR! System Linux 3.10.0-862.el7.x86_64
    gyp ERR! command "/www/server/nvm/versions/node/v10.13.0/bin/node" "/www/server/nvm/versions/node/v10.13.0/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"
    gyp ERR! cwd /root/express-ffmpeg/node_modules/canvas
    gyp ERR! node -v v10.13.0
    gyp ERR! node-gyp -v v3.8.0
    gyp ERR! not ok

    1. wowowowo
      @爱看动漫的小梁

      怎么解决的?我就是这个错误,装了好几次

      1. Rat's
        @wowowowo

        卸载pm2,用文章下面的方法手动安装nodejs。

        1. wowwoo
          @Rat's

          删除PM2试过了,全部都是手动安装,依然报错
          gyp ERR! configure error
          gyp ERR! stack Error: gyp failed with exit code: 1
          网上有人说是gcc版本的问题,升级到5.5问题依然没有解决
          还有人删除node-gyp,都试过了,没有用,我是centos7,卡在这里2天了
          现在准备换NODE版本试试,解决过这个问题的能不能说说是什么原因

          1. Rat's
            @wowwoo

            重新来,别安装pm2,直接手动nodejs。

            1. wowowow
              @Rat's

              从头来还是这个报错,没有装PM2
              应该跟GCC的版本有关,我的是4.8
              网上说要5以上的

              1. Rat's
                @wowowow

                是CentOS 7吗?我记得我在很多台的C7的服务器上面都一次性装成功了,并没有遇到gcc版本的问题。

                1. 往往
                  @Rat's

                  各种centos7版本都报这个错,要手动安装各种cairo cairo-devel cairomm-devel等等
                  好多,终于不报错了,尼玛又卡在要下载什么模块
                  sharp@0.20.8 install /www/wwwroot/express-ffmpeg/node_modules/sharp
                  (node install/libvips && node install/dll-copy && prebuild-install) || (node-gyp rebuild && node install/dll-copy)
                  info sharp Downloading https://github.com/lovell/sharp-libvips/releases/download/v8.6.1/libvips-8.6.1-linux-x64.tar.gz
                  用V7N才能下载,最后总算搞好了,npm install终于不报错了
                  打开后台无法连接,你们安装感觉好简单

                  1. Rat's
                    @往往

                    安装方法确实挺简单的,但就是容易出错。

    2. 感谢
      @爱看动漫的小梁

      gyp ERR! configure error
      gyp ERR! stack Error: gyp failed with exit code: 1
      gyp ERR! stack at ChildProcess.onCpExit (/www/server/nvm/versions/node/v8.3.0/lib/node_modules/npm/node_modules/node-gyp/lib/configure.js:336:16)
      gyp ERR! stack at emitTwo (events.js:125:13)
      gyp ERR! stack at ChildProcess.emit (events.js:213:7)
      gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:200:12)
      gyp ERR! System Linux 4.12.9-041209-generic
      gyp ERR! command "/www/server/nvm/versions/node/v8.3.0/bin/node" "/www/server/nvm/versions/node/v8.3.0/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"
      gyp ERR! cwd /www/wwwroot/express-ffmpeg/node_modules/canvas
      gyp ERR! node -v v8.3.0
      gyp ERR! node-gyp -v v3.6.2
      gyp ERR! not ok

      1. Rat's
        @感谢

        我加点手动教程吧,应该就可以解决了。

    3. 感谢
      @爱看动漫的小梁

      我的问题和你一样,请问你是怎么解决的

  35. 虾哈

    为什么进不了后台,输入密码后跳转到百度了。

    1. Rat's
      @虾哈

      因为你密码输入错误,就会直接跳百度

  36. 123

    为啥视频状态不更新呢 明明已经转完了
    开了秒切就是chunking 关闭秒切就是trans&chunk
    完成后cpu负载是0% 进文件夹里看已经转好切好了 但是状态就是不更新finished
    点分享也点不了

    1. 123
      @123

      直接用链接打开视频是一片黑的

      1. Rat's
        @123

        会不会是你后台没设置好?比如截图数啥的,使用pm2 log查看下日志。

        1. 123
          @Rat's

          截图数是0 等了好一会 状态一直显示chunking 实际上已经切好了 cpu也一直是0% 然后复制链接可以播了 过了一天去看状态还是chunking 但不影响播放 算是搞定了 谢谢你的教程 下一步就是找个网络快的服务器了 不然上传视频太慢

          1. Rat's
            @123

            截图貌似不能为0,下次你可以试试我那个docker镜像?https://www.moerats.com/archives/782

            1. 123
              @Rat's

              我是分享到其他网站播放 不用自带cms 所以截图没用吧
              docker有机会再试 先找服务器 大硬盘国内网络快的 有推荐吗

              1. Rat's
                @123

                看看这个,cn2 gia便宜的大硬盘https://www.moerats.com/archives/748/。

                1. 123
                  @Rat's

                  收藏了 看看他们黑五有没有优惠

                  1. Rat's
                    @123

                    他那个大盘鸡就是特价。

                    1. 123
                      @Rat's

                      他们这大盘鸡 允许资源长期满载吗 如果要转码 cpu长期跑满 播视频网络也会大量占用 不会封吗?

                      1. Rat's
                        @123

                        他们的老板很好说话,你可以工单问下。

  37. 海天

    博主 有没有类似的好的 PDF管理程序啊 推荐个啊 万分感谢

    1. Rat's
      @海天

      这个我得注意下,知道了回复你,有邮件通知。

  38. 123
    运行npm install错误 node版本 v8.0 v8.1都试过了

    gyp ERR! build error
    gyp ERR! stack Error: make failed with exit code: 2
    gyp ERR! stack at ChildProcess.onExit (/www/server/nvm/versions/node/v8.0.0/lib/node_modules/npm/node_modules/node-gyp/lib/build.js:285:23)
    gyp ERR! stack at emitTwo (events.js:125:13)
    gyp ERR! stack at ChildProcess.emit (events.js:213:7)
    gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:197:12)
    gyp ERR! System Linux 2.6.32-042stab129.1
    gyp ERR! command "/www/server/nvm/versions/node/v8.0.0/bin/node" "/www/server/nvm/versions/node/v8.0.0/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"
    gyp ERR! cwd /root/express-ffmpeg/node_modules/sharp
    gyp ERR! node -v v8.0.0
    gyp ERR! node-gyp -v v3.6.1
    gyp ERR! not ok
    npm ERR! code ELIFECYCLE
    npm ERR! errno 1
    npm ERR! sharp@0.20.8 install: (node install/libvips && node install/dll-copy && prebuild-install) || (node-gyp rebuild && node install/dll-copy)
    npm ERR! Exit status 1
    npm ERR!
    npm ERR! Failed at the sharp@0.20.8 install script.

    npm ERR! This is probably not a problem with npm. There is likely additional logging output above.

    log日志
    1743 verbose stack Error: sharp@0.20.8 install: (node install/libvips && node install/dll-copy && prebuild-install) || (node-gyp rebuild && node install/dll-copy)
    1750 error code ELIFECYCLE
    1751 error errno 1
    1752 error sharp@0.20.8 install: (node install/libvips && node install/dll-copy && prebuild-install) || (node-gyp rebuild && node install/dll-copy)
    1752 error Exit status 1
    1753 error Failed at the sharp@0.20.8 install script.
    1753 error This is probably not a problem with npm. There is likely additional logging output above.

    1. 123
      @123

      网上搜了其他教程 有人说云转码更新了 教程不起作用了

      1. Rat's
        @123

        我这个管用的,一直尽量保证最新。

        1. 123
          @Rat's

          那能不能看一下我上面的错误日志是什么原因?
          Failed at the sharp@0.20.8 install script 脚本错误?

          1. Rat's
            @123

            你这是缺少点依赖,而且错误日志关键地方貌似没留,还有系统是什么。

  39. 猫猫

    make: * [Release/obj.target/canvas/src/Canvas.o] Error 1
    make: Leaving directory `/root/express-ffmpeg/node_modules/node-sprite-generator/node_modules/canvas/build'
    gyp ERR! build error
    gyp ERR! stack Error: make failed with exit code: 2
    gyp ERR! stack at ChildProcess.onExit (/www/server/nvm/versions/node/v10.13.0/lib/node_modules/npm/node_modules/node-gyp/lib/build.js:262:23)
    gyp ERR! stack at ChildProcess.emit (events.js:182:13)
    gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:240:12)
    gyp ERR! System Linux 3.10.0-862.3.2.el7.x86_64
    gyp ERR! command "/www/server/nvm/versions/node/v10.13.0/bin/node" "/www/server/nvm/versions/node/v10.13.0/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"
    gyp ERR! cwd /root/express-ffmpeg/node_modules/node-sprite-generator/node_modules/canvas
    gyp ERR! node -v v10.13.0
    gyp ERR! node-gyp -v v3.8.0
    gyp ERR! not ok
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: canvas@1.3.12 (node_modules/node-sprite-generator/node_modules/canvas):
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: canvas@1.3.12 install: node-gyp rebuild
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: Exit status 1

    audited 893 packages in 3.411s
    found 4 vulnerabilities (3 low, 1 high)
    run npm audit fix to fix them, or npm audit for details

    1. Rat's
      @猫猫

      这个错误不全,建议你在宝塔软件管理的pm2,把nodejs版本调到v8,然后再有错误可以留下言,别留太多,只需要Error字符出现的上下几排。

  40. 爱看动漫的小梁

    请问vm的虚拟机可以安装吗

    1. Rat's
      @爱看动漫的小梁

      这个没试过。

  41. 爱看动漫的小梁

    secret是session需要的秘钥
    这个复制代码即可???

  42. ThinkVN

    please tell me, state watting longtime
    thanks.

    1. Rat's
      @ThinkVN

      what?

  43. 爱看动漫的小梁

    CXX(target) Release/obj.target/canvas/src/CanvasGradient.o
    CXX(target) Release/obj.target/canvas/src/CanvasPattern.o
    In file included from ../src/CanvasPattern.cc:9:0:
    ../src/Image.h:19:21: 致命错误:gif_lib.h:没有那个文件或目录
    #include <gif_lib.h>

    ^

    编译中断。
    make: * [Release/obj.target/canvas/src/CanvasPattern.o] 错误 1
    make: 离开目录“/www/wwwroot/express-ffmpeg/node_modules/canvas/build”
    gyp ERR! build error
    gyp ERR! stack Error: make failed with exit code: 2
    gyp ERR! stack at ChildProcess.onExit (/www/server/nvm/versions/node/v8.12.0/lib/node_modules/npm/node_modules/node-gyp/lib/build.js:262:23)
    gyp ERR! stack at emitTwo (events.js:126:13)
    gyp ERR! stack at ChildProcess.emit (events.js:214:7)
    gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:198:12)
    gyp ERR! System Linux 3.10.0-862.el7.x86_64
    gyp ERR! command "/www/server/nvm/versions/node/v8.12.0/bin/node" "/www/server/nvm/versions/node/v8.12.0/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"
    gyp ERR! cwd /www/wwwroot/express-ffmpeg/node_modules/canvas
    gyp ERR! node -v v8.12.0
    gyp ERR! node-gyp -v v3.8.0
    gyp ERR! not ok

    sharp@0.20.8 install /www/wwwroot/express-ffmpeg/node_modules/sharp
    (node install/libvips && node install/dll-copy && prebuild-install) || (node-gyp rebuild && node install/dll-copy)

    info sharp Downloading https://github.com/lovell/sharp-libvips/releases/download/v8.6.1/libvips-8.6.1-linux-x64.tar.gz
    npm notice created a lockfile as package-lock.json. You should commit this file.
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: canvas@1.3.12 (node_modules/canvas):
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: canvas@1.3.12 install: node-gyp rebuild
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: Exit status 1

    added 385 packages from 408 contributors and audited 796 packages in 1127.664s
    found 4 vulnerabilities (3 low, 1 high)
    run npm audit fix to fix them, or npm audit for details

    这次是centos 7 64位

    1. Rat's
      @爱看动漫的小梁

      我刚测试的无任何问题,教程的一些细节我也加了点,你还是检查下你的操作吧。

      1. 爱看动漫的小梁
        @Rat's

        请问,你的CentOS 7是什么版本!

        1. Rat's
          @爱看动漫的小梁

          CentOS 7系统。

          1. 爱看动漫的小梁
            @Rat's

            请问,宝塔安装那四个环境,极速安装还是编译安装?

            1. Rat's
              @爱看动漫的小梁

              先极速,有问题就编译。

    2. Rat's
      @爱看动漫的小梁

      我晚上试试看吧。

  44. 爱看动漫的小梁

    安装报错啊
    root@ubuntu:/www/wwwroot/express-ffmpeg# npm install
    npm WARN deprecated crypto@1.0.1: This package is no longer supported. It's now a built-in Node module. If you've depended on crypto, you should switch to the one that's built-in.
    npm WARN deprecated jade@1.11.0: Jade has been renamed to pug, please install the latest version of pug instead of jade
    npm WARN deprecated constantinople@3.0.2: Please update to at least constantinople 3.1.1
    npm WARN deprecated transformers@2.1.0: Deprecated, use jstransformer
    npm WARN deprecated minimatch@2.0.10: Please update to minimatch 3.0.2 or higher to avoid a RegExp DoS issue

    canvas@1.3.12 install /www/wwwroot/express-ffmpeg/node_modules/canvas
    node-gyp rebuild

    Package cairo was not found in the pkg-config search path.
    Perhaps you should add the directory containing `cairo.pc'
    to the PKG_CONFIG_PATH environment variable
    No package 'cairo' found
    gyp: Call to './util/has_lib.sh freetype' returned exit status 0 while in binding.gyp. while trying to load binding.gyp
    gyp ERR! configure error
    gyp ERR! stack Error: gyp failed with exit code: 1
    gyp ERR! stack at ChildProcess.onCpExit (/www/server/nvm/versions/node/v8.12.0/lib/node_modules/npm/node_modules/node-gyp/lib/configure.js:345:16)
    gyp ERR! stack at emitTwo (events.js:126:13)
    gyp ERR! stack at ChildProcess.emit (events.js:214:7)
    gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:198:12)
    gyp ERR! System Linux 4.15.0-29-generic
    gyp ERR! command "/www/server/nvm/versions/node/v8.12.0/bin/node" "/www/server/nvm/versions/node/v8.12.0/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"
    gyp ERR! cwd /www/wwwroot/express-ffmpeg/node_modules/canvas
    gyp ERR! node -v v8.12.0
    gyp ERR! node-gyp -v v3.8.0
    gyp ERR! not ok

    sharp@0.20.8 install /www/wwwroot/express-ffmpeg/node_modules/sharp
    (node install/libvips && node install/dll-copy && prebuild-install) || (node-gyp rebuild && node install/dll-copy)

    info sharp Downloading https://github.com/lovell/sharp-libvips/releases/download/v8.6.1/libvips-8.6.1-linux-x64.tar.gz
    npm notice created a lockfile as package-lock.json. You should commit this file.
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: canvas@1.3.12 (node_modules/canvas):
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: canvas@1.3.12 install: node-gyp rebuild
    npm WARN optional SKIPPING OPTIONAL DEPENDENCY: Exit status 1

    added 385 packages from 408 contributors in 123.028s
    root@ubuntu:/www/wwwroot/express-ffmpeg#

    是gyp开头的报错

    1. Rat's
      @爱看动漫的小梁

      有点像gcc问题,安装下开发者工具包看看,yum -y groupinstall "Development Tools",再有问题建议百度一下。

      1. 爱看动漫的小梁
        @Rat's

        我用的还是Ubuntu 64位系统,这个命令真的合适吗

        1. Rat's
          @爱看动漫的小梁

          忘了,我以为你会按照我的建议用CentOS 7。

  45. 爱看动漫的小梁

    版本貌似都更新了,这个教程还有效吗?我安装还是有几处提示错误的gyp ERR!

    1. Rat's
      @爱看动漫的小梁

      看了下源码,这个安装教程没啥问题,你可以去研究下官方文档https://ffmpeg.moejj.com/guide/install.html。

  46. 爱看动漫的小梁

    最新安装出新
    gyp ERR! stack at emitTwo (events.js:87:13)
    gyp ERR! stack at ChildProcess.emit (events.js:172:7)
    gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:200:12)
    gyp ERR! System Linux 4.15.0-29-generic
    gyp ERR! command "/usr/bin/nodejs" "/usr/bin/node-gyp" "rebuild"
    gyp ERR! cwd /www/wwwroot/express-ffmpeg/node_modules/canvas
    gyp ERR! node -v v4.2.6
    gyp ERR! node-gyp -v v3.0.3
    gyp ERR! not ok
    npm WARN install:canvas@1.3.12 canvas@1.3.12 install: node-gyp rebuild
    npm WARN install:canvas@1.3.12 Exit status 1

    sharp@0.20.8 install /www/wwwroot/express-ffmpeg/node_modules/sharp
    (node install/libvips && node install/dll-copy && prebuild-install) || (node-gyp rebuild && node install/dll-copy)

    sh: node: 未找到命令
    /bin/sh: node: 未找到命令
    gyp: Call to 'node -e "console.log(require('./lib/libvips').pkgConfigPath())"' returned exit status 127 while in binding.gyp. while trying to load binding.gyp
    gyp ERR! configure error
    gyp ERR! stack Error: gyp failed with exit code: 1
    gyp ERR! stack at ChildProcess.onCpExit (/usr/share/node-gyp/lib/configure.js:354:16)
    gyp ERR! stack at emitTwo (events.js:87:13)
    gyp ERR! stack at ChildProcess.emit (events.js:172:7)
    gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:200:12)
    gyp ERR! System Linux 4.15.0-29-generic
    gyp ERR! command "/usr/bin/nodejs" "/usr/bin/node-gyp" "rebuild"
    gyp ERR! cwd /www/wwwroot/express-ffmpeg/node_modules/sharp
    gyp ERR! node -v v4.2.6
    gyp ERR! node-gyp -v v3.0.3
    gyp ERR! not ok
    npm ERR! Linux 4.15.0-29-generic
    npm ERR! argv "/usr/bin/nodejs" "/usr/bin/npm" "install"
    npm ERR! node v4.2.6
    npm ERR! npm v3.5.2
    npm ERR! code ELIFECYCLE

    npm ERR! sharp@0.20.8 install: (node install/libvips && node install/dll-copy && prebuild-install) || (node-gyp rebuild && node install/dll-copy)
    npm ERR! Exit status 1
    npm ERR!
    npm ERR! Failed at the sharp@0.20.8 install script '(node install/libvips && node install/dll-copy && prebuild-install) || (node-gyp rebuild && node install/dll-copy)'.
    npm ERR! Make sure you have the latest version of node.js and npm installed.
    npm ERR! If you do, this is most likely a problem with the sharp package,
    npm ERR! not with npm itself.
    npm ERR! Tell the author that this fails on your system:
    npm ERR! (node install/libvips && node install/dll-copy && prebuild-install) || (node-gyp rebuild && node install/dll-copy)
    npm ERR! You can get information on how to open an issue for this project with:
    npm ERR! npm bugs sharp
    npm ERR! Or if that isn't available, you can get their info via:
    npm ERR! npm owner ls sharp
    npm ERR! There is likely additional logging output above.

    npm ERR! Please include the following file with any support request:
    npm ERR! /www/wwwroot/express-ffmpeg/npm-debug.log
    Ubuntu 64位系统

    1. Rat's
      @爱看动漫的小梁

      提示node命令未找到,你可以去面板管理那里卸载pm2,再重新安装,建议你使用CentOS系统。

  47. gscsds

    大佬,后台登录提示此页面不能正确地重定向

    1. Rat's
      @gscsds

      是打不开么?检查下域名设置什么的看看。

      1. gscsds
        @Rat's

        不是,是在admin/下输入正确的账号密码后就会无限重定向,直接ip访问也是这样

        1. Rat's
          @gscsds

          这个问题还没遇到过,你清空缓存看看?

          1. gscsds
            @Rat's

            清空过,火狐的隐私模式,和换浏览器都一样

            1. Rat's
              @gscsds

              这个就不是很清楚了。

              1. gscsds
                @Rat's

                后台登录页不能是admin,会无限跳转,终于知道了

                1. Rat's
                  @gscsds

                  是的,我也发现了,所以我下午改了下教程。

  48. 咔嚓

    请问这个错误实怎么回事啊
    Package cairo was not found in the pkg-config search path.
    Perhaps you should add the directory containing `cairo.pc'
    to the PKG_CONFIG_PATH environment variable
    No package 'cairo' found
    gyp: Call to './util/has_lib.sh freetype' returned exit status 0 while in binding.gyp. while trying to load binding.gyp
    gyp ERR! configure error
    gyp ERR! stack Error: gyp failed with exit code: 1
    gyp ERR! stack at ChildProcess.onCpExit (/www/server/nvm/versions/node/v8.12.0/lib/node_modules/npm/node_modules/node-gyp/lib/configure.js:345:16)
    gyp ERR! stack at emitTwo (events.js:126:13)
    gyp ERR! stack at ChildProcess.emit (events.js:214:7)
    gyp ERR! stack at Process.ChildProcess._handle.onexit (internal/child_process.js:198:12)
    gyp ERR! System Linux 4.4.0-28-generic
    gyp ERR! command "/www/server/nvm/versions/node/v8.12.0/bin/node" "/www/server/nvm/versions/node/v8.12.0/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"
    gyp ERR! cwd /root/express-ffmpeg/node_modules/canvas
    gyp ERR! node -v v8.12.0
    gyp ERR! node-gyp -v v3.8.0
    gyp ERR! not ok

    1. Rat's
      @咔嚓

      什么系统?CentOS的话可以yum install cairo cairo-devel -y,Debian可以试试apt-get install libcairo2-dev libjpeg-dev libgif-dev -y

  49. 海天

    博主 有没有文档、pdf和这个视频功能一整套的系统推荐啊

    1. Rat's
      @海天

      暂时没发现。

  50. 寒惜

    第三步那里 执行了npm install express -gd
    出现
    -bash: npm: command not found
    想问下博主这个怎么解决?百度谷歌了一圈还是没解决。。

    1. Rat's
      @寒惜

      面板安装PM2管理器后需要重新进入ssh才行。

  51. 墨池

    创建并编辑auth.js配置文件:
    ssh输入这个nano auth.js提示
    -bash: nano: command not found
    怎么办

    1. Rat's
      @墨池

      善用搜索,缺少nano命令,yum install nano -y。

  52. 墨池

    大佬 能出个视频教程就好了!

  53. sam

    gyp WARN install got an error, rolling back install
    gyp ERR! configure error
    gyp ERR! stack Error: This is most likely not a problem with node-gyp or the package itself and
    gyp ERR! stack is related to network connectivity. In most cases you are behind a proxy or have bad
    gyp ERR! stack network settings.
    gyp ERR! stack at Request.<anonymous> (/www/server/nvm/versions/node/v8.11.3/lib/node_modules/npm/node_modules/node-gyp/lib/install.js:193:21)
    gyp ERR! stack at emitOne (events.js:116:13)
    gyp ERR! stack at Request.emit (events.js:211:7)
    gyp ERR! stack at Request.onRequestError (/www/server/nvm/versions/node/v8.11.3/lib/node_modules/npm/node_modules/request/request.js:878:8)
    gyp ERR! stack at emitOne (events.js:116:13)
    gyp ERR! stack at ClientRequest.emit (events.js:211:7)
    gyp ERR! stack at TLSSocket.socketErrorListener (_http_client.js:387:9)
    gyp ERR! stack at emitOne (events.js:116:13)
    gyp ERR! stack at TLSSocket.emit (events.js:211:7)
    gyp ERR! stack at emitErrorNT (internal/streams/destroy.js:64:8)
    gyp ERR! System Linux 3.10.0-862.3.2.el7.x86_64
    gyp ERR! command "/www/server/nvm/versions/node/v8.11.3/bin/node" "/www/server/nvm/versions/node/v8.11.3/lib/node_modules/npm/node_modules/node-gyp/bin/node-gyp.js" "rebuild"
    gyp ERR! cwd /root/express-ffmpeg/node_modules/canvas
    gyp ERR! node -v v8.11.3
    gyp ERR! node-gyp -v v3.6.2
    gyp ERR! not ok

    1. Rat's
      @sam

      试下这个命令:export ATOM_NODE_URL=http://gh-contractor-zcbenz.s3.amazonaws.com/atom-shell/dist。然后再安装。

  54. 仙侠

    全部按照步骤执行完,然后网站还是打不开,IP和反代地址都打不开

    1. Rat's
      @仙侠

      建议用CentOS7系统,然后照着教程一步步来,中途出现问题可以留言。

      1. 仙侠
        @Rat's

        就是centos7

        1. Rat's
          @仙侠

          如果所有操作没出现错误提示的话,你检查下数据库什么的在线不,还不行的话就没法了。

  55. 爱看动漫的小梁

    一直100

  56. 爱看动漫的小梁

    转码如何取消吧

    1. Rat's
      @爱看动漫的小梁

      这个自己可以研究下,我搭建好了,就测了下转码就没管了。

      1. 爱看动漫的小梁
        @Rat's

        这,怎么办,CPU100%了

        1. Rat's
          @爱看动漫的小梁

          转码的时候是100%,还是一直这样

  57. 爱看动漫的小梁

    怎么样的才能完美不影响

  58. 爱看动漫的小梁

    求推荐配置

    1. Rat's
      @爱看动漫的小梁

      这个我也说不清楚哪个好,应该是越贵越好。

  59. 爱看动漫的小梁

    重新启动系统,然后重新运行启动命令又是CPU100%,502 Bad Gateway

    1. Rat's
      @爱看动漫的小梁

      应该转码的时候吃配置,其它的你自己慢慢琢磨吧。

  60. 爱看动漫的小梁

    视频上传的大小是14.5兆

  61. 爱看动漫的小梁

    后台提示视频状态是:chunking

  62. 爱看动漫的小梁

    视频上传成功,但是访问视频连接就提示:502 Bad Gateway

  63. 爱看动漫的小梁

    Redis需要配置吗

    1. Rat's
      @爱看动漫的小梁

      不需要。

  64. 爱看动漫的小梁

    报错提示:502 Bad Gateway

    1. Rat's
      @爱看动漫的小梁

      我这两天有空重新安装一遍看看。

      1. 爱看动漫的小梁
        @Rat's

        嗯嗯,非常感谢,希望提详细点,例如:哪些文件是不能乱放的,指定要放哪个文件夹的!

        1. Rat's
          @爱看动漫的小梁

          刚用CentOS 7试了下,没啥问题,就是最新版的需要多装个Redis,直接在软件管理安装就可以了,你再重新试试吧。

          1. 爱看动漫的小梁
            @Rat's

            好吧

  65. 爱看动漫的小梁

    ubuntu-16.04表示这里:6、安装并运行云转码》》cd /root/express-ffmpeg!!
    这个提示了没有那个文件或目录

    1. Rat's
      @爱看动漫的小梁

      配置云转码那步做了吧?你看那个源码文件在哪个文件夹,就进入到哪个文件夹操作。

      1. 爱看动漫的小梁
        @Rat's

        了解

  66. 天城

    全程无错,web打不开!

    1. Rat's
      @天城

      能进去后台地址么?还去面板上检查下mongodb数据库是否是开启状态。

      1. 天城
        @Rat's

        不行啊!web打不开后台也一样链接失败!然后cpu百分百 我是独服!

        1. 爱看动漫的小梁
          @天城

          ubuntu-16.04.5系统搭建成功,可惜www.ayypd.com/admin提示502错误,我也是CPU百分百!

          1. Rat's
            @爱看动漫的小梁

            你什么配置,502看下nginx运行没。

            1. 爱看动漫的小梁
              @Rat's

              1G2H20GB,表示运行着的 服务器机器为虚拟机搭建

        2. Rat's
          @天城

          mongodb数据库是开启的么?或者你安装的时候有没有出现哪里报错?

          1. 天城
            @Rat's

            全程无错!数据库开启了

            1. Rat's
              @天城

              这个就不是很清楚了,毕竟看不到日志,不知道哪里有问题。

              1. 天城
                @Rat's

                现在搭建好了,请问下播放器右键信息在哪修改啊?全文搜索也没找到!

                1. Rat's
                  @天城

                  这个不是很清楚,一般我只是搭建好了,测试下基本功能就没管了。

  67. 爱看动漫的小梁

    博主,有没有群号?我想加群

    1. Rat's
      @爱看动漫的小梁

      不建群。

  68. 爱看动漫的小梁

    大神,第七步的反代添加网站怎么搞?你得说清楚添加哪个文件夹作为网站啊!

    1. Rat's
      @爱看动漫的小梁

      不需要添加文件夹,直接反代http://127.0.0.1:3000就可以了。

  69. kevin

    我用的是宝塔Centos来测试,测试不成功
    6、安装并运行云转码

    cd /root/express-ffmpeg
    npm install
    到这一步就报错了
    请博主支持,谢谢

  70. 惜情

    Centos宝塔测试失败 运行不起来

    1. Rat's
      @惜情

      你哪个步骤出现了问题?我就是用centos系统测试的。

      1. 爱看动漫的小梁
        @Rat's

        能否告诉我,你的centos是什么版本?测试成功的版本系统

        1. Rat's
          @爱看动漫的小梁

          我6/7都成功过,还有debian,不过是vultr的系统。

      2. 爱看动漫的小梁
        @Rat's

        6、安装并运行云转码的npm install表示出错,大概意思是命令不存在,已经继续用ubuntu -16.04.5系统再进行安装!

        1. Rat's
          @爱看动漫的小梁

          你得观察报错命令,然后再解决掉错误,然后再安装。

  71. lin

    博主很厉害,有群么,加个群好友么

    1. Rat's
      @lin

      萌咖群看到过你。

  72. KINO

    哇 真的好棒!

  73. 屈阿零

    很详细,很受用。

    1. 仙侠
      @屈阿零

      大佬

    2. 我是博主
      @屈阿零

      作者大佬,您能推荐一款低价杜甫吗?

    3. Rat's
      @屈阿零

      这不是作者么。

      1. 刘超
        @Rat's

        老大能录制个视频教程吗,给钱的,这样最好了

      2. 刘超
        @Rat's

        centos6.8x64安装完也是502,5555555

        1. Rat's
          @刘超

          502正常,装完后需要先去后台,把所有设置提交一次就好了。

          1. 刘超
            @Rat's

            主要后台地址也是502

            1. Rat's
              @刘超

              检查下nginx和数据库状态是否正常运行。

              1. 曾厝垵
                @Rat's

                我也是502报错 能方便留个QQ吗 高价请求帮助

                1. Rat's
                  @曾厝垵

                  扣扣用的少,加我微信吧,微信rats54。