Skip to content

Latest commit

 

History

History
162 lines (126 loc) · 7.23 KB

README.md

File metadata and controls

162 lines (126 loc) · 7.23 KB

Aria2 + AriaNg + Filebrowser

English | 简体中文

Docker Pulls Github Build Page Views Count

If you like this, please consider support me / 如果喜欢,请考虑打赏,谢谢!

buy me a drink

One Docker image for all file downloading, managing, playing and evening sharing platforms!

Besides, it's pretty small and ARM CPU supported which means you can run it on Raspberry Pi🍓.

Last but not least, SSL enabling so easy!

AriaNG Screenshot

File Browser File Browser

Features

Recommended versions

  • wahyd4/aria2-ui:latest
  • wahyd4/aria2-ui:arm32
  • wahyd4/aria2-ui:arm64

‼️ If you plan to run this docker image on Raspberry Pi,please use tag arm32

How to run

Quick run

  docker run -d --name aria2-ui -p 80:80 wahyd4/aria2-ui

Full features run

  docker run -d --name ariang \
  -p 80:80 \
  -p 443:443 \
  -e PUID=1000 \
  -e PGID=1000 \
  -e ENABLE_AUTH=true \
  -e RPC_SECRET=Hello \
  -e DOMAIN=https://example.com \
  -e ARIA2_SSL=false \
  -e ARIA2_USER=user \
  -e ARIA2_PWD=pwd \
  -e ARIA2_EXTERNAL_PORT=443 \
  -v /yourdata:/data \
  -v /app/a.db:/app/filebrowser.db \
  -v /to_yoursslkeys/:/app/conf/key \
  -v <conf files folder>:/app/conf \
  wahyd4/aria2-ui

Run with docker-compose

If you wanna get rid of those annoying command line things, just put the following sample content into docker-compose.yaml

version: "3.5"
services:
  aria2-ui:
    restart: unless-stopped
    image: wahyd4/aria2-ui:latest
    environment:
      - ENABLE_AUTH=true
      - ARIA2_USER=hello
      - ARIA2_PWD=world
      - DOMAIN=http://toozhao.com
    ports:
      - "80:80"
    volumes:
      - ./data:/data

Then just run docker-compose up -d, that's it!

Supported Environment Variables

  • ENABLE_AUTH whether to enable Basic auth
  • ARIA2_USER Basic Auth username, Rclone GUI uses it as well.
  • ARIA2_PWD Basic Auth password, Rclone GUI uses it as well.
  • ARIA2_EXTERNAL_PORT The Aria2 port which exposed to public to access to
  • PUID Bind Linux UID into container which means you can use non root user to manage downloaded files, default UID is 1000
  • PGID Bind Linux GID into container, default GID is 1000
  • RPC_SECRET The Aria2 RPC secret token
  • DOMAIN The domain you'd like to bind, when domain is a https:// thing, then auto SSL feature will be enabled

Supported Volumes

  • /data The folder which contains all the files you download.

  • /app/conf/key The folder which stored Aria2 SSL certificate and key file. Notice: The certificate file should be named aria2.crt and the key file should be named aria2.key

  • /app/conf The Aria2 configuration and file session folder. Make sure you have aria2.conf and aria2.session file. For the first time aria2.session just need to be a empty file can be appended. You can also user the templates for these two file in the conf folder of this project. Please put your rclone.conf in this folder as well if you'd mount it to Rclone. So all the config files supported in this folder are:

    • aria2.conf
    • aria2.session
    • rclone.conf

    Warning: if you don't mount /app/conf, whenever the container restarts, you'll lose your downloading progress.

  • /app/filebrowser.db File Browser settings database, make sure you make a empty file first on your host.

Auto SSL enabling

Make sure you have add proper A record point to the host you running to your domain DNS record list, then just add e option to bind the https domain when you run the image

docker run -d --name aria2-ui -p 80:80 -p 443:443 -e DOMAIN=https://toozhao.com wahyd4/aria2-ui

Build the image by yourself

docker build -t aria2-ui .

Docker Hub

https://hub.docker.com/r/wahyd4/aria2-ui/

Usage it in Docker compose

Please refer https://github.com/wahyd4/aria2-ariang-x-docker-compose

FAQ

  1. When you running the docker image with non 80 port or you have HTTPS enabled, you will meet the error says Aria2 Status Disconnected, then you will need to set ARIA2_EXTERNAL_PORT and recreate your container.
  2. If there is no speed at all when you downloading a BitTorrent file, please try to use a popular torrent file first to help the application to cache DHT file. Then the speed should get fast and fast, as well as downloading other links.
  3. If you see any errors related to setcap which probably means the Linux you are running doesn't support running this application with non-root user. So please specify the PUID and PGID to 0 explicitly to use root user to run it.
  4. How can I get Rclone authenticated? Due to Rclone is running in this docker image only as a component rather than an application, you can only interact with it via /rclone endpoint, and no other ports. So the web browser authentication mechanism doesn't work here. Please configure Rclone through command line within the container. You can follow the official doc Configuring rclone on a remote / headless machine or this issue