自建云下载和云播放

本教程主要用于学习目的,参考了大量网上的教程。
最近online终止了2欧独服的服务,换成了9欧,我没注意,莫名多了2台9欧,太贵了,不打算续费了,所以打算把9欧独服拿来折腾一个月。
先安装了系统,安装的centos7 64位。
9欧对电信网络越来越不友好了,现在延迟已经飙升到400多ms了,但是移动用户访问爽翻。
所以决定先装个加速服务,选用了目前比较流行的BBR。安装教程如下:
1、系统更新到centos7.3
yum update
2、查看系统版本,若输出
CentOS Linux release 7.3.1611 (Core)
表示已经升级成功
查看命令
cat /etc/redhat-release
3.安装elrepo并升级内核
rpm --import https://www.elrepo.org/RPM-GPG-KEY-elrepo.org
rpm -Uvh http://www.elrepo.org/elrepo-release-7.0-2.el7.elrepo.noarch.rpm
yum --enablerepo=elrepo-kernel install kernel-ml -y

一般输出如下信息表示成功

Transaction Summary

Install 1 Package

Total download size: 39 M
Installed size: 169 M
Downloading packages:
kernel-ml-4.9.0-1.el7.elrepo.x86_64.rpm | 39 MB 00:00
Running transaction check
Running transaction test
Transaction test succeeded
Running transaction
Warning: RPMDB altered outside of yum.
Installing : kernel-ml-4.9.0-1.el7.elrepo.x86_64 1/1
Verifying : kernel-ml-4.9.0-1.el7.elrepo.x86_64 1/1

Installed:
kernel-ml.x86_64 0:4.9.0-1.el7.elrepo

Complete!

4、更新grub文件并重启(reboot后,ssh会断开,稍等一会儿重新连接)
egrep ^menuentry /etc/grub2.cfg | cut -f 2 -d \'
grub2-set-default 0
reboot

5、开机后查看内核是否已更换为4.9
uname -r
输出如下:
4.9.0-1.el7.elrepo.x86_64

6、开启BBR
vi /etc/sysctl.conf
添加:
net.core.default_qdisc = fq
net.ipv4.tcp_congestion_control = bbr

7、加载系统参数(正常情况下会输出刚才我们加入的内容)
sysctl -p

8、验证BBR已成功开启
输入:
sysctl net.ipv4.tcp_available_congestion_control
返回:
net.ipv4.tcp_available_congestion_control = bbr cubic reno
输入:
lsmod | grep bbr
返回类似:
tcp_bbr 16384 1

至此BBR开启成功

二、在线云下载和云播放我们使用网上的一键脚本,将下列脚本复制,并保存位sh文件,加上执行权限
chmod +x a.sh
(a.sh为我们自己命名的脚本文件名,你也可以命名为其他名字)
脚本内容如下(记得修改域名为你自己的):

clear
echo '


***** *****
***** 本脚本只在Centos7 x64上通过测试 *****
***** *****
************************************************************

-Powered by HMP博客-小表弟

##设置域名
read -p ‘请输入离线下载地址(例如 dl.xxx.com): ‘ dl;
read -p ‘请输入网盘下载地址(例如 pan.xxx.com): ‘ pan;
[ -z “$dl” ] && echo “你是猪吗,让你填域名 已经给你设置为www.baidu.com,自己改” && dl=”此处修改为你自己云下载的域名”
[ -z “$pan” ] && echo “你是猪吗,让你填域名 已经给你设置为www.baidu.com,自己改” && pan=”此处修改为你自己云播的域名”
##设置完毕

#更新php7 nginx1.10 ffmpeg源

yum update -y
yum install wget unzip -y
yum install epel-release -y
yum update -y
rpm -Uvh http://rpms.famillecollet.com/enterprise/remi-release-7.rpm #php源
rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm #nginx源
rpm -Uvh http://li.nux.ro/download/nux/dextop/el7/x86_64/nux-dextop-release-0-5.el7.nux.noarch.rpm #ffmpeg源
yum update -y

#安装PHP NGINX

yum install nginx -y
yum install php70-php-fpm php70-php php70-php-gd -y
yum install ffmpeg -y

#启动PHP NGINX

systemctl start nginx
systemctl start php70-php-fpm
systemctl enable nginx
systemctl enable php70-php-fpm

