Rat's

使用Docker快速安装express-ffmpeg云转码切片
说明:之前博主介绍过这个云转码和搭建教程,查看:云转码express-ffmpeg+CMS一体化系统安装教程,功能...
扫描右侧二维码阅读全文
02
2018/11

使用Docker快速安装express-ffmpeg云转码切片

说明:之前博主介绍过这个云转码和搭建教程,查看:云转码express-ffmpeg+CMS一体化系统安装教程,功能确实强大,不过还是有很多人搭建容易出点小问题,这里博主就整了个Docker镜像,适合小白使用。

更新

【2019.9.3】
重做镜像,新增部分变量参数,必要设置都给填了,使用更方便了。
【2018.11.4】
修复了上传错误等问题。

安装

注意:该安装方法不适用于OVZ等类似结构。内存太小的话,建议加点SwapSwap添加脚本→传送门。目前云转码为最新版本,如果作者有修复Bug和添加功能,请提醒博主更新下镜像。

说明:镜像测试了一下,上传和转码均正常,记得安装后,如果使用自带CMS播放,请在播放设置那里关掉强制QQ浏览器。

1、安装Docker

#CentOS 6
rpm -iUvh http://dl.fedoraproject.org/pub/epel/6/x86_64/epel-release-6-8.noarch.rpm
yum update -y
yum -y install docker-io
service docker start
chkconfig docker on

#CentOS 7、Debian、Ubuntu
curl -sSL https://get.docker.com/ | sh
systemctl start docker
systemctl enable docker

2、运行镜像

#先看下面的参数详解,进行相关修改后,再将下面一起复制到ssh客户端运行
docker run --restart=always --name express-ffmpeg -d \
-p 3000:3000 \
-e localip=192.168.2.1 \
-e usr=moerats \
-e pass=moerats \
-e url=moerats \
-v ~/express-ffmpeg/mongodb:/data \
-v ~/express-ffmpeg/config:/express-ffmpeg/config \
-v ~/express-ffmpeg/movies:/express-ffmpeg/movies \
-v ~/express-ffmpeg/videos:/express-ffmpeg/public/videos \
-v ~/express-ffmpeg/uploads:/express-ffmpeg/public/uploads \
-v ~/express-ffmpeg/images:/express-ffmpeg/public/images \
moerats/express-ffmpeg

相关变量参数详解,自行修改:

serverip:服务器的ip地址
#用户名、密码,后台路径均自己修改,且路径不能为admin
usr:后台管理员用户名
pass:后台管理员密码
url:后台登录路径

最后访问地址是http://ip:3000,后台路径为http://ip:3000/moerats,路径参考自己修改的。

对于CentOS系统,还需要开启3000端口,开启如下:

#CentOS 6
iptables -I INPUT -p tcp --dport 3000 -j ACCEPT
service iptables save
service iptables restart

#CentOS 7
firewall-cmd --zone=public --add-port=3000/tcp --permanent
firewall-cmd --reload

如果要用域名访问,就需要反代了。

相关目录

#数据库的目录
~/express-ffmpeg/mongodb
#配置文件目录
~/express-ffmpeg/config
#上传视频文件夹
~/express-ffmpeg/movies
#放切片文件、上传封面和VTT字幕文件夹
~/express-ffmpeg/videos
#上传文章图片的文件夹
~/express-ffmpeg/uploads
#上传图集的文件夹
~/express-ffmpeg/images

域名访问

反代可以用NginxApacheCaddy,这里只说宝塔和Caddy。如果你网站有宝塔,就可以使用宝塔进行反代,如果没有,建议使用第2种的Caddy反代,配置很快。

1、宝塔反代
先进入宝塔面板,然后点击左侧网站,添加站点,然后再点击添加好了的域名名称,这时候就进入了站点配置,点击反向代理,目标URL填入http://127.0.0.1:3000,再启用反向代理即可。至于启用SSL就不说了,直接在站点配置就可以启用。

2、Caddy反代
安装Caddy

wget -N --no-check-certificate https://raw.githubusercontent.com/iiiiiii1/doubi/master/caddy_install.sh && chmod +x caddy_install.sh && bash caddy_install.sh
#备用地址
wget -N --no-check-certificate https://www.moerats.com/usr/shell/Caddy/caddy_install.sh && chmod +x caddy_install.sh && bash caddy_install.sh

配置Caddy

#以下全部内容是一个整体,请修改域名后一起复制到SSH运行!

#http访问,该配置不会自动签发SSL
echo "www.moerats.com {
 gzip
 proxy / 127.0.0.1:3000 {
    header_upstream Host {host}
    header_upstream X-Real-IP {remote}
    header_upstream X-Forwarded-For {remote}
    header_upstream X-Forwarded-Port {server_port}
    header_upstream X-Forwarded-Proto {scheme}
  }
}" > /usr/local/caddy/Caddyfile

