说明:之前博主介绍过这个云转码和搭建教程,查看:云转码express-ffmpeg+CMS一体化系统安装教程,功能确实强大,不过还是有很多人搭建容易出点小问题,这里博主就整了个Docker
镜像,适合小白使用。
更新
【2018.11.4】
修复了上传错误等问题。
安装
注意:该安装方法不适用于OVZ
等类似结构。内存太小的话,建议加点Swap
,Swap
添加脚本→传送门。目前云转码为最新版本,如果作者有修复Bug
和添加功能,请提醒博主更新下镜像。
说明:镜像测试了一下,上传和转码均正常,记得安装后在后台对播放器、CMS
、转码等都设置下,不然会出现很多未知错误。转码时记得耐心等待,每段时间刷新一下查看状态。
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.service
2、编辑配置文件
#创建配置config文件夹
mkdir -p /express-ffmpeg/config
#增加配置文件并编辑,然后将下面一整条复制到SSH客户端运行
cat > /express-ffmpeg/config/auth.js <<EOF
module.exports = {
user: "admin",
password: "admin",
db: "ffmpeg",
dbuser: "ffmpeg",
dbpassword: "ffmpeg",
secret: "yoursecret",
login: "/adminlogin",
loginmsg: "404 Not Found"
};
EOF
user
和password
为后台登录账号和密码,下面的数据库别修改,接下来secret
是session
需要的秘钥,login
是后台登陆地址(请勿改成admin
),loginmsg
是后台未登录显示的内容,默认是404
。
3、启动镜像
docker run --restart=always --name express-ffmpeg -d \
-p 3000:3000 \
-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 \
zuta/express-ffmpeg
这时候基本上安装好了云转码,最后我们重启下镜像使配置生效:
docker restart express-ffmpeg
云转码访问地址是http://IP:3000
。对于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
如果要用域名访问,就需要反代了。如果突然访问不了了,大概是容器自动退出了,使用docker start express-ffmpeg
重新启动容器。
相关目录
#数据库的目录
/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/ToyoDAdoubiBackup/doubi/master/caddy_install.sh && chmod +x caddy_install.sh && bash caddy_install.sh
#备用地址
wget -N --no-check-certificate https://www.zuta.net/down/caddy_install.sh && chmod +x caddy_install.sh && bash caddy_install.sh
配置Caddy
:
#以下全部内容是一个整体,请修改域名后一起复制到SSH运行!
#http访问,该配置不会自动签发SSL
echo "xx.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-Proto {scheme}
}
}" > /usr/local/caddy/Caddyfile
#https访问,该配置会自动签发SSL,请提前解析域名到VPS服务器
echo "xx.com {
gzip
tls admin@zuta.net
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-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;
}
最后先去后台地址http://xx.com/adminlogin
,进行相关设置。