|
|
1.Aria2的安装与RPC的部署
Aria2的安装
Aria2的GitHub地址 https://github.com/aria2/aria2
apt update && apt dist-upgrade
apt-get install aria2
aria2c -v
#检查aria2c是否正确安装
RPC的部署
配置文件 aria.conf,aria2.session
配置目录 aria2c默认下载目录/home/docker/nginx/Share和上述两个文件存放目录/home/docker/nginx/html/aria2/
可以使用其他目录,如aria2.conf可以放到新建的/home/docker/nginx/html/aria2/下方便管理
- mkdir -p /home/docker/nginx/Share /home/docker/nginx/html/aria2/
- touch /home/docker/nginx/html/aria2/aria2.{conf,session}
- vi /home/docker/nginx/html/aria2/aria2.conf
复制代码
在aria2.conf中写入以下内容(aria2.conf原始文档在Aria2的GitHub页面可找到)
注意 在60-80行附近的rpc-secret=<TOKEN>中的<TOKEN>应当改为要设置的RPC密码 , 这里设置“amochili"
- #允许rpc
- enable-rpc=true
- #允许所有来源, web界面跨域权限需要
- rpc-allow-origin-all=true
- #允许非外部访问
- rpc-listen-all=true
- ## '#'开头为注释内容, 选项都有相应的注释说明, 根据需要修改 ##
- ## 被注释的选项填写的是默认值, 建议在需要修改时再取消注释 ##
- ## 文件保存相关 ##
- # 文件的保存路径(可使用绝对路径或相对路径), 默认: 当前启动位置
- dir=/home/Share
- # 启用磁盘缓存, 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=3
- # 同一服务器连接数, 添加时可指定, 默认:1
- max-connection-per-server=5
- # 最小文件分片大小, 添加时可指定, 取值范围1M -1024M, 默认:20M
- # 假定size=10M, 文件为20MiB 则使用两个来源下载; 文件为15MiB 则使用一个来源下载
- min-split-size=10M
- # 单个任务最大线程数, 添加时可指定, 默认:5
- #split=5
- # 整体下载速度限制, 运行时可修改, 默认: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
- # 连接超时时间, 默认:60
- #timeout=60
- # 最大重试次数, 设置为0表示不限制重试次数, 默认:5
- #max-tries=5
- # 设置重试等待的秒数, 默认:0
- #retry-wait=0
- ## 进度保存相关 ##
- # 从会话文件中读取下载任务
- input-file=/home/docker/nginx/html/aria2/aria2.session
- # 在Aria2退出时保存`错误/未完成`的下载任务到会话文件
- save-session=/home/docker/nginx/html/aria2/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=amochili
- # 设置的RPC访问用户名, 此选项新版已废弃, 建议改用 --rpc-secret 选项
- #rpc-user=<USER>
- # 设置的RPC访问密码, 此选项新版已废弃, 建议改用 --rpc-secret 选项
- #rpc-passwd=<PASSWD>
- # 是否启用 RPC 服务的 SSL/TLS 加密,
- # 启用加密后 RPC 服务需要使用 https 或者 wss 协议连接
- #rpc-secure=true
- # 在 RPC 服务中启用 SSL/TLS 加密时的证书文件,
- # 使用 PEM 格式时,您必须通过 --rpc-private-key 指定私钥
- #rpc-certificate=/path/to/certificate.pem
- # 在 RPC 服务中启用 SSL/TLS 加密时的私钥文件
- #rpc-private-key=/path/to/certificate.key
- ## BT/PT下载相关 ##
- # 当下载的是一个种子(以.torrent结尾)时, 自动开始BT任务, 默认:true
- #follow-torrent=true
- # BT监听端口, 当端口被屏蔽时使用, 默认:6881-6999
- listen-port=51413
- # 单个种子最大连接数, 默认:55
- #bt-max-peers=55
- # 打开DHT功能, PT需要禁用, 默认:true
- enable-dht=false
- # 打开IPv6 DHT功能, PT需要禁用
- #enable-dht6=false
- # DHT网络监听端口, 默认:6881-6999
- #dht-listen-port=6881-6999
- # 本地节点查找, PT需要禁用, 默认:false
- #bt-enable-lpd=false
- # 种子交换, PT需要禁用, 默认:true
- enable-peer-exchange=false
- # 每个种子限速, 对少种的PT很有用, 默认:50K
- #bt-request-peer-speed-limit=50K
- # 客户端伪装, PT需要
- peer-id-prefix=-TR2770-
- user-agent=Transmission/2.77
- peer-agent=Transmission/2.77
- # 当种子的分享率达到这个数时, 自动停止做种, 0为一直做种, 默认:1.0
- seed-ratio=0
- # 强制保存会话, 即使任务已经完成, 默认:false
- # 较新的版本开启后会在任务完成后依然保留.aria2文件
- #force-save=false
- # BT校验相关, 默认:true
- #bt-hash-check-seed=true
- # 继续之前的BT任务时, 无需再次校验, 默认:false
- bt-seed-unverified=true
- # 保存磁力链接元数据为种子文件(.torrent文件), 默认:false
- bt-save-metadata=true
复制代码
设置Aria2c开机自启动
在系统自启动目录下注册aria2c服务
vi /lib/systemd/system/aria2c.service
在文件中写入以下内容
- [Unit]
- Description=Aria2c
- [Service]
- TimeoutStartSec=0
- ExecStart=/usr/bin/aria2c --conf-path=/home/docker/nginx/html/aria2/aria2.conf
- ExecReload=/bin/kill -HUP $MAINPID
- KillMode=process
- Restart=on-failure
- RestartSec=42s
- [Install]
- WantedBy=multi-user.target
复制代码
保存退出,然后启动aria2c服务并查看运行状态
- systemctl enable aria2c
- systemctl restart aria2c
- systemctl status aria2c
复制代码
如果输出的结果中含有“Active: active (running)”字样,则aria2c自启动服务注册成功
尝试重启服务器确认服务自启动正常工作
reboot
2.AriaNg的安装与配置
AriaNg的GitHub地址 https://github.com/mayswind/AriaNg
具体要下载的版本参考GitHub release页面,此处使用了1.1.7版本
wget https://github.com/mayswind/Aria ... .7/AriaNg-1.1.7.zip #下载
mkdir /var/www/html/ariang #创建ariang文件夹
unzip -d /var/www/html/ariang AriaNg-1.1.7.zip #具体zip包名参考wget时的包名
chmod 755 /var/www/html/ariang #给其他用户读取和执行权限
在浏览器访问 http://<IP地址>/ariang,确认配置成功
在AriaNg设置->RPC设置中填写在rpc-secret中设置的密码(注意放行RPC的监听端口)。输完密码后刷新页面,如果左侧栏底部的Aria2状态显示为“已连接”则表明配置成功
3.(可选)添加域名和启用 SSL/TLS 加密
此处使用 Nginx ,Apache 等 Web 服务器类推
添加证书文件
mkdir /etc/nginx/certs
touch /etc/nginx/certs/example.com.{pem,key}
# 注意根据具体域名进行变更
在 pem 文件写入公钥,key 文件写入私钥
配置 Nginx
Nginx 可以修改 nginx.conf 或 /etc/nginx/sites-enabled 下的文件
Todo:添加具体配置项
完成后重启 Nginx 以载入配置
systemctl restart nginx
此步骤后可以在浏览器访问 https://<your domain>/ariang
配置 Aria2
在 aria2.conf 中修改相关项
# 使用 PEM 格式时,您必须通过 --rpc-private-key 指定私钥
rpc-certificate=/path/to/certificate.pem
# 在 RPC 服务中启用 SSL/TLS 加密时的私钥文件
rpc-private-key=/path/to/certificate.key
配置 AriaNg
在RPC设置界面修改 IP 为域名
|
|