#https访问,该配置会自动签发SSL,请提前解析域名到VPS服务器
echo "www.moerats.com {
 gzip
 tls admin@moerats.com
 proxy / 127.0.0.1:3000 {
    header_upstream Host {host}
    header_upstream X-Real-IP {remote}
    header_upstream X-Forwarded-For {remote}
    header_upstream X-Forwarded-Port {server_port}
    header_upstream X-Forwarded-Proto {scheme}
  }
}" > /usr/local/caddy/Caddyfile

tls参数会自动帮你签发ssl证书,如果你要使用自己的ssl,改为tls /root/xx.crt /root/xx.key即可。后面为ssl证书路径。

启动Caddy

/etc/init.d/caddy start

就可以打开域名进行访问了。

3、Nginx配置
如果你使用其它的,这里就大概发个Nginx反代配置,直接添加到配置文件即可。

#在配置文件里添加
location / {
     proxy_pass http://127.0.0.1:3000;
     proxy_redirect off;
     proxy_set_header X-Real-IP $remote_addr;
     proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }

最后该Docker仅供学习交流,如果想正式使用,推荐该云转码的纯净版和高级版程序,均提供一键安装脚本,地址→传送门,看该文章后面介绍即可。

Vultr新用户注册送100美元/16个机房按小时计费,支持支付宝,【点击查看】。
最后修改:2019 年 10 月 19 日 02 : 06 PM

发表评论

188 条评论

  1. qcyg

    大神,请问怎么把上传视频的切片文件安装的其他地方

    1. Rat's
      @qcyg

      切片转移到其它地方吗?转移其它服务器用rsync,然后绑定其它域名,设置好分发就行,这时候访问m3u8,切片会从分发域名读取

  2. merlin

    电影库页面报错
    my.js:435 Uncaught TypeError: Cannot set property 'id' of null

    at my.js:435

    点击分享链接也报错
    jquery.min.js:2 GET https://api.weibo.com/2/short_url/shorten.json?source=2849184197&url_long=http://116.62.79.17:3000/share/60c87a4e5d9fbc07c75505c1&callback=jQuery33107803496245922608_1623754082277&_=1623754082278 net::ERR_ABORTED 403 (Forbidden)

    这是啥情况?

    1. Rat's
      @merlin

      好像是这个api用不了了。

  3. aFeng

    大神,群晖安装DOCKER通过注册表下载映像,一切正常。运行容器以后,能登陆能注册,但是访问后台提示404错误(adminlogin或者moerats目录),显示一堆代码。。。跟@h提示的错误一样

    请问如何确认正确的后台管理目录?

    1. Rat's
      @aFeng

      错误应该是后台路径不对,你检查下,最好是学会手动安装,这是安装教程https://ffmpeg.moejj.com/guide/install.html

      1. aFeng
        @Rat's

        谢谢博主提醒,检查了一下start.sh,里面写死了,auth.js改了没用,必须修改start.sh才行。

        要不然每次重启容器,都会变成默认目录跟默认用户名密码。

        1. Rat's
          @aFeng

          之前为了简单,就随便写的docker。

  4. 林哲

    我发现用宝塔的反向代理会重复消耗下行和上行的资源 这个有解决办法吗

  5. 四十一枝花

    大佬 安装好后 登录后直接跳转到百度去了

    1. Rat's
      @四十一枝花

      百度是用户名和密码不对,就会跳百度

  6. mjj

    博主,安装好以后,用m3u8分享到其他站播放,出现这个Access to XMLHttpRequest at 'http://1xx.204.34.xxx:3000/videos/5e4763524da3a10045a4b7f7/index.m3u8' from origin 'http://*.com' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

    播放不了,搜索了一下说是跨域问题,请博主帮忙一下如何解决,谢谢

    1. Rat's
      @mjj

      这个不好说,百度下,nginx反向代理防跨域

  7. nong

    挂载目录,本地目录没有的话会自动创建?

    1. Rat's
      @nong

      对的,映射的文件夹会自动创建

  8. Song_K

    html结构在那个文件阿

    1. Fast
      @Song_K

      同问,在哪里哇?

      1. Rat's
        @Fast

        模板?views文件夹只有一个模板。默认的那个

        1. Fast
          @Rat's

          /root/express-ffmpeg/下貌似只有6个文件夹,木有 views 文件夹呃

          1. Rat's
            @Fast

            这个文件夹没映射出来,你自己去容器内部看看,怎么进就百度下。

            1. Fast
              @Rat's

              明白,谢谢MJJ

  9. 达芬奇

    请问防盗链 token在前端播放器的地方到底怎么用?

  10. 达芬奇

    后台播放器设置加上key以后,即便绑定调用的地址也没法调用了,请问如何解决? 哪个key在调用的网站上怎么设置?

    1. Rat's
      @达芬奇

      去其他网站调用就需要删掉key。

      1. 达芬奇
        @Rat's

        请问纯净版是否支持带key调用?

      2. 达芬奇
        @Rat's

        请问纯净版支持带key指定网站调用吗?

        1. Rat's
          @达芬奇

          不支持,这个容易被破解,所以弃用了。