this post was submitted on 04 Feb 2024
28 points (91.2% liked)

Linux

47308 readers
548 users here now

From Wikipedia, the free encyclopedia

Linux is a family of open source Unix-like operating systems based on the Linux kernel, an operating system kernel first released on September 17, 1991 by Linus Torvalds. Linux is typically packaged in a Linux distribution (or distro for short).

Distributions include the Linux kernel and supporting system software and libraries, many of which are provided by the GNU Project. Many Linux distributions use the word "Linux" in their name, but the Free Software Foundation uses the name GNU/Linux to emphasize the importance of GNU software, causing some controversy.

Rules

Related Communities

Community icon by Alpár-Etele Méder, licensed under CC BY 3.0

founded 5 years ago
MODERATORS
 

I have 6 devices that i rsync to a central location to back them up. Ive been using ssh as the -e option. Problem is i use public key with passphrases, meaning to backup all six i need to go to each device and run the backup script. Since i typically backup /etc, /home, and /root this means entering sudo and the ssh passphrase 3x for each device.

I would much prefer a script that runs on back storage device that can pull the data from each device without having to use ssh (encryption is not necessary since all traffic is either local or going through a vpn connection).

I could then put this script in root's crontab or make it a systemd service running as root.

But i dont know how i can remote sync without ssh

you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 3 points 7 months ago (4 children)

Because i don't like have passphraseless keys on my devices, i may just be being paranoid.

[–] [email protected] 8 points 7 months ago

You can create a key pair that is specifically just for this kind of backup transaction.

To limit its affects, create a user and group on each of the devices that are highly restricted.

This is actually the most secure solution that doesn't require an interactive password prompt. The passwordless key only serves this one purpose and has small attack surface.

[–] [email protected] 3 points 7 months ago (1 children)

Look into ssh agent. It's a program that runs in the background and "caches" ssh keys after you unlock them once.

[–] [email protected] 2 points 7 months ago (1 children)

I have tried but it doesn't really work in the script. You load the key into the agent but it still asks for the passphrase

[–] ElderWendigo 1 points 7 months ago (1 children)

As long as you restrict the user of those keys access to an interactive shell and limit access to only the directories rsync needs for backup, it's more like giving the pool boy keys to the pool rather than allowing access to the whole house.

[–] [email protected] 1 points 7 months ago

Well i gave it readonly access to / because i am trying to sync /etc /home and /root. Is there a way to give access to multiple locations?

[–] taladar 0 points 7 months ago (1 children)

It is still many times more secure than using something unencrypted.

If you are truly paranoid you could also use something like borg in append only mode though and put that into a chroot with just the necessary tools on the server side.

[–] [email protected] 2 points 7 months ago

Yeah, i think im gonna look into rrsync and try to set up a user with a password-less key