Linux as Time Machine backup server for MacOS systems

originally published: by #

Two paths: Samba and Netatalk

Samba is faster at data transfer, but flakey with powernap and background tasks — backups will probably fail while your MacOS systems are asleep, but it’s what I started with and it will back up faster when it works. (an update with these details coming soon-ish)

Netatalk is slower but can host proper(ish?) Time Machine services over AFP, so your backups will actually work while your MacOS systems nap. this is how I’m currently running things.

Step zero: setting up the filesystem for backups

regardless which path you use, you'll need somewhere to put the backups. I mount a the physical disks that make up my network storage to /drivepool, then mount a fuse filesystem to /srv/share this is only important so that you have the context needed to translate these steps to your own machine.

at the end of the day, you just need a directory to put the backups into. It doesn't need to be encrypted: you're encrypting the Time Machine backups on the host side anyway.

the Netatalk way

first, a few acknowledgements

the overview:

configure user(s) for backup directory access

sudo useradd --no-create-home --home-dir /backup --shell /usr/sbin/nologin timemachine
sudo chown -R timemachine:timemachine /srv/share/backups
sudo chmod og-rwx /srv/share/backups

you'll also want to set a password for the time machine user. This will be important when setting up your MacOS systems.

sudo passwd timemachine

install and configure netatalk/AFP for Time Machine

install netatalk. as with all things this is easy unless your package manager ecosystem makes it hard (debian, alegedly)

sudo apt update && sudo apt install -y netatalk

you'll need to create a file for your netatalk config: /etc/netatalk/afp.conf

[Time Machine]
path = /srv/share/backup
time machine = yes
valid users = timemachine

save that config and restart netatalk

sudo service netatalk restart

and go ahead and add some enteries to systemctl

sudo systemctl enable netatalk.service
sudo systemctl start netatalk.service
sudo systemctl enable avahi-daemon.service
sudo systemctl start avahi-daemon.service

Configuring firewall for Netatalk and Time Machine

ht to Unix & Linux: What ports need to be open for netatalk to work as a Time Machine server on my LAN?

you'll, allegedly, need to following ports open, both tcp and udp (I haven't confirmed every item on this list, but I have them open and it's working):

port protocol
7 upd/tcp
206 upd/tcp
548 upd/tcp
427 upd/tcp
1900 upd/tcp
1935 upd/tcp
5353 upd/tcp

UFW and Netatalk for Time Machine

I use UFW at the moment. you can create a file in /etc/ufw/applications.d/ to hold app or service related rules that can be enabled and disabled with ufw allow <service> and will show up cleanly in response to ufw status, like this:

justin@machine$ sudo ufw status
Status: active

To                         Action      From
--                         ------      ----
[...]
time machine               ALLOW       192.168.1.0/24
[...]

I, creatively, called mine timemachine

[time machine]
title=Time Machine via Netatalk
description=netatalk services for facilitating Time Machine backups
ports=7,206,427,548,1900,1935,5353/tcp|7,206,427,548,1900,1935,5353/udp

enable the rule

sudo ufw allow from {IP adress}/{subnet mask} to any app 

note: <profile name> is, in this case "time machine" not timemachine as you might initially assume based on the file-based configuration.

for more on UFW rules:

Configure your MacOS systems to use the Netatalk server backup destination

out of the box, MacOS may not want to show your fancy new Time Machine server. if that's the case, set your MacOS systems to show unofficial Time Machine destinations.

defaults write com.apple.systempreferences TMShowUnsupportedNetworkVolumes 1

configure Time Machine as usual, and use the username and password set when configuring users and access.

if you have existing backups (I did, as I was switching away from the Samba way), those sparsebundles will be there waiting for you unless you deleted them. Time Machine will ask if you want to use or erase the existing backup. If you want to keep your backups rolling, provide the password for your existing encrypted backups and be on your marry way.

if you get an error while attempting to use the existing backups, it's likely becasue you skipped the -R in chown -R above. ask me how I know.

an upside I hadn't considered with this path is your MacOS systems will not show the Time Machine share as a browseable folder. this might not be a benefit to you, or you may not care. I think it keep things cleaner and less likely that random files end up in the time machine directory.

the Samba way

coming soon