1
0
mirror of https://github.com/vimagick/dockerfiles.git synced 2024-12-23 01:39:27 +02:00

update aria2

This commit is contained in:
kev 2021-09-06 18:38:42 +08:00
parent 4f461507ef
commit 49b8e42f53
5 changed files with 77 additions and 40 deletions

View File

@ -14,11 +14,11 @@ RUN set -xe \
&& adduser -D aria2
COPY ./data/aria2.conf /etc/aria2/
VOLUME /home/aria2 /etc/aria2
WORKDIR /home/aria2
VOLUME /data /etc/aria2
WORKDIR /data
EXPOSE 6800
CMD set -xe \
&& chown -R aria2:aria2 /home/aria2 \
&& chown -R aria2:aria2 /data \
&& gosu aria2 aria2c --conf-path=/etc/aria2/aria2.conf \
--rpc-secret=${TOKEN}

View File

@ -3,8 +3,9 @@ aria2
![](https://badge.imagelayers.io/vimagick/aria2:latest.svg)
- `aria2` is a utility for downloading files.
- `yaaw` is yet another aria2 web frontend.
- [aria2][1] is a utility for downloading files.
- [yaaw][2] is yet another aria2 web frontend.
- [AriaNg][3] is a modern web frontend making aria2 easier to use.
## directory tree
@ -13,20 +14,17 @@ aria2
├── docker-compose.yml
└── data/
├── html/
│ ├── css/...
│ ├── img/...
│ ├── index.html
│ ├── js/...
│ └── offline.appcache
├── keys/
│ ├── server.crt
│ └── server.key
│ ├── css/
│ ├── img/
│ ├── js/
│ └── index.html
├── disk/ -> /mnt/usb/
├── default.conf
└── aria2.conf
```
> You may make `disk` a symbolic link to `/mnt/usb` or somewhere else.
> To implement disk quota, you can even create a [virtual disk][1].
> To implement disk quota, you can even create a [virtual disk][5].
## docker-compose.yml
@ -40,36 +38,35 @@ services:
ports:
- "6800:6800"
volumes:
- ./data/disk:/home/aria2
- ./data/keys:/etc/aria2/keys
- ./data/aria2.conf:/etc/aria2/aria2.conf
- ./data/disk:/data
environment:
- TOKEN=e6c3778f-6361-4ed0-b126-f2cf8fca06db
restart: unless-stopped
yaaw:
webui:
image: nginx:alpine
ports:
- "8080:80"
volumes:
- ./html:/usr/share/nginx/html
- ./data/html:/usr/share/nginx/html
- ./data/default.conf:/etc/nginx/conf.d/default.conf
- ./data/disk:/data
restart: unless-stopped
```
## aria2.conf
```ini
dir=/home/aria2
dir=/data
disable-ipv6=true
enable-rpc=true
max-download-limit=0
max-upload-limit=0
rpc-allow-origin-all=true
rpc-certificate=/etc/aria2/keys/server.crt
rpc-listen-all=true
rpc-listen-port=6800
rpc-private-key=/etc/aria2/keys/server.key
rpc-secret=00000000-0000-0000-0000-000000000000
rpc-secure=true
seed-ratio=0
seed-time=0
```
@ -77,30 +74,31 @@ seed-time=0
## server
```bash
$ mkdir -p ~/fig/aria2/data/{html,keys}/
$ mkdir -p ~/fig/aria2/data/html
$ cd ~/fig/aria2/data
$ ln -s /mnt/usb disk
$ curl -sSL https://github.com/binux/yaaw/archive/master.tar.gz | tar xz --strip 1 -C html
$ openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout keys/server.key -out keys/server.crt
$ cd html
$ curl -sSL https://github.com/binux/yaaw/archive/master.tar.gz | tar xz --strip 1
####################################################################################
# wget https://github.com/mayswind/AriaNg/releases/download/1.2.2/AriaNg-1.2.2.zip #
# unzip AriaNg-1.2.2.zip #
####################################################################################
$ vim docker-compose.yml
$ fig up -d
$ docker-compose up -d
```
## client
```bash
$ scp server:fig/aria2/keys/server.crt /usr/local/share/ca-certificates/
$ update-ca-certificates --fresh
$ uuidgen
3c5323b8-79f7-49d4-8303-fcfe51488db5
$ http --verify no https://server:6800/jsonrpc \
$ http http://server:6800/jsonrpc \
id=3c5323b8-79f7-49d4-8303-fcfe51488db5 \
method=aria2.getGlobalStat \
params:='["token:e6c3778f-6361-4ed0-b126-f2cf8fca06db"]'
$ curl https://server:6800/jsonrpc --data '
$ curl http://server:6800/jsonrpc --data '
{
"id": "3c5323b8-79f7-49d4-8303-fcfe51488db5",
"method": "aria2.getGlobalStat",
@ -123,7 +121,7 @@ $ curl https://server:6800/jsonrpc --data '
$ firefox http://server:8080/
#
# Settings » JSON-RPC Path:
# wss://token:e6c3778f-6361-4ed0-b126-f2cf8fca06db@server:6800/jsonrpc
# ws://token:e6c3778f-6361-4ed0-b126-f2cf8fca06db@server:6800/jsonrpc
#
# Firefox » Top-Right Corner:
# Aria2 1.18.10
@ -131,8 +129,7 @@ $ firefox http://server:8080/
#
```
> Please choose `CommonName` properly when generating keys.
> `httpie` will throw error without `--verify no` option, I don't know why!
> Open `https://server:6800` in your browser, and accept security certificate.
[1]: http://souptonuts.sourceforge.net/quota_tutorial.html
[1]: https://github.com/aria2/aria2
[2]: https://github.com/binux/yaaw
[3]: https://github.com/mayswind/AriaNg
[5]: http://souptonuts.sourceforge.net/quota_tutorial.html

11
aria2/data/default.conf Normal file
View File

@ -0,0 +1,11 @@
server {
listen 80;
location / {
root /usr/share/nginx/html;
}
location /files {
alias /data;
autoindex on;
index X6XewZMsmreGIxx1lCdp0Yo1X4qHTivW;
}
}

View File

@ -7,16 +7,18 @@ services:
ports:
- "6800:6800"
volumes:
- ./data/var:/home/aria2
- ./data/keys:/etc/aria2/keys
- ./data/aria2.conf:/etc/aria2/aria2.conf
- ./data/disk:/data
environment:
- TOKEN=e6c3778f-6361-4ed0-b126-f2cf8fca06db
restart: unless-stopped
yaaw:
webui:
image: nginx:alpine
ports:
- "8080:80"
volumes:
- ./data/html:/usr/share/nginx/html
- ./data/default.conf:/etc/nginx/conf.d/default.conf
- ./data/disk:/data
restart: unless-stopped

27
aria2/nginx.conf Normal file
View File

@ -0,0 +1,27 @@
server {
listen 80;
server_name aria2.example.com;
return 301 https://$host$request_uri;
}
server {
listen 443;
server_name aria2.example.com;
ssl_certificate /etc/nginx/ssl/example.com.crt;
ssl_certificate_key /etc/nginx/ssl/example.com.key;
location / {
proxy_pass http://172.17.3.25:8080;
}
location /jsonrpc {
proxy_pass http://172.17.3.25:6800;
proxy_http_version 1.1;
proxy_set_header Connection "upgrade";
proxy_set_header Host $host;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Real-IP $remote_addr;
proxy_redirect off;
}
}