Skip to content

AdGuard Home Debian LXC container archive for unRAID

Notifications You must be signed in to change notification settings

Mainfrezzer/unraid_lxc_debian_adguard

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

18 Commits
 
 
 
 
 
 
 
 

Repository files navigation

AdGuard Home LXC container archive for unRAID

Prerequisites

  • unRAID server
  • Properly configured and installed LXC plugin for unRAID
  • Basic understanding of command line usage

Container archive contents

  • Unbound
  • keepalived
  • Cron
  • AdGuard Home

(please note that IPv6 is disabled by default)

LXC Distribution Infromation

  • debian
  • trixie
  • amd64

Table of Contents

  1. Install container
  2. Set root password
  3. Set a static IP
  4. (optional) Configure keepalived
  5. (optional) Confiure cron
  6. (optional) Configure Unbound

Step 1: Install Container archive

  1. Go to the CA App and search for AdGuardHome Debian <- not implemented currently
  2. Select the LXC template and install it <- not implemented currently

Currently only available by manually downloading and installing the template

  1. Open a Unraid terminal and execute wget -O /tmp/lxc_container_template.xml https://raw.githubusercontent.com/mainfrezzer/unraid_lxc_debian_adguard/main/lxc_container_template.xml
  2. Navigate to http://<YourunRAIDIP>/LXCAddTemplate
  3. Make your changes if necessary
  4. Click Apply
  5. Wait for the Done button

Step 2: Set root password

  • Open up a Terminal from the AdGuard Home container (click the container icon and select "Terminal")
  • Type in passwd
  • Type in your prefered password twice (no output is displayed) and press ENTER

Step 3: Set a static IP

This step is highly recommended but not necessary. Usually, it is sufficient for your container to be assigned a random IP address from your DHCP server because the virtual IP address for your DNS should be static and is set in the configure keepalived section.
It is also recommended to change the hostname from the container with the command: hostnamectl set-hostname <HOSTNAME>(replace with your prefered Hostname).

You have multiple options here:

  1. Set a static IP for the container in your DHCP server:
  • Visit the configuration page from your Router/Firewall and assign a static IP and stop/start the container once (restarting the container could lead to unexpected behaviour like that the old IP is keeped until you fully stop and start the container once)
  1. Set a static IP in the container itself (recommended):
  • Type in nano /etc/systemd/network/eth0.network and press ENTER
  • Replace the line DHCP=true with the following code block by copy-paste:
Address=x.x.x.x/24
#Address=xxxx:xxxx:xxxx:x:x:x:x 

Gateway=x.x.x.x
#Gateway=xxxx:xxxx:xxxx:x:x:x:x  

DNS=x.x.x.x
#DNS=xxxx:xxxx:xxxx:x:x:x:x
  • Replace "x.x.x.x" at "Address" with your prefered IP address
  • Replace "x.x.x.x" at "Gateway" with your Gateway IP address
  • Replace "x.x.x.x" at "DNS" with your favourite public DNS server or from your Router
  • (optional) If you need IPv6 uncomment the IPv6 lines and replace them with your IPv6 addresses
  • Save and close the file with "CTRL + X" followed by "Y" and press ENTER
  • Stop/Start the container once (restarting the container could lead to unexpected behaviour like that the old IP is keeped until you fully stop and start the container once)

(optional) Step 4: Configure keepalived

  • Type in nano /etc/keepalived/keepalived.conf
  • Change the "state" to MASTER or BACKUP depending which instance you are configuring (only one MASTER but multiple BACKUP instances are allowed)
  • (optional) change the "virtual_router_id" if you have multiple keepalived instances in your network and you want to use for each instance a separate router
  • Change the "priority" depending if it's a MASTER or BACKUP instance (the MASTER interface should be set to 100 and the BACKUP instance(s) from 1 to 99 <- higher priority is prefered first)
  • Change the password "superstrongpassword" at "auth_pass" (must be the same on all MASTER and BACKUP instances for the current virtual_router_id)
  • Change "x.x.x.x" at "virtual_ipaddress" to the IPv4 address which should have high availability and you want to use for DNS requests (must be the same on all MASTER and BACKUP instances)
  • (optional) if you need IPv6, uncomment the lines as specified in the configuration and specify a static IPv6
  • Save the file by pressing "CTRL + X" followed by "Y" and ENTER
  • Enable keepalived for automatic start from the container with systemctl enable keepalived
  • To start keepalived restart the container or issue systemctl start keepalived

(optional) Step 5: Configure cron

By default the cron schedules for updates are:

  • root.hints: every Sunday at 0:00
  • AdGuard Home update check: every Sunday at 0:15

To change the crontab:

  • Issue crontab -e from a container Terminal
  • Select your prefered editor (in this example nano) by pressing 1 and ENTER
  • Change the crontab accordingly and press "CTRL + X" followed by "Y" and ENTER to save the file

(optional) Step 6: Configure Unbound

  • The configuration from Unbound is located at /etc/unbound/unbound.conf(if you need for example IPv6 or your local subnets doesn't match)
  • Don't forget to restart Unbound with systemctl restart unboundafter editing the file or simply restart the container

Finished

  • Open up the AdGuardHome WebUI by clicking on the container icon and select WebUI
  • Credentials are "admin" and "adguardhome"

About

AdGuard Home Debian LXC container archive for unRAID

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Shell 100.0%