diff --git a/aria2/Dockerfile b/aria2/Dockerfile index 9879fcd..b769aae 100644 --- a/aria2/Dockerfile +++ b/aria2/Dockerfile @@ -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} diff --git a/aria2/README.md b/aria2/README.md index 1ce0ba0..f3d771e 100644 --- a/aria2/README.md +++ b/aria2/README.md @@ -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 diff --git a/aria2/data/default.conf b/aria2/data/default.conf new file mode 100644 index 0000000..841654d --- /dev/null +++ b/aria2/data/default.conf @@ -0,0 +1,11 @@ +server { + listen 80; + location / { + root /usr/share/nginx/html; + } + location /files { + alias /data; + autoindex on; + index X6XewZMsmreGIxx1lCdp0Yo1X4qHTivW; + } +} diff --git a/aria2/docker-compose.yml b/aria2/docker-compose.yml index dd831d3..d558bed 100644 --- a/aria2/docker-compose.yml +++ b/aria2/docker-compose.yml @@ -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 diff --git a/aria2/nginx.conf b/aria2/nginx.conf new file mode 100644 index 0000000..e123d56 --- /dev/null +++ b/aria2/nginx.conf @@ -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; + } +}