说明:之前博主介绍过这个云转码和搭建教程,查看:云转码express-ffmpeg+CMS一体化系统安装教程,功能确实强大,不过还是有很多人搭建容易出点小问题,这里博主就整了个Docker
镜像,适合小白使用。
更新
【2019.9.3】
重做镜像,新增部分变量参数,必要设置都给填了,使用更方便了。
【2018.11.4】
修复了上传错误等问题。
安装
注意:该安装方法不适用于OVZ
等类似结构。内存太小的话,建议加点Swap
,Swap
添加脚本→传送门。目前云转码为最新版本,如果作者有修复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
域名访问
反代可以用Nginx
、Apache
、Caddy
,这里只说宝塔和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
仅供学习交流,如果想正式使用,推荐该云转码的纯净版和高级版程序,均提供一键安装脚本,地址→传送门,看该文章后面介绍即可。
html结构在那个文件阿
同问,在哪里哇?
模板?views文件夹只有一个模板。默认的那个
/root/express-ffmpeg/下貌似只有6个文件夹,木有 views 文件夹呃
这个文件夹没映射出来,你自己去容器内部看看,怎么进就百度下。
明白,谢谢MJJ
请问防盗链 token在前端播放器的地方到底怎么用?
后台播放器设置加上key以后,即便绑定调用的地址也没法调用了,请问如何解决? 哪个key在调用的网站上怎么设置?
去其他网站调用就需要删掉key。
请问纯净版是否支持带key调用?
请问纯净版支持带key指定网站调用吗?
不支持,这个容易被破解,所以弃用了。
大佬,我看你这篇日志,从18点搞到凌晨4点,没玩过docker,需要挂载些什么文件夹还要配置些什么,整不清楚,一直在报错。
WARNING overcommit_memory is set to 0! Background save may fail under low memory condition. To fix this issue add 'vm.overcommit_memory = 1' to /etc/sysctl.conf and then reboot or run the command 'sysctl vm.overcommit_memory=1' for this to take effectWarning: no config file specified, using the default config. In order to specify a config file use redis-server /path/to/redis.conf这是警告而已,不是报错,不会的话,直接照着复制粘贴就行了,一般没啥问题。
我回了一封邮件,麻烦大佬帮我看一下怎么回事。
看到了,好像显示缺少www那个文件啥的,实际上我在vps中跑的时候,并没有遇到
那有没有什么办法解决,那个docker还引用了什么库吗?
没,只要安装好docker就可以了
这玩意不太好啊,经常cpu跑满了之后就一直chunking了,而且效果也就那样吧,官网的Ubuntu16.04下还gyp ERR!(换成centos就行了),这类的开源转码还有其他能玩的吗?
转码肯定cpu得跑满,一直chunking的话,应该是服务器太差了,一直在转码切片状态,这个转码主要看你的cpu性能的,cpu好转码就快,差就慢。
阿西吧 我调用m3u8的视频对比本地mp4视频,mp4比m3u8快好多好多,不知道咋回事我m3u8视频经常卡死。
本地调用mp4肯定快些,m3u8的话,在远程服务端效果就出来了,不然怎么很多人都喜欢m3u8。
视频上传完成转码切片完成 分享出来的m3u8视频一直转圈圈,我用那个在线播放m3u8的工具,显示The media playback was aborted due to a corruption problem or because the media used features your browser did not support.
前端能放么?一般切片是没问题的。
前端可以看到图片,点进去就是502
关掉播放器设置的强制qq浏览器
cms未开启 我看你们说要去后台开启 后台地址是多少我不知道
ip:3000/login后台地址不就是这个嘛? 我打开502
路径是/adminlogin
安装完成,打开后台,登陆之后跳转百度,进不去后台是什么情况啊?
跳转百度就说明你的用户名和密码错误
另外,切片转码文件夹movies可以改变吗? 默认空间只有50G,4T是外加的盘
或者怎么样可以像Windows一样弄一个快捷连接过去?
docker是可以改变路径的,自行调整