I need a Domain Name System (DNS) server to control DNS queries and allow my internal and DMZ networks to access the Internet. Due to the low resource requirements, I can use Linux Containers (LXCs) rather than a full VM for these servers. I am going to install a Pi-hole for DNS on an LXC in the DMZ and on the external network. This allows the internal network to forward requests to a server within the domains control without exposing the Active Directory servers to the Internet. Using Pi-hole also allows me to configure a blacklist for certain domains. I use this on my personal network to remove ads which is Pi-hole’s main purpose.
Set up a Linux Container (LXC) for Pi-hole
Prerequisite: Creating a DMZ in pfsense to Separate Internal Servers
Since it’s the first time I am using a Linux Container (LXC) I will walk through the process to set one up in Proxmox. The first step is to get a CT Template since I don’t have one already. I will use the Ubuntu-20.04-standard tempalte.
data:image/s3,"s3://crabby-images/5c55f/5c55f9d316adc6d4fe1e68ed48e502e494e995bf" alt="Image of local storage on vmhost1 showing CT template screen."
data:image/s3,"s3://crabby-images/398c8/398c871ce4d2013d614df44e39c49fbdfe22e980" alt="Selecting ubuntu-20.04-standard as the template for DNS LXCs."
Once the download is complete you can create a LXC container in Proxmox.
data:image/s3,"s3://crabby-images/5f94d/5f94d90d5cbe016b51fea2c806f56c888f6dee65" alt="Example first screen of LXC configuration"
data:image/s3,"s3://crabby-images/778d7/778d725d2eea0152dcd3e8d4339bf5d1bb4aa7ad" alt="Screen showing template selection"
After selecting the template I selected the system resources for the LXC. My DNS servers will have the following resources:
- Disk: 8GB
- CPU cores: 1
- Memory: 512MB / Swap: 512MB
- Network: Bridge for external / DMZ for DMZ server
- Static IP: follows network diagram
- DNS: use host settings for external / external DNS server IP for DMZ
Once you create the LXC the install happens automatically. Once you start it you access using root and the password set during configuration.
data:image/s3,"s3://crabby-images/f0344/f0344f1e25318fa9c60c526f076bfaa612cafed0" alt="pi-hole login page for external DNS"
Install Pi-hole for DNS on the LXC
Like with the other VMs my first step is to update, upgrade, and install dependencies. All I need for Pi-hole is curl to run the command in Pi-hole’s install guide.
# apt update && apt upgrade -y
# apt install curl
data:image/s3,"s3://crabby-images/e9e48/e9e4894120fac2859a945a7ae135d920cc17851c" alt="Install curl using # apt install curl"
After the update and upgrade I rebooted, then I ran the install command.
# curl -sSL https://install.pi-hole.net | bash
data:image/s3,"s3://crabby-images/15471/1547164e5c6e33672a93effca5a50f6186001e26" alt="Install screen after running command"
After running the system checks the Pi-hole automated installer will start.
data:image/s3,"s3://crabby-images/52dbc/52dbc25fcba9b6c9e362f8e18adc673a5306b414" alt="Pi-hole automated installer screen"
From here I chose the following settings for my server:
- Upstream servers: OpenDNS for external / External pi-hole for DMZ
- Blocklists: Yes
- Install Admin Web Interface: Yes
- Web Server: Yes
- Everything else was left default
After that I had a summary page with admin webpage login password.
data:image/s3,"s3://crabby-images/9d033/9d033fb759943e382241ba6704344eefd403cec2" alt="Install complete summary page"
Once the server is finished installing I accessed the web interface, and then logged in to the Pi-hole dashboard.
data:image/s3,"s3://crabby-images/3e172/3e172e5b46b62f622ed14a37a0bb1edcffb86d2a" alt="Pi-hole dashboard after initial login"
Firewall and DHCP changes
I am using the pfsense firewall as my DHCP server so for the DMZ interface I needed to change the DNS servers to the new Pi-hole. I am not changing the LAN interface yet because those machines will eventually use the domain controller for its DNS which will forward requests to the Pi-hole.
data:image/s3,"s3://crabby-images/3cf77/3cf7702cbf53dfff3be30662c1225a9bcefdecbe" alt="Pi-hole DNS changes on pfsense web interface"
Next it’s finally time to build my internal network, starting with a domain controller. Before installing that I am going to create a Windows Server template to streamline future server installs.
0 Comments
2 Pingbacks