mkdir -p /home/wwwroot/${dl}
mkdir -p /home/wwwroot/${pan}
cd /etc/nginx/
rm -rf fastcgi_params
echo '
fastcgi_param GATEWAY_INTERFACE CGI/1.1;
fastcgi_param REDIRECT_STATUS 200;
fastcgi_param SERVER_SOFTWARE nginx/$nginx_version;
fastcgi_param QUERY_STRING $query_string;
fastcgi_param REQUEST_METHOD $request_method;
fastcgi_param CONTENT_TYPE $content_type;
fastcgi_param CONTENT_LENGTH $content_length;
fastcgi_param SCRIPT_NAME $fastcgi_script_name;
fastcgi_param REQUEST_URI $request_uri;
fastcgi_param DOCUMENT_URI $document_uri;
fastcgi_param DOCUMENT_ROOT $document_root;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param SERVER_PROTOCOL $server_protocol;
fastcgi_param HTTPS $https if_not_empty;
fastcgi_param REMOTE_ADDR $remote_addr;
fastcgi_param REMOTE_PORT $remote_port;
fastcgi_param SERVER_ADDR $server_addr;
fastcgi_param SERVER_PORT $server_port;
fastcgi_param SERVER_NAME $server_name;
' >> fastcgi_params
cd conf.d

echo "
server {
listen 80;
server_name ${dl};
root /home/wwwroot/${dl};

location / {
index index.html index.php;
}
location ~* \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /home/wwwroot/${dl}$fastcgi_script_name;
fastcgi_split_path_info ^(.+\.php)(.*)$;
include fastcgi_params;
}
}
" >> ${dl}.conf

echo "
server {
listen 80;
server_name ${pan};
root /home/wwwroot/${pan};

location / {
index index.html index.php /_h5ai/public/index.php;
}
location ~* \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /home/wwwroot/${dl}$fastcgi_script_name;
fastcgi_split_path_info ^(.+\.php)(.*)$;
include fastcgi_params;
}
}
" >> ${pan}.conf

##开始配置程序

echo '开始安装程序'
cd
yum install aria2 screen -y
mkdir .aria2
echo "

## ‘#’开头为注释内容, 选项都有相应的注释说明, 根据需要修改 ##
## 被注释的选项填写的是默认值, 建议在需要修改时再取消注释 ##

## 文件保存相关 ##

# 文件的保存路径(可使用绝对路径或相对路径), 默认: 当前启动位置
dir=/home/wwwroot/${pan}
# 启用磁盘缓存, 0为禁用缓存, 需1.16以上版本, 默认:16M
#disk-cache=32M
# 文件预分配方式, 能有效降低磁盘碎片, 默认:prealloc
# 预分配所需时间: none < falloc ? trunc < prealloc
# falloc和trunc则需要文件系统和内核支持
# NTFS建议使用falloc, EXT3/4建议trunc, MAC 下需要注释此项
file-allocation=none
# 断点续传
continue=true

## 下载连接相关 ##

# 最大同时下载任务数, 运行时可修改, 默认:5
max-concurrent-downloads=10
# 同一服务器连接数, 添加时可指定, 默认:1
max-connection-per-server=5
# 最小文件分片大小, 添加时可指定, 取值范围1M -1024M, 默认:20M
# 假定size=10M, 文件为20MiB 则使用两个来源下载; 文件为15MiB 则使用一个来源下载
min-split-size=10M
# 单个任务最大线程数, 添加时可指定, 默认:5
split=20
# 整体下载速度限制, 运行时可修改, 默认:0
#max-overall-download-limit=0
# 单个任务下载速度限制, 默认:0
#max-download-limit=0
# 整体上传速度限制, 运行时可修改, 默认:0
#max-overall-upload-limit=0
# 单个任务上传速度限制, 默认:0
#max-upload-limit=0
# 禁用IPv6, 默认:false
disable-ipv6=true

## 进度保存相关 ##

# 从会话文件中读取下载任务
input-file=/root/aria2.session
# 在Aria2退出时保存`错误/未完成`的下载任务到会话文件
save-session=/root/aria2.session
# 定时保存会话, 0为退出时才保存, 需1.16.1以上版本, 默认:0
#save-session-interval=60

## RPC相关设置 ##

