Skip to content
This repository has been archived by the owner on Mar 23, 2021. It is now read-only.
/ alpine-seedbox Public archive

Minimal Alpine Linux based Docker container with Transmission, OpenVPN and FlexGet

License

Notifications You must be signed in to change notification settings

0x022b/alpine-seedbox

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

59 Commits
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Latest Tag Docker Build Docker Pulls

A minimal Alpine Linux based Docker container, that includes Transmission, OpenVPN and FlexGet, which uses s6-overlay to manage the processes.

All traffic from within the container is forced through VPN tunnel by iptables rules and the container is configured to terminate in case VPN connection drops. All other processes will be restarted automatically by s6-supervise if they terminate.

Configuration

DNS servers

An alternative DNS server should be used to prevent DNS leaks. Use the DNS servers provided by the VPN provider or choose an alternative from the list that WikiLeaks has compiled.

OpenVPN

For OpenVPN two configuration files are required. VPN providers usually have already made configuration files that can be used as is as the config.ovpn file. The second file named passwd is used as a value for auth-user-pass parameter and it must contain username on the first line and password on the second line. For more information on how to configure OpenVPN see the official documentation at the website.

Transmission

Transmission doesn't require any special configuration. For information on how to configure Transmission's advanced features see the official documentation at the website.

FlexGet

FlexGet is a tool used to automate content processing tasks. The following snippet can be used as a simple starting point for FlexGet's config.yml file. For information on how to configure FlexGet's more advanced features see the official documentation at the website.

tasks:
  linux:
    rss: http://linuxtracker.org/rss.php
    download: /mnt/torrent/download
    transmission: yes

Mount points

The container requires a couple of mount points to work, which are listed below. Host directories and files can be mounted using -v /host/path:/docker/path commandline argument.

Mandatory

The container requires that at least the following files and directories are mounted from the host.

/mnt/
	flexget/
		config.yml
	openvpn/
		config.ovpn
		login.conf
	torrent/
		.tmp/
		download/
		watch/
	transmission/

Optional

Processes in the container are configured to log their stdout and stderr into the following locations. To persist logs mount a directory as /var/log/ or a file as a single log file.

/var/log/
	flexget/
		stderr.log
		stdout.log
	openvpn/
		stderr.log
		stdout.log
	transmission/
		stderr.log
		stdout.log

SELinux

To use this container on a host that has SELinux enabled use the docker-openvpn.te policy module from the base image which can be downloaded from here or create your own if it doesn't work. To compile and install the policy module run the following commands.

$ checkmodule -M -m docker-openvpn.te -o /tmp/docker-openvpn.mod
$ semodule_package -m /tmp/docker-openvpn.mod -o /tmp/docker-openvpn.pp
# semodule -i /tmp/docker-openvpn.pp

In addition to installing the module volumes must be mounted using the :Z mount option so that Docker will relabel the volumes with a correct security label.

Usage

To run the container interactively execute the following command. Modify the parameters to fit your environment.

# docker run -it --rm --cap-add=NET_ADMIN --device=/dev/net/tun \
	--dns=8.8.8.8 --dns=8.8.4.4 --publish 9091:9091 \
	--volume /home/user/.config/flexget:/mnt/flexget:Z \
	--volume /home/user/.config/openvpn:/mnt/openvpn:Z \
	--volume /home/user/.config/transmission-daemon:/mnt/transmission:Z \
	--volume /home/user/Downloads/Torrents:/mnt/torrent:Z \
	scoobadog/alpine-seedbox:latest

systemd service

A reliable way to start the container at boot time and restart it, if something goes wrong and the container shuts down, is to use systemd to manage the container. Use the following code snippet as a template, modify the parameters to fit your environment and save it as /usr/lib/systemd/system/alpine-seedbox.service.

[Unit]
Description=alpine-seedbox
After=docker.service
Requires=docker.service

[Service]
Restart=always
ExecStart=/usr/bin/docker run \
	--cap-add=NET_ADMIN --device=/dev/net/tun \
	--dns=8.8.8.8 --dns=8.8.4.4 --publish 9091:9091 \
	--volume /home/user/.config/flexget:/mnt/flexget:Z \
	--volume /home/user/.config/openvpn:/mnt/openvpn:Z \
	--volume /home/user/.config/transmission-daemon:/mnt/transmission:Z \
	--volume /home/user/Downloads/Torrents:/mnt/torrent:Z \
	--name seedbox scoobadog/alpine-seedbox:latest
ExecStop=/usr/bin/docker stop -t 10 seedbox
ExecStopPost=/usr/bin/docker rm -f seedbox

[Install]
WantedBy=multi-user.target

To enable and start the service run the following commands.

# systemctl enable alpine-seedbox
# systemctl start alpine-seedbox

License

alpine-seedbox is licensed under the MIT License.

About

Minimal Alpine Linux based Docker container with Transmission, OpenVPN and FlexGet

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages