Homer NixOS container setup
Introduction
Homer describes itself as: A dead simple static HOMepage for your servER to keep your services on hand, from a simple yaml configuration file.
The dashboard is indeed easy to configure, supports dark mode, and allows for tile grouping. You can also add extra features to tiles, such as displaying info about Pi-hole.
Setup
-
Add virtualisation to
configuration.nix
Add
virtualisation
and the import to a seperate nix file for the container toconfiguration.nix
: -
Add the macvlan network to
configuration.nix
The container will use a macvlan network (
net_macvlan
) with a dedicated IP address. Add the following toconfiguration.nix
:Instructions:
- Required Replace
192.168.1.1
with your gateway IP address - Required Replace
192.168.1.0
with your subnet - Required Replace
ens18
with the name of own network interface
- Required Replace
-
Add a script to create folders to
configuration.nix
Make sure the folders for use with the container are created by adding the following to
configuration.nix
:Instructions:
- Required Replace
<username>
with your NixOS username
- Required Replace
-
Create the containers folder
Run the following command:
-
Add the container configuration to
homer.nix
Add the following to
homer.nix
:Instructions:
- Required Replace
Europe/Amsterdam
with your own timezone - Required Replace
<username>
with your NixOS username - Optional Replace
--pull=newer
with--pull=never
if you do not want the image to be automatically replaced by new versions - Optional Replace
net_macvlan
with the name of your macvlan network if needed - Required Replace
<IP address>
with the IP address of this container. Make sure it is within the range of the macvlan network - Required Replace
<MAC address>
a (randomly generated) MAC address. Otherwise, every time the container is started, a new mac address will be used, which for example will be created as a new device within the Unifi Network Application. Or temporarily disable this option, and add the MAC address that is generated the first time when this container is started. Use inspect to get the MAC address if needed:sudo podman inspect <container name> |grep MacAddress|tr -d ' ,"'|sort -u
- Required Replace
-
Switch NixOS configuration
Now you can switch to the new configuration within NixOS, the image will be downloaded and the container will be created:
Run the following command:
-
Check the results
Run the following command to check if the container is working properly:
Now you can browse to the Homer dashboard by opening a web browser and going to:
http://localhost:8080
. Replace localhost with the relevant IP address or FQDN if needed, and adjust the port if you changed it earlier.
No comments found for this note.
Join the discussion for this note on Github. Comments appear on this page instantly.