# 启用RPC, 默认:false
enable-rpc=true
# 允许所有来源, 默认:false
rpc-allow-origin-all=true
# 允许非外部访问, 默认:false
rpc-listen-all=true
# 事件轮询方式, 取值:[epoll, kqueue, port, poll, select], 不同系统默认值不同
#event-poll=select
# RPC监听端口, 端口被占用时可以修改, 默认:6800
#rpc-listen-port=6800
# 设置的RPC授权令牌, v1.18.4新增功能, 取代 --rpc-user 和 --rpc-passwd 选项
#rpc-secret=
# 设置的RPC访问用户名, 此选项新版已废弃, 建议改用 --rpc-secret 选项
#rpc-user=
# 设置的RPC访问密码, 此选项新版已废弃, 建议改用 --rpc-secret 选项
#rpc-passwd=

## BT/PT下载相关 ##

# 当下载的是一个种子(以.torrent结尾)时, 自动开始BT任务, 默认:true
#follow-torrent=true
# BT监听端口, 当端口被屏蔽时使用, 默认:6881-6999
listen-port=51413
# 单个种子最大连接数, 默认:55
#bt-max-peers=55
# 打开DHT功能, PT需要禁用, 默认:true
enable-dht=true
# 打开IPv6 DHT功能, PT需要禁用
#enable-dht6=false
# DHT网络监听端口, 默认:6881-6999
#dht-listen-port=6881-6999
# 本地节点查找, PT需要禁用, 默认:false
#bt-enable-lpd=true
# 种子交换, PT需要禁用, 默认:true
enable-peer-exchange=true
# 每个种子限速, 对少种的PT很有用, 默认:50K
#bt-request-peer-speed-limit=50K
# 客户端伪装, PT需要
peer-id-prefix=-TR2770-
user-agent=Transmission/2.77
# 当种子的分享率达到这个数时, 自动停止做种, 0为一直做种, 默认:1.0
seed-ratio=0.1
# 强制保存会话, 即使任务已经完成, 默认:false
# 较新的版本开启后会在任务完成后依然保留.aria2文件
#force-save=false
# BT校验相关, 默认:true
#bt-hash-check-seed=true
# 继续之前的BT任务时, 无需再次校验, 默认:false
bt-seed-unverified=true
# 保存磁力链接元数据为种子文件(.torrent文件), 默认:false
bt-save-metadata=false

" >> /root/.aria2/aria2.conf

screen -dmS aria2 aria2c --enable-rpc --rpc-listen-all=true --rpc-allow-origin-all -c
echo '' > /root/aria2.session

cd /home/wwwroot/${dl}
wget --no-check-certificate https://raw.githubusercontent.com/godzlalala/onlineplayer/master/yaaw.zip
unzip yaaw.zip
cd /home/wwwroot/${pan}
wget --no-check-certificate https://raw.githubusercontent.com/godzlalala/onlineplayer/master/_h5ai.zip
unzip _h5ai.zip
chmod 777 /home/wwwroot/${pan}/_h5ai/public/cache
chmod 777 /home/wwwroot/${pan}/_h5ai/private/cache

#启动程序

echo '配置完毕,启动程序'
systemctl restart nginx

echo "
************************************************************
* *
* 程序安装完毕 *
* 离线下载域名${dl} *
* 在线观看域名${pan} *
* 感谢使用 *
************************************************************

-Powered by HMP博客-小表弟
"

至此云下载和云播搭建完毕

但是有一些收尾工作,特别是对于新安装的系统,防火墙默认是阻止了http服务和json-rpc的,我们需要添加防火墙规则
将http加入到白名单:

firewall-cmd --permanent --add-service=http
firewall-cmd --permanent --zone=trusted --add-port=80/tcp

添加一个自定义的白名单规则,将aria2c启用json-rpc需要用到的6800端口开放出来
方法如下:
1、创建新文件aria2c.xml

touch /etc/firewalld/services/aria2c.xml

编辑aria2c.xml,

vim /etc/firewalld/services/aria2c.xml

添加如下内容:



aria2c
此处为文字说明

2、编辑public.xml 文件,加入相应的Server

vim /etc/firewalld/zones/public.xml

编辑文件并保存:



Public
For use in public areas. You do not trust the other computers on networks to not harm your computer. Only selected incoming connections are accepted.


# 这行是后加的,要匹配 /etc/firewalld/services/aria2c.xml 文件名

3、然后重新加载防火墙规则:

firewall-cmd --reload

至此,大功告成。
去你的域名注册商那里把刚才自己定义的两个域名解析到你的服务器ip,使用域名访问吧。(dns解析不赘述,不会的自己百度,很简单)

One thought on “自建云下载和云播放

Comments are